[ 
https://issues.apache.org/jira/browse/FELIX-261?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#action_12497487
 ] 

Stuart McCulloch commented on FELIX-261:
----------------------------------------

Hi Richard,

What I think is happening is that Maven by default copies and (if necessary) 
filters its resources to target/classes - however, the Include-Resource 
directive as implemented now means BND should copy and (if necessary) filter 
the _original_ resources (that is from src/main/resources, etc.)

For example:

    framework/target/classes/org/apache/felix/framework/Felix.properties

contains the unfiltered resource copied by Maven's default resource setting, 
but:

    framework/target/org.apache.felix.framework-0.9.0-incubator-SNAPSHOT.jar

contains the filtered resource included by the BND Analyzer from 
src/main/resources.

Feel free to open a new issue if you'd like me to investigate turning off the 
normal Maven resource mechanism from inside the bundleplugin.

> maven-bundle-plugin, Include-Resources directive and maven <resources/>
> -----------------------------------------------------------------------
>
>                 Key: FELIX-261
>                 URL: https://issues.apache.org/jira/browse/FELIX-261
>             Project: Felix
>          Issue Type: Improvement
>          Components: Maven Bundle Plugin
>            Reporter: Alin Dreghiciu
>         Assigned To: Richard S. Hall
>         Attachments: FELIX-261-20070413.patch, FELIX-261-20070517.patch, 
> FELIX-261-20070521-add-warning.patch
>
>
> Currently maven-bundle-plugin handling of resources is hardcoded to the usgae 
> of folder "src/main/resources".
> It should instead use the <resources/> folder setting from the pom.
> This is a followup of a discussion from felix mail list and bellow is a 
> possible solution from Stuart McCulloch:
> I think you just need to iterate through the project resource list, for 
> example:
>   /*
>    * I grant license to ASF for inclusion of the following code
>    * in ASF works, as per the Apache Software License
>    */
>   StringBuilder resourcePaths = new StringBuilder();
>   for (Iterator i = project.getResources().iterator(); i.hasNext();) {
>     org.apache.maven.model.Resource resource =
> (org.apache.maven.model.Resource)i.next();
>     if (new File(resource.getDirectory()).exists()) {
>       String path = resource.getDirectory();
>       String base = baseDir.getAbsolutePath();
>       if (path.startsWith(base)) {
>         path = path.substring(base.length() + 1);
>       }
>       if (resourcePaths.length() > 0) {
>         resourcePaths.append(',');
>       }
>       resourcePaths.append(path);
>     }
>   }
>   header(properties, Analyzer.INCLUDE_RESOURCE, resourcePaths);
>   /*** warning: it hasn't been thoroughly tested! ***/
> There should also be a plugin option to turn off this code, just in case ;)
> Also should we be preserving the path layout in the bundle, which requires
> the PATH=PATH form of Include-Resource, or should we flatten resources?
> Perhaps add another plugin option...

-- 
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