[ 
https://issues.apache.org/jira/browse/FELIX-463?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12559035#action_12559035
 ] 

Lucas Galfaso commented on FELIX-463:
-------------------------------------

R 4.1 of the standard has a flow describing the expected behavior and it states 
that this is:
 1. If the class or resource is in a java.* package, the request is delegated 
to the parent class loader. If the resource or class is not found, the search 
fails.
 2. If the class or resource is from a package included in the boot delegation 
list (org.osgi.framework.bootdelegation), then the request is delegated
to the parent class loader. If the class or resource is found there, the search 
ends, otherwise the search continues with the next step.

So Felix Meschberger is right.


> Re: Felix does not start with bootdelegation="*"
> ------------------------------------------------
>
>                 Key: FELIX-463
>                 URL: https://issues.apache.org/jira/browse/FELIX-463
>             Project: Felix
>          Issue Type: Bug
>          Components: Framework
>    Affects Versions: 1.0.0
>         Environment: JDK 1.5.0_06 or 1.6 on Solaris 10/x86
>            Reporter: Sahoo
>            Assignee: Karl Pauls
>            Priority: Minor
>         Attachments: bootdelegation.patch
>
>
> I am having trouble starting Felix when I use 
> -Dorg.osgi.framework.bootdelegation="*". When I run using the following 
> command:
> '/usr/bin/java -Dorg.osgi.framework.bootdelegation="*" -jar bin/felix.jar', 
> it fails like this:
> WARNING: *** Class 'org.apache.felix.shell.impl.Activator' was not found. 
> Bundle 1 does not import package 'org.apache.felix.shell.impl', nor is the 
> package exported by any other bundle or available from the system class 
> loader. *** (java.lang.ClassNotFoundException: *** Class 
> 'org.apache.felix.shell.impl.Activator' was not found. Bundle 1 does not 
> import package 'org.apache.felix.shell.impl', nor is the package exported by 
> any other bundle or available from the system class loader. ***)ERROR: Error 
> starting file:bundle/org.apache.felix.shell-1.1.0-SNAPSHOT.jar 
> (org.osgi.framework.BundleException: Not found: 
> org.apache.felix.shell.impl.Activator)
> java.lang.ClassNotFoundException: org.apache.felix.shell.impl.Activator
>        at 
> org.apache.felix.framework.Felix.createBundleActivator(Felix.java:3438)       
>  at org.apache.felix.framework.Felix._startBundle(Felix.java:1540)
>        at org.apache.felix.framework.Felix.startBundle(Felix.java:1479)
>        at 
> org.apache.felix.framework.Felix.setFrameworkStartLevel(Felix.java:1074)      
>   at org.apache.felix.framework.StartLevelImpl.run(StartLevelImpl.java:258)   
>      at java.lang.Thread.run(Thread.java:595)
> Section #3.8.4, Overall Search Order, of OSGi Service Platform Release 4 spec 
> does not clearly (or I don't understand it well enough) state what should be 
> the behavior. Relevant portions of the spec is given below:
> /1 If the class or resource is in a java.* package, the request is delegated 
> to the parent class loader; otherwise, the search continues with the next 
> step. If the request is delegated to the parent class loader and the class or 
> resource is not found, then the search terminates and the request fails.
> 2 If the class or resource is from a package included in the boot delegation 
> list (org.osgi.framework.bootdelegation), then the request is delegated to 
> the parent class loader. If the class or resource is found there, the search 
> ends.
> /
> Unlike point #1 above, point #2 does not mandate the search to terminate. I 
> can understand the search terminating for java.* packages, but why for other 
> packages? It seems Felix is terminating the search, therefore I am seeing 
> this failure. Can anyone please clarify this? I am using "*, " because I want 
> to see how I can make packages from some library jars available to bundles 
> without having to set org.osgi.framework.system.packages property?
> I am hoping that if I add my library jars in system classpath and set 
> bootdelegation="*", the library jar's content will be automatically available 
> to other bundles even if I don't set org.osgi.framework.system.packages 
> property. Is this not going to work?
> Thanks,
> Sahoo 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to