Modified: 
websites/staging/felix/trunk/content/components/bundle-plugin/xref/org/apache/felix/bundleplugin/BundlePlugin.html
==============================================================================
--- 
websites/staging/felix/trunk/content/components/bundle-plugin/xref/org/apache/felix/bundleplugin/BundlePlugin.html
 (original)
+++ 
websites/staging/felix/trunk/content/components/bundle-plugin/xref/org/apache/felix/bundleplugin/BundlePlugin.html
 Mon Aug 19 08:39:57 2019
@@ -606,1570 +606,1572 @@
 <a class="jxr_linenumber" name="L598" href="#L598">598</a>         
builder.setProperties( sanitize( properties ) );
 <a class="jxr_linenumber" name="L599" href="#L599">599</a>         <strong 
class="jxr_keyword">if</strong> ( classpath != <strong 
class="jxr_keyword">null</strong> )
 <a class="jxr_linenumber" name="L600" href="#L600">600</a>         {
-<a class="jxr_linenumber" name="L601" href="#L601">601</a>             Jar[] 
jars = <strong class="jxr_keyword">new</strong> Jar[ classpath.length ];
+<a class="jxr_linenumber" name="L601" href="#L601">601</a>             
List&lt;Jar&gt; jars = <strong class="jxr_keyword">new</strong> 
ArrayList&lt;&gt;();
 <a class="jxr_linenumber" name="L602" href="#L602">602</a>             <strong 
class="jxr_keyword">for</strong> ( <strong class="jxr_keyword">int</strong> i = 
0; i &lt; classpath.length; i++ ) {
-<a class="jxr_linenumber" name="L603" href="#L603">603</a>                 
jars[i] = <strong class="jxr_keyword">new</strong> Jar( classpath[i].id, 
classpath[i].file );
-<a class="jxr_linenumber" name="L604" href="#L604">604</a>             }
-<a class="jxr_linenumber" name="L605" href="#L605">605</a>             
builder.setClasspath( jars );
-<a class="jxr_linenumber" name="L606" href="#L606">606</a>         }
-<a class="jxr_linenumber" name="L607" href="#L607">607</a> 
-<a class="jxr_linenumber" name="L608" href="#L608">608</a>         <strong 
class="jxr_keyword">return</strong> builder;
-<a class="jxr_linenumber" name="L609" href="#L609">609</a>     }
-<a class="jxr_linenumber" name="L610" href="#L610">610</a> 
-<a class="jxr_linenumber" name="L611" href="#L611">611</a> 
-<a class="jxr_linenumber" name="L612" href="#L612">612</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> Properties sanitize( Properties properties )
-<a class="jxr_linenumber" name="L613" href="#L613">613</a>     {
-<a class="jxr_linenumber" name="L614" href="#L614">614</a>         <em 
class="jxr_comment">// convert any non-String keys/values to Strings</em>
-<a class="jxr_linenumber" name="L615" href="#L615">615</a>         Properties 
sanitizedEntries = <strong class="jxr_keyword">new</strong> Properties();
-<a class="jxr_linenumber" name="L616" href="#L616">616</a>         <strong 
class="jxr_keyword">for</strong> ( 
Iterator&lt;Map.Entry&lt;Object,Object&gt;&gt; itr = 
properties.entrySet().iterator(); itr.hasNext(); )
-<a class="jxr_linenumber" name="L617" href="#L617">617</a>         {
-<a class="jxr_linenumber" name="L618" href="#L618">618</a>             
Map.Entry&lt;Object,Object&gt; entry = itr.next();
-<a class="jxr_linenumber" name="L619" href="#L619">619</a>             <strong 
class="jxr_keyword">if</strong> ( !(entry.getKey() instanceof String) )
-<a class="jxr_linenumber" name="L620" href="#L620">620</a>             {
-<a class="jxr_linenumber" name="L621" href="#L621">621</a>                 
String key = sanitize(entry.getKey());
-<a class="jxr_linenumber" name="L622" href="#L622">622</a>                 
<strong class="jxr_keyword">if</strong> ( !properties.containsKey( key ) )
-<a class="jxr_linenumber" name="L623" href="#L623">623</a>                 {
-<a class="jxr_linenumber" name="L624" href="#L624">624</a>                     
sanitizedEntries.setProperty( key, sanitize( entry.getValue() ) );
-<a class="jxr_linenumber" name="L625" href="#L625">625</a>                 }
-<a class="jxr_linenumber" name="L626" href="#L626">626</a>                 
itr.remove();
-<a class="jxr_linenumber" name="L627" href="#L627">627</a>             }
-<a class="jxr_linenumber" name="L628" href="#L628">628</a>             <strong 
class="jxr_keyword">else</strong> <strong class="jxr_keyword">if</strong> ( 
!(entry.getValue() instanceof String) )
-<a class="jxr_linenumber" name="L629" href="#L629">629</a>             {
-<a class="jxr_linenumber" name="L630" href="#L630">630</a>                 
entry.setValue( sanitize( entry.getValue() ) );
-<a class="jxr_linenumber" name="L631" href="#L631">631</a>             }
-<a class="jxr_linenumber" name="L632" href="#L632">632</a>         }
-<a class="jxr_linenumber" name="L633" href="#L633">633</a>         
properties.putAll( sanitizedEntries );
-<a class="jxr_linenumber" name="L634" href="#L634">634</a>         <strong 
class="jxr_keyword">return</strong> properties;
-<a class="jxr_linenumber" name="L635" href="#L635">635</a>     }
-<a class="jxr_linenumber" name="L636" href="#L636">636</a> 
-<a class="jxr_linenumber" name="L637" href="#L637">637</a> 
-<a class="jxr_linenumber" name="L638" href="#L638">638</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> String sanitize( Object value )
-<a class="jxr_linenumber" name="L639" href="#L639">639</a>     {
-<a class="jxr_linenumber" name="L640" href="#L640">640</a>         <strong 
class="jxr_keyword">if</strong> ( value instanceof String )
-<a class="jxr_linenumber" name="L641" href="#L641">641</a>         {
-<a class="jxr_linenumber" name="L642" href="#L642">642</a>             <strong 
class="jxr_keyword">return</strong> ( String ) value;
-<a class="jxr_linenumber" name="L643" href="#L643">643</a>         }
-<a class="jxr_linenumber" name="L644" href="#L644">644</a>         <strong 
class="jxr_keyword">else</strong> <strong class="jxr_keyword">if</strong> ( 
value instanceof Iterable )
-<a class="jxr_linenumber" name="L645" href="#L645">645</a>         {
-<a class="jxr_linenumber" name="L646" href="#L646">646</a>             String 
delim = <span class="jxr_string">""</span>;
-<a class="jxr_linenumber" name="L647" href="#L647">647</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
-<a class="jxr_linenumber" name="L648" href="#L648">648</a>             <strong 
class="jxr_keyword">for</strong> ( Object i : ( Iterable&lt;?&gt; ) value )
-<a class="jxr_linenumber" name="L649" href="#L649">649</a>             {
-<a class="jxr_linenumber" name="L650" href="#L650">650</a>                 
buf.append( delim ).append( i );
-<a class="jxr_linenumber" name="L651" href="#L651">651</a>                 
delim = <span class="jxr_string">", "</span>;
-<a class="jxr_linenumber" name="L652" href="#L652">652</a>             }
-<a class="jxr_linenumber" name="L653" href="#L653">653</a>             <strong 
class="jxr_keyword">return</strong> buf.toString();
-<a class="jxr_linenumber" name="L654" href="#L654">654</a>         }
-<a class="jxr_linenumber" name="L655" href="#L655">655</a>         <strong 
class="jxr_keyword">else</strong> <strong class="jxr_keyword">if</strong> ( 
value.getClass().isArray() )
-<a class="jxr_linenumber" name="L656" href="#L656">656</a>         {
-<a class="jxr_linenumber" name="L657" href="#L657">657</a>             String 
delim = <span class="jxr_string">""</span>;
-<a class="jxr_linenumber" name="L658" href="#L658">658</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
-<a class="jxr_linenumber" name="L659" href="#L659">659</a>             <strong 
class="jxr_keyword">for</strong> ( <strong class="jxr_keyword">int</strong> i = 
0, len = Array.getLength( value ); i &lt; len; i++ )
-<a class="jxr_linenumber" name="L660" href="#L660">660</a>             {
-<a class="jxr_linenumber" name="L661" href="#L661">661</a>                 
buf.append( delim ).append( Array.get( value, i ) );
-<a class="jxr_linenumber" name="L662" href="#L662">662</a>                 
delim = <span class="jxr_string">", "</span>;
-<a class="jxr_linenumber" name="L663" href="#L663">663</a>             }
-<a class="jxr_linenumber" name="L664" href="#L664">664</a>             <strong 
class="jxr_keyword">return</strong> buf.toString();
-<a class="jxr_linenumber" name="L665" href="#L665">665</a>         }
-<a class="jxr_linenumber" name="L666" href="#L666">666</a>         <strong 
class="jxr_keyword">else</strong>
-<a class="jxr_linenumber" name="L667" href="#L667">667</a>         {
-<a class="jxr_linenumber" name="L668" href="#L668">668</a>             <strong 
class="jxr_keyword">return</strong> String.valueOf( value );
-<a class="jxr_linenumber" name="L669" href="#L669">669</a>         }
-<a class="jxr_linenumber" name="L670" href="#L670">670</a>     }
-<a class="jxr_linenumber" name="L671" href="#L671">671</a> 
-<a class="jxr_linenumber" name="L672" href="#L672">672</a> 
-<a class="jxr_linenumber" name="L673" href="#L673">673</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">void</strong> addMavenInstructions(MavenProject 
currentProject, Builder builder) <strong class="jxr_keyword">throws</strong> 
Exception
-<a class="jxr_linenumber" name="L674" href="#L674">674</a>     {
-<a class="jxr_linenumber" name="L675" href="#L675">675</a>         <strong 
class="jxr_keyword">if</strong> ( currentProject.getBasedir() != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L676" href="#L676">676</a>         {
-<a class="jxr_linenumber" name="L677" href="#L677">677</a>             <em 
class="jxr_comment">// update BND instructions to add included Maven 
resources</em>
-<a class="jxr_linenumber" name="L678" href="#L678">678</a>             
includeMavenResources(currentProject, builder, getLog());
-<a class="jxr_linenumber" name="L679" href="#L679">679</a> 
-<a class="jxr_linenumber" name="L680" href="#L680">680</a>             <em 
class="jxr_comment">// Fixup error messages</em>
-<a class="jxr_linenumber" name="L681" href="#L681">681</a>             
includeJava9Fixups(currentProject, builder);
-<a class="jxr_linenumber" name="L682" href="#L682">682</a> 
-<a class="jxr_linenumber" name="L683" href="#L683">683</a>             <em 
class="jxr_comment">// calculate default export/private settings based on 
sources</em>
-<a class="jxr_linenumber" name="L684" href="#L684">684</a>             
addLocalPackages(outputDirectory, builder);
-<a class="jxr_linenumber" name="L685" href="#L685">685</a> 
-<a class="jxr_linenumber" name="L686" href="#L686">686</a>             <em 
class="jxr_comment">// tell BND where the current project source resides</em>
-<a class="jxr_linenumber" name="L687" href="#L687">687</a>             
addMavenSourcePath(currentProject, builder, getLog());
-<a class="jxr_linenumber" name="L688" href="#L688">688</a>         }
-<a class="jxr_linenumber" name="L689" href="#L689">689</a> 
-<a class="jxr_linenumber" name="L690" href="#L690">690</a>         <em 
class="jxr_comment">// update BND instructions to embed selected Maven 
dependencies</em>
-<a class="jxr_linenumber" name="L691" href="#L691">691</a>         
Collection&lt;Artifact&gt; embeddableArtifacts = getEmbeddableArtifacts( 
currentProject, builder );
-<a class="jxr_linenumber" name="L692" href="#L692">692</a>         <a 
href="../../../../org/apache/felix/bundleplugin/DependencyEmbedder.html">DependencyEmbedder</a>
 dependencyEmbedder = <strong class="jxr_keyword">new</strong> <a 
href="../../../../org/apache/felix/bundleplugin/DependencyEmbedder.html">DependencyEmbedder</a>(getLog(),
 embeddableArtifacts);
-<a class="jxr_linenumber" name="L693" href="#L693">693</a>         
dependencyEmbedder.processHeaders(builder);
-<a class="jxr_linenumber" name="L694" href="#L694">694</a> 
-<a class="jxr_linenumber" name="L695" href="#L695">695</a>         
Collection&lt;Artifact&gt; embeddedArtifacts = 
dependencyEmbedder.getEmbeddedArtifacts();
-<a class="jxr_linenumber" name="L696" href="#L696">696</a>         <strong 
class="jxr_keyword">if</strong> ( !embeddedArtifacts.isEmpty() &amp;&amp; 
createDependencyReducedPom )
-<a class="jxr_linenumber" name="L697" href="#L697">697</a>         {
-<a class="jxr_linenumber" name="L698" href="#L698">698</a>             
Set&lt;String&gt; embeddedIds = <strong class="jxr_keyword">new</strong> 
HashSet&lt;String&gt;();
-<a class="jxr_linenumber" name="L699" href="#L699">699</a>             <strong 
class="jxr_keyword">for</strong> ( Artifact artifact : embeddedArtifacts )
-<a class="jxr_linenumber" name="L700" href="#L700">700</a>             {
-<a class="jxr_linenumber" name="L701" href="#L701">701</a>                 
embeddedIds.add( getId( artifact ) );
-<a class="jxr_linenumber" name="L702" href="#L702">702</a>             }
-<a class="jxr_linenumber" name="L703" href="#L703">703</a>             
createDependencyReducedPom( embeddedIds );
-<a class="jxr_linenumber" name="L704" href="#L704">704</a> 
-<a class="jxr_linenumber" name="L705" href="#L705">705</a>         }
+<a class="jxr_linenumber" name="L603" href="#L603">603</a>                 
<strong class="jxr_keyword">if</strong> ( classpath[i].file.exists() ) {
+<a class="jxr_linenumber" name="L604" href="#L604">604</a>                     
jars.add( <strong class="jxr_keyword">new</strong> Jar( classpath[i].id, 
classpath[i].file ) );
+<a class="jxr_linenumber" name="L605" href="#L605">605</a>                 }
+<a class="jxr_linenumber" name="L606" href="#L606">606</a>             }
+<a class="jxr_linenumber" name="L607" href="#L607">607</a>             
builder.setClasspath( jars );
+<a class="jxr_linenumber" name="L608" href="#L608">608</a>         }
+<a class="jxr_linenumber" name="L609" href="#L609">609</a> 
+<a class="jxr_linenumber" name="L610" href="#L610">610</a>         <strong 
class="jxr_keyword">return</strong> builder;
+<a class="jxr_linenumber" name="L611" href="#L611">611</a>     }
+<a class="jxr_linenumber" name="L612" href="#L612">612</a> 
+<a class="jxr_linenumber" name="L613" href="#L613">613</a> 
+<a class="jxr_linenumber" name="L614" href="#L614">614</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> Properties sanitize( Properties properties )
+<a class="jxr_linenumber" name="L615" href="#L615">615</a>     {
+<a class="jxr_linenumber" name="L616" href="#L616">616</a>         <em 
class="jxr_comment">// convert any non-String keys/values to Strings</em>
+<a class="jxr_linenumber" name="L617" href="#L617">617</a>         Properties 
sanitizedEntries = <strong class="jxr_keyword">new</strong> Properties();
+<a class="jxr_linenumber" name="L618" href="#L618">618</a>         <strong 
class="jxr_keyword">for</strong> ( 
Iterator&lt;Map.Entry&lt;Object,Object&gt;&gt; itr = 
properties.entrySet().iterator(); itr.hasNext(); )
+<a class="jxr_linenumber" name="L619" href="#L619">619</a>         {
+<a class="jxr_linenumber" name="L620" href="#L620">620</a>             
Map.Entry&lt;Object,Object&gt; entry = itr.next();
+<a class="jxr_linenumber" name="L621" href="#L621">621</a>             <strong 
class="jxr_keyword">if</strong> ( !(entry.getKey() instanceof String) )
+<a class="jxr_linenumber" name="L622" href="#L622">622</a>             {
+<a class="jxr_linenumber" name="L623" href="#L623">623</a>                 
String key = sanitize(entry.getKey());
+<a class="jxr_linenumber" name="L624" href="#L624">624</a>                 
<strong class="jxr_keyword">if</strong> ( !properties.containsKey( key ) )
+<a class="jxr_linenumber" name="L625" href="#L625">625</a>                 {
+<a class="jxr_linenumber" name="L626" href="#L626">626</a>                     
sanitizedEntries.setProperty( key, sanitize( entry.getValue() ) );
+<a class="jxr_linenumber" name="L627" href="#L627">627</a>                 }
+<a class="jxr_linenumber" name="L628" href="#L628">628</a>                 
itr.remove();
+<a class="jxr_linenumber" name="L629" href="#L629">629</a>             }
+<a class="jxr_linenumber" name="L630" href="#L630">630</a>             <strong 
class="jxr_keyword">else</strong> <strong class="jxr_keyword">if</strong> ( 
!(entry.getValue() instanceof String) )
+<a class="jxr_linenumber" name="L631" href="#L631">631</a>             {
+<a class="jxr_linenumber" name="L632" href="#L632">632</a>                 
entry.setValue( sanitize( entry.getValue() ) );
+<a class="jxr_linenumber" name="L633" href="#L633">633</a>             }
+<a class="jxr_linenumber" name="L634" href="#L634">634</a>         }
+<a class="jxr_linenumber" name="L635" href="#L635">635</a>         
properties.putAll( sanitizedEntries );
+<a class="jxr_linenumber" name="L636" href="#L636">636</a>         <strong 
class="jxr_keyword">return</strong> properties;
+<a class="jxr_linenumber" name="L637" href="#L637">637</a>     }
+<a class="jxr_linenumber" name="L638" href="#L638">638</a> 
+<a class="jxr_linenumber" name="L639" href="#L639">639</a> 
+<a class="jxr_linenumber" name="L640" href="#L640">640</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> String sanitize( Object value )
+<a class="jxr_linenumber" name="L641" href="#L641">641</a>     {
+<a class="jxr_linenumber" name="L642" href="#L642">642</a>         <strong 
class="jxr_keyword">if</strong> ( value instanceof String )
+<a class="jxr_linenumber" name="L643" href="#L643">643</a>         {
+<a class="jxr_linenumber" name="L644" href="#L644">644</a>             <strong 
class="jxr_keyword">return</strong> ( String ) value;
+<a class="jxr_linenumber" name="L645" href="#L645">645</a>         }
+<a class="jxr_linenumber" name="L646" href="#L646">646</a>         <strong 
class="jxr_keyword">else</strong> <strong class="jxr_keyword">if</strong> ( 
value instanceof Iterable )
+<a class="jxr_linenumber" name="L647" href="#L647">647</a>         {
+<a class="jxr_linenumber" name="L648" href="#L648">648</a>             String 
delim = <span class="jxr_string">""</span>;
+<a class="jxr_linenumber" name="L649" href="#L649">649</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
+<a class="jxr_linenumber" name="L650" href="#L650">650</a>             <strong 
class="jxr_keyword">for</strong> ( Object i : ( Iterable&lt;?&gt; ) value )
+<a class="jxr_linenumber" name="L651" href="#L651">651</a>             {
+<a class="jxr_linenumber" name="L652" href="#L652">652</a>                 
buf.append( delim ).append( i );
+<a class="jxr_linenumber" name="L653" href="#L653">653</a>                 
delim = <span class="jxr_string">", "</span>;
+<a class="jxr_linenumber" name="L654" href="#L654">654</a>             }
+<a class="jxr_linenumber" name="L655" href="#L655">655</a>             <strong 
class="jxr_keyword">return</strong> buf.toString();
+<a class="jxr_linenumber" name="L656" href="#L656">656</a>         }
+<a class="jxr_linenumber" name="L657" href="#L657">657</a>         <strong 
class="jxr_keyword">else</strong> <strong class="jxr_keyword">if</strong> ( 
value.getClass().isArray() )
+<a class="jxr_linenumber" name="L658" href="#L658">658</a>         {
+<a class="jxr_linenumber" name="L659" href="#L659">659</a>             String 
delim = <span class="jxr_string">""</span>;
+<a class="jxr_linenumber" name="L660" href="#L660">660</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
+<a class="jxr_linenumber" name="L661" href="#L661">661</a>             <strong 
class="jxr_keyword">for</strong> ( <strong class="jxr_keyword">int</strong> i = 
0, len = Array.getLength( value ); i &lt; len; i++ )
+<a class="jxr_linenumber" name="L662" href="#L662">662</a>             {
+<a class="jxr_linenumber" name="L663" href="#L663">663</a>                 
buf.append( delim ).append( Array.get( value, i ) );
+<a class="jxr_linenumber" name="L664" href="#L664">664</a>                 
delim = <span class="jxr_string">", "</span>;
+<a class="jxr_linenumber" name="L665" href="#L665">665</a>             }
+<a class="jxr_linenumber" name="L666" href="#L666">666</a>             <strong 
class="jxr_keyword">return</strong> buf.toString();
+<a class="jxr_linenumber" name="L667" href="#L667">667</a>         }
+<a class="jxr_linenumber" name="L668" href="#L668">668</a>         <strong 
class="jxr_keyword">else</strong>
+<a class="jxr_linenumber" name="L669" href="#L669">669</a>         {
+<a class="jxr_linenumber" name="L670" href="#L670">670</a>             <strong 
class="jxr_keyword">return</strong> String.valueOf( value );
+<a class="jxr_linenumber" name="L671" href="#L671">671</a>         }
+<a class="jxr_linenumber" name="L672" href="#L672">672</a>     }
+<a class="jxr_linenumber" name="L673" href="#L673">673</a> 
+<a class="jxr_linenumber" name="L674" href="#L674">674</a> 
+<a class="jxr_linenumber" name="L675" href="#L675">675</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">void</strong> addMavenInstructions(MavenProject 
currentProject, Builder builder) <strong class="jxr_keyword">throws</strong> 
Exception
+<a class="jxr_linenumber" name="L676" href="#L676">676</a>     {
+<a class="jxr_linenumber" name="L677" href="#L677">677</a>         <strong 
class="jxr_keyword">if</strong> ( currentProject.getBasedir() != <strong 
class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L678" href="#L678">678</a>         {
+<a class="jxr_linenumber" name="L679" href="#L679">679</a>             <em 
class="jxr_comment">// update BND instructions to add included Maven 
resources</em>
+<a class="jxr_linenumber" name="L680" href="#L680">680</a>             
includeMavenResources(currentProject, builder, getLog());
+<a class="jxr_linenumber" name="L681" href="#L681">681</a> 
+<a class="jxr_linenumber" name="L682" href="#L682">682</a>             <em 
class="jxr_comment">// Fixup error messages</em>
+<a class="jxr_linenumber" name="L683" href="#L683">683</a>             
includeJava9Fixups(currentProject, builder);
+<a class="jxr_linenumber" name="L684" href="#L684">684</a> 
+<a class="jxr_linenumber" name="L685" href="#L685">685</a>             <em 
class="jxr_comment">// calculate default export/private settings based on 
sources</em>
+<a class="jxr_linenumber" name="L686" href="#L686">686</a>             
addLocalPackages(outputDirectory, builder);
+<a class="jxr_linenumber" name="L687" href="#L687">687</a> 
+<a class="jxr_linenumber" name="L688" href="#L688">688</a>             <em 
class="jxr_comment">// tell BND where the current project source resides</em>
+<a class="jxr_linenumber" name="L689" href="#L689">689</a>             
addMavenSourcePath(currentProject, builder, getLog());
+<a class="jxr_linenumber" name="L690" href="#L690">690</a>         }
+<a class="jxr_linenumber" name="L691" href="#L691">691</a> 
+<a class="jxr_linenumber" name="L692" href="#L692">692</a>         <em 
class="jxr_comment">// update BND instructions to embed selected Maven 
dependencies</em>
+<a class="jxr_linenumber" name="L693" href="#L693">693</a>         
Collection&lt;Artifact&gt; embeddableArtifacts = getEmbeddableArtifacts( 
currentProject, builder );
+<a class="jxr_linenumber" name="L694" href="#L694">694</a>         <a 
href="../../../../org/apache/felix/bundleplugin/DependencyEmbedder.html">DependencyEmbedder</a>
 dependencyEmbedder = <strong class="jxr_keyword">new</strong> <a 
href="../../../../org/apache/felix/bundleplugin/DependencyEmbedder.html">DependencyEmbedder</a>(getLog(),
 embeddableArtifacts);
+<a class="jxr_linenumber" name="L695" href="#L695">695</a>         
dependencyEmbedder.processHeaders(builder);
+<a class="jxr_linenumber" name="L696" href="#L696">696</a> 
+<a class="jxr_linenumber" name="L697" href="#L697">697</a>         
Collection&lt;Artifact&gt; embeddedArtifacts = 
dependencyEmbedder.getEmbeddedArtifacts();
+<a class="jxr_linenumber" name="L698" href="#L698">698</a>         <strong 
class="jxr_keyword">if</strong> ( !embeddedArtifacts.isEmpty() &amp;&amp; 
createDependencyReducedPom )
+<a class="jxr_linenumber" name="L699" href="#L699">699</a>         {
+<a class="jxr_linenumber" name="L700" href="#L700">700</a>             
Set&lt;String&gt; embeddedIds = <strong class="jxr_keyword">new</strong> 
HashSet&lt;String&gt;();
+<a class="jxr_linenumber" name="L701" href="#L701">701</a>             <strong 
class="jxr_keyword">for</strong> ( Artifact artifact : embeddedArtifacts )
+<a class="jxr_linenumber" name="L702" href="#L702">702</a>             {
+<a class="jxr_linenumber" name="L703" href="#L703">703</a>                 
embeddedIds.add( getId( artifact ) );
+<a class="jxr_linenumber" name="L704" href="#L704">704</a>             }
+<a class="jxr_linenumber" name="L705" href="#L705">705</a>             
createDependencyReducedPom( embeddedIds );
 <a class="jxr_linenumber" name="L706" href="#L706">706</a> 
-<a class="jxr_linenumber" name="L707" href="#L707">707</a>         <strong 
class="jxr_keyword">if</strong> ( dumpInstructions != <strong 
class="jxr_keyword">null</strong> || getLog().isDebugEnabled() )
-<a class="jxr_linenumber" name="L708" href="#L708">708</a>         {
-<a class="jxr_linenumber" name="L709" href="#L709">709</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
-<a class="jxr_linenumber" name="L710" href="#L710">710</a>             
getLog().debug( <span class="jxr_string">"BND Instructions:"</span> + NL + 
dumpInstructions( builder.getProperties(), buf ) );
-<a class="jxr_linenumber" name="L711" href="#L711">711</a>             <strong 
class="jxr_keyword">if</strong> ( dumpInstructions != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L712" href="#L712">712</a>             {
-<a class="jxr_linenumber" name="L713" href="#L713">713</a>                 
getLog().info( <span class="jxr_string">"Writing BND instructions to "</span> + 
dumpInstructions );
-<a class="jxr_linenumber" name="L714" href="#L714">714</a>                 
dumpInstructions.getParentFile().mkdirs();
-<a class="jxr_linenumber" name="L715" href="#L715">715</a>                 
FileUtils.fileWrite( dumpInstructions, <span class="jxr_string">"# BND 
instructions"</span> + NL + buf );
-<a class="jxr_linenumber" name="L716" href="#L716">716</a>             }
-<a class="jxr_linenumber" name="L717" href="#L717">717</a>         }
-<a class="jxr_linenumber" name="L718" href="#L718">718</a> 
-<a class="jxr_linenumber" name="L719" href="#L719">719</a> 
+<a class="jxr_linenumber" name="L707" href="#L707">707</a>         }
+<a class="jxr_linenumber" name="L708" href="#L708">708</a> 
+<a class="jxr_linenumber" name="L709" href="#L709">709</a>         <strong 
class="jxr_keyword">if</strong> ( dumpInstructions != <strong 
class="jxr_keyword">null</strong> || getLog().isDebugEnabled() )
+<a class="jxr_linenumber" name="L710" href="#L710">710</a>         {
+<a class="jxr_linenumber" name="L711" href="#L711">711</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
+<a class="jxr_linenumber" name="L712" href="#L712">712</a>             
getLog().debug( <span class="jxr_string">"BND Instructions:"</span> + NL + 
dumpInstructions( builder.getProperties(), buf ) );
+<a class="jxr_linenumber" name="L713" href="#L713">713</a>             <strong 
class="jxr_keyword">if</strong> ( dumpInstructions != <strong 
class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L714" href="#L714">714</a>             {
+<a class="jxr_linenumber" name="L715" href="#L715">715</a>                 
getLog().info( <span class="jxr_string">"Writing BND instructions to "</span> + 
dumpInstructions );
+<a class="jxr_linenumber" name="L716" href="#L716">716</a>                 
dumpInstructions.getParentFile().mkdirs();
+<a class="jxr_linenumber" name="L717" href="#L717">717</a>                 
FileUtils.fileWrite( dumpInstructions, <span class="jxr_string">"# BND 
instructions"</span> + NL + buf );
+<a class="jxr_linenumber" name="L718" href="#L718">718</a>             }
+<a class="jxr_linenumber" name="L719" href="#L719">719</a>         }
 <a class="jxr_linenumber" name="L720" href="#L720">720</a> 
-<a class="jxr_linenumber" name="L721" href="#L721">721</a>         <strong 
class="jxr_keyword">if</strong> ( dumpClasspath != <strong 
class="jxr_keyword">null</strong> || getLog().isDebugEnabled() )
-<a class="jxr_linenumber" name="L722" href="#L722">722</a>         {
-<a class="jxr_linenumber" name="L723" href="#L723">723</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
-<a class="jxr_linenumber" name="L724" href="#L724">724</a>             
getLog().debug(<span class="jxr_string">"BND Classpath:"</span> + NL + 
dumpClasspath(builder.getClasspath(), buf));
-<a class="jxr_linenumber" name="L725" href="#L725">725</a>             <strong 
class="jxr_keyword">if</strong> ( dumpClasspath != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L726" href="#L726">726</a>             {
-<a class="jxr_linenumber" name="L727" href="#L727">727</a>                 
getLog().info( <span class="jxr_string">"Writing BND classpath to "</span> + 
dumpClasspath );
-<a class="jxr_linenumber" name="L728" href="#L728">728</a>                 
dumpClasspath.getParentFile().mkdirs();
-<a class="jxr_linenumber" name="L729" href="#L729">729</a>                 
FileUtils.fileWrite( dumpClasspath, <span class="jxr_string">"# BND 
classpath"</span> + NL + buf );
-<a class="jxr_linenumber" name="L730" href="#L730">730</a>             }
-<a class="jxr_linenumber" name="L731" href="#L731">731</a>         }
-<a class="jxr_linenumber" name="L732" href="#L732">732</a>     }
-<a class="jxr_linenumber" name="L733" href="#L733">733</a> 
-<a class="jxr_linenumber" name="L734" href="#L734">734</a> 
-<a class="jxr_linenumber" name="L735" href="#L735">735</a>     <em 
class="jxr_comment">// We need to find the direct dependencies that have been 
included in the uber JAR so that we can modify the</em>
-<a class="jxr_linenumber" name="L736" href="#L736">736</a>     <em 
class="jxr_comment">// POM accordingly.</em>
-<a class="jxr_linenumber" name="L737" href="#L737">737</a>     <strong 
class="jxr_keyword">private</strong> <strong class="jxr_keyword">void</strong> 
createDependencyReducedPom( Set&lt;String&gt; artifactsToRemove )
-<a class="jxr_linenumber" name="L738" href="#L738">738</a>             <strong 
class="jxr_keyword">throws</strong> IOException, ProjectBuildingException, 
DependencyTreeBuilderException {
-<a class="jxr_linenumber" name="L739" href="#L739">739</a>         Model model 
= project.getOriginalModel();
-<a class="jxr_linenumber" name="L740" href="#L740">740</a>         
List&lt;Dependency&gt; dependencies = <strong class="jxr_keyword">new</strong> 
ArrayList&lt;Dependency&gt;();
-<a class="jxr_linenumber" name="L741" href="#L741">741</a> 
-<a class="jxr_linenumber" name="L742" href="#L742">742</a>         <strong 
class="jxr_keyword">boolean</strong> modified = false;
+<a class="jxr_linenumber" name="L721" href="#L721">721</a> 
+<a class="jxr_linenumber" name="L722" href="#L722">722</a> 
+<a class="jxr_linenumber" name="L723" href="#L723">723</a>         <strong 
class="jxr_keyword">if</strong> ( dumpClasspath != <strong 
class="jxr_keyword">null</strong> || getLog().isDebugEnabled() )
+<a class="jxr_linenumber" name="L724" href="#L724">724</a>         {
+<a class="jxr_linenumber" name="L725" href="#L725">725</a>             
StringBuilder buf = <strong class="jxr_keyword">new</strong> StringBuilder();
+<a class="jxr_linenumber" name="L726" href="#L726">726</a>             
getLog().debug(<span class="jxr_string">"BND Classpath:"</span> + NL + 
dumpClasspath(builder.getClasspath(), buf));
+<a class="jxr_linenumber" name="L727" href="#L727">727</a>             <strong 
class="jxr_keyword">if</strong> ( dumpClasspath != <strong 
class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L728" href="#L728">728</a>             {
+<a class="jxr_linenumber" name="L729" href="#L729">729</a>                 
getLog().info( <span class="jxr_string">"Writing BND classpath to "</span> + 
dumpClasspath );
+<a class="jxr_linenumber" name="L730" href="#L730">730</a>                 
dumpClasspath.getParentFile().mkdirs();
+<a class="jxr_linenumber" name="L731" href="#L731">731</a>                 
FileUtils.fileWrite( dumpClasspath, <span class="jxr_string">"# BND 
classpath"</span> + NL + buf );
+<a class="jxr_linenumber" name="L732" href="#L732">732</a>             }
+<a class="jxr_linenumber" name="L733" href="#L733">733</a>         }
+<a class="jxr_linenumber" name="L734" href="#L734">734</a>     }
+<a class="jxr_linenumber" name="L735" href="#L735">735</a> 
+<a class="jxr_linenumber" name="L736" href="#L736">736</a> 
+<a class="jxr_linenumber" name="L737" href="#L737">737</a>     <em 
class="jxr_comment">// We need to find the direct dependencies that have been 
included in the uber JAR so that we can modify the</em>
+<a class="jxr_linenumber" name="L738" href="#L738">738</a>     <em 
class="jxr_comment">// POM accordingly.</em>
+<a class="jxr_linenumber" name="L739" href="#L739">739</a>     <strong 
class="jxr_keyword">private</strong> <strong class="jxr_keyword">void</strong> 
createDependencyReducedPom( Set&lt;String&gt; artifactsToRemove )
+<a class="jxr_linenumber" name="L740" href="#L740">740</a>             <strong 
class="jxr_keyword">throws</strong> IOException, ProjectBuildingException, 
DependencyTreeBuilderException {
+<a class="jxr_linenumber" name="L741" href="#L741">741</a>         Model model 
= project.getOriginalModel();
+<a class="jxr_linenumber" name="L742" href="#L742">742</a>         
List&lt;Dependency&gt; dependencies = <strong class="jxr_keyword">new</strong> 
ArrayList&lt;Dependency&gt;();
 <a class="jxr_linenumber" name="L743" href="#L743">743</a> 
-<a class="jxr_linenumber" name="L744" href="#L744">744</a>         
List&lt;Dependency&gt; transitiveDeps = <strong 
class="jxr_keyword">new</strong> ArrayList&lt;Dependency&gt;();
+<a class="jxr_linenumber" name="L744" href="#L744">744</a>         <strong 
class="jxr_keyword">boolean</strong> modified = false;
 <a class="jxr_linenumber" name="L745" href="#L745">745</a> 
-<a class="jxr_linenumber" name="L746" href="#L746">746</a>         <strong 
class="jxr_keyword">for</strong> ( Artifact artifact : project.getArtifacts() )
-<a class="jxr_linenumber" name="L747" href="#L747">747</a>         {
-<a class="jxr_linenumber" name="L748" href="#L748">748</a>             <strong 
class="jxr_keyword">if</strong> ( <span class="jxr_string">"pom"</span>.equals( 
artifact.getType() ) )
-<a class="jxr_linenumber" name="L749" href="#L749">749</a>             {
-<a class="jxr_linenumber" name="L750" href="#L750">750</a>                 <em 
class="jxr_comment">// don't include pom type dependencies in dependency 
reduced pom</em>
-<a class="jxr_linenumber" name="L751" href="#L751">751</a>                 
<strong class="jxr_keyword">continue</strong>;
-<a class="jxr_linenumber" name="L752" href="#L752">752</a>             }
-<a class="jxr_linenumber" name="L753" href="#L753">753</a> 
-<a class="jxr_linenumber" name="L754" href="#L754">754</a>             <em 
class="jxr_comment">//promote</em>
-<a class="jxr_linenumber" name="L755" href="#L755">755</a>             
Dependency dep = <strong class="jxr_keyword">new</strong> Dependency();
-<a class="jxr_linenumber" name="L756" href="#L756">756</a>             
dep.setArtifactId( artifact.getArtifactId() );
-<a class="jxr_linenumber" name="L757" href="#L757">757</a>             <strong 
class="jxr_keyword">if</strong> ( artifact.hasClassifier() )
-<a class="jxr_linenumber" name="L758" href="#L758">758</a>             {
-<a class="jxr_linenumber" name="L759" href="#L759">759</a>                 
dep.setClassifier( artifact.getClassifier() );
-<a class="jxr_linenumber" name="L760" href="#L760">760</a>             }
-<a class="jxr_linenumber" name="L761" href="#L761">761</a>             
dep.setGroupId( artifact.getGroupId() );
-<a class="jxr_linenumber" name="L762" href="#L762">762</a>             
dep.setOptional( artifact.isOptional() );
-<a class="jxr_linenumber" name="L763" href="#L763">763</a>             
dep.setScope( artifact.getScope() );
-<a class="jxr_linenumber" name="L764" href="#L764">764</a>             
dep.setType( artifact.getType() );
-<a class="jxr_linenumber" name="L765" href="#L765">765</a>             
dep.setVersion( artifact.getVersion() );
-<a class="jxr_linenumber" name="L766" href="#L766">766</a> 
-<a class="jxr_linenumber" name="L767" href="#L767">767</a>             <em 
class="jxr_comment">//we'll figure out the exclusions in a bit.</em>
+<a class="jxr_linenumber" name="L746" href="#L746">746</a>         
List&lt;Dependency&gt; transitiveDeps = <strong 
class="jxr_keyword">new</strong> ArrayList&lt;Dependency&gt;();
+<a class="jxr_linenumber" name="L747" href="#L747">747</a> 
+<a class="jxr_linenumber" name="L748" href="#L748">748</a>         <strong 
class="jxr_keyword">for</strong> ( Artifact artifact : project.getArtifacts() )
+<a class="jxr_linenumber" name="L749" href="#L749">749</a>         {
+<a class="jxr_linenumber" name="L750" href="#L750">750</a>             <strong 
class="jxr_keyword">if</strong> ( <span class="jxr_string">"pom"</span>.equals( 
artifact.getType() ) )
+<a class="jxr_linenumber" name="L751" href="#L751">751</a>             {
+<a class="jxr_linenumber" name="L752" href="#L752">752</a>                 <em 
class="jxr_comment">// don't include pom type dependencies in dependency 
reduced pom</em>
+<a class="jxr_linenumber" name="L753" href="#L753">753</a>                 
<strong class="jxr_keyword">continue</strong>;
+<a class="jxr_linenumber" name="L754" href="#L754">754</a>             }
+<a class="jxr_linenumber" name="L755" href="#L755">755</a> 
+<a class="jxr_linenumber" name="L756" href="#L756">756</a>             <em 
class="jxr_comment">//promote</em>
+<a class="jxr_linenumber" name="L757" href="#L757">757</a>             
Dependency dep = <strong class="jxr_keyword">new</strong> Dependency();
+<a class="jxr_linenumber" name="L758" href="#L758">758</a>             
dep.setArtifactId( artifact.getArtifactId() );
+<a class="jxr_linenumber" name="L759" href="#L759">759</a>             <strong 
class="jxr_keyword">if</strong> ( artifact.hasClassifier() )
+<a class="jxr_linenumber" name="L760" href="#L760">760</a>             {
+<a class="jxr_linenumber" name="L761" href="#L761">761</a>                 
dep.setClassifier( artifact.getClassifier() );
+<a class="jxr_linenumber" name="L762" href="#L762">762</a>             }
+<a class="jxr_linenumber" name="L763" href="#L763">763</a>             
dep.setGroupId( artifact.getGroupId() );
+<a class="jxr_linenumber" name="L764" href="#L764">764</a>             
dep.setOptional( artifact.isOptional() );
+<a class="jxr_linenumber" name="L765" href="#L765">765</a>             
dep.setScope( artifact.getScope() );
+<a class="jxr_linenumber" name="L766" href="#L766">766</a>             
dep.setType( artifact.getType() );
+<a class="jxr_linenumber" name="L767" href="#L767">767</a>             
dep.setVersion( artifact.getVersion() );
 <a class="jxr_linenumber" name="L768" href="#L768">768</a> 
-<a class="jxr_linenumber" name="L769" href="#L769">769</a>             
transitiveDeps.add( dep );
-<a class="jxr_linenumber" name="L770" href="#L770">770</a>         }
-<a class="jxr_linenumber" name="L771" href="#L771">771</a>         
List&lt;Dependency&gt; origDeps = project.getDependencies();
-<a class="jxr_linenumber" name="L772" href="#L772">772</a> 
-<a class="jxr_linenumber" name="L773" href="#L773">773</a>         <strong 
class="jxr_keyword">for</strong> (Dependency d : origDeps)
-<a class="jxr_linenumber" name="L774" href="#L774">774</a>         {
-<a class="jxr_linenumber" name="L775" href="#L775">775</a>             
dependencies.add(d);
-<a class="jxr_linenumber" name="L776" href="#L776">776</a> 
-<a class="jxr_linenumber" name="L777" href="#L777">777</a>             String 
id = getId(d);
+<a class="jxr_linenumber" name="L769" href="#L769">769</a>             <em 
class="jxr_comment">//we'll figure out the exclusions in a bit.</em>
+<a class="jxr_linenumber" name="L770" href="#L770">770</a> 
+<a class="jxr_linenumber" name="L771" href="#L771">771</a>             
transitiveDeps.add( dep );
+<a class="jxr_linenumber" name="L772" href="#L772">772</a>         }
+<a class="jxr_linenumber" name="L773" href="#L773">773</a>         
List&lt;Dependency&gt; origDeps = project.getDependencies();
+<a class="jxr_linenumber" name="L774" href="#L774">774</a> 
+<a class="jxr_linenumber" name="L775" href="#L775">775</a>         <strong 
class="jxr_keyword">for</strong> (Dependency d : origDeps)
+<a class="jxr_linenumber" name="L776" href="#L776">776</a>         {
+<a class="jxr_linenumber" name="L777" href="#L777">777</a>             
dependencies.add(d);
 <a class="jxr_linenumber" name="L778" href="#L778">778</a> 
-<a class="jxr_linenumber" name="L779" href="#L779">779</a>             <strong 
class="jxr_keyword">if</strong> (artifactsToRemove.contains(id))
-<a class="jxr_linenumber" name="L780" href="#L780">780</a>             {
-<a class="jxr_linenumber" name="L781" href="#L781">781</a>                 
modified = <strong class="jxr_keyword">true</strong>;
-<a class="jxr_linenumber" name="L782" href="#L782">782</a> 
-<a class="jxr_linenumber" name="L783" href="#L783">783</a>                 
dependencies.remove(d);
-<a class="jxr_linenumber" name="L784" href="#L784">784</a>             }
-<a class="jxr_linenumber" name="L785" href="#L785">785</a>         }
-<a class="jxr_linenumber" name="L786" href="#L786">786</a> 
-<a class="jxr_linenumber" name="L787" href="#L787">787</a>         <em 
class="jxr_comment">// Check to see if we have a reduction and if so rewrite 
the POM.</em>
-<a class="jxr_linenumber" name="L788" href="#L788">788</a>         <strong 
class="jxr_keyword">if</strong> ( modified )
-<a class="jxr_linenumber" name="L789" href="#L789">789</a>         {
-<a class="jxr_linenumber" name="L790" href="#L790">790</a>             <strong 
class="jxr_keyword">while</strong> ( modified )
-<a class="jxr_linenumber" name="L791" href="#L791">791</a>             {
-<a class="jxr_linenumber" name="L792" href="#L792">792</a> 
-<a class="jxr_linenumber" name="L793" href="#L793">793</a>                 
model.setDependencies( dependencies );
+<a class="jxr_linenumber" name="L779" href="#L779">779</a>             String 
id = getId(d);
+<a class="jxr_linenumber" name="L780" href="#L780">780</a> 
+<a class="jxr_linenumber" name="L781" href="#L781">781</a>             <strong 
class="jxr_keyword">if</strong> (artifactsToRemove.contains(id))
+<a class="jxr_linenumber" name="L782" href="#L782">782</a>             {
+<a class="jxr_linenumber" name="L783" href="#L783">783</a>                 
modified = <strong class="jxr_keyword">true</strong>;
+<a class="jxr_linenumber" name="L784" href="#L784">784</a> 
+<a class="jxr_linenumber" name="L785" href="#L785">785</a>                 
dependencies.remove(d);
+<a class="jxr_linenumber" name="L786" href="#L786">786</a>             }
+<a class="jxr_linenumber" name="L787" href="#L787">787</a>         }
+<a class="jxr_linenumber" name="L788" href="#L788">788</a> 
+<a class="jxr_linenumber" name="L789" href="#L789">789</a>         <em 
class="jxr_comment">// Check to see if we have a reduction and if so rewrite 
the POM.</em>
+<a class="jxr_linenumber" name="L790" href="#L790">790</a>         <strong 
class="jxr_keyword">if</strong> ( modified )
+<a class="jxr_linenumber" name="L791" href="#L791">791</a>         {
+<a class="jxr_linenumber" name="L792" href="#L792">792</a>             <strong 
class="jxr_keyword">while</strong> ( modified )
+<a class="jxr_linenumber" name="L793" href="#L793">793</a>             {
 <a class="jxr_linenumber" name="L794" href="#L794">794</a> 
-<a class="jxr_linenumber" name="L795" href="#L795">795</a>                 
<strong class="jxr_keyword">if</strong> ( dependencyReducedPomLocation == 
<strong class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L796" href="#L796">796</a>                 {
-<a class="jxr_linenumber" name="L797" href="#L797">797</a>                     
<em class="jxr_comment">// MSHADE-123: We can't default to 'target' because it 
messes up uses of ${project.basedir}</em>
-<a class="jxr_linenumber" name="L798" href="#L798">798</a>                     
dependencyReducedPomLocation = <strong class="jxr_keyword">new</strong> File ( 
project.getBasedir(), <span 
class="jxr_string">"dependency-reduced-pom.xml"</span> );
-<a class="jxr_linenumber" name="L799" href="#L799">799</a>                 }
-<a class="jxr_linenumber" name="L800" href="#L800">800</a> 
-<a class="jxr_linenumber" name="L801" href="#L801">801</a>                 
File f = dependencyReducedPomLocation;
-<a class="jxr_linenumber" name="L802" href="#L802">802</a>                 
<strong class="jxr_keyword">if</strong> ( f.exists() )
-<a class="jxr_linenumber" name="L803" href="#L803">803</a>                 {
-<a class="jxr_linenumber" name="L804" href="#L804">804</a>                     
f.delete();
-<a class="jxr_linenumber" name="L805" href="#L805">805</a>                 }
-<a class="jxr_linenumber" name="L806" href="#L806">806</a> 
-<a class="jxr_linenumber" name="L807" href="#L807">807</a>                 
Writer w = WriterFactory.newXmlWriter( f );
+<a class="jxr_linenumber" name="L795" href="#L795">795</a>                 
model.setDependencies( dependencies );
+<a class="jxr_linenumber" name="L796" href="#L796">796</a> 
+<a class="jxr_linenumber" name="L797" href="#L797">797</a>                 
<strong class="jxr_keyword">if</strong> ( dependencyReducedPomLocation == 
<strong class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L798" href="#L798">798</a>                 {
+<a class="jxr_linenumber" name="L799" href="#L799">799</a>                     
<em class="jxr_comment">// MSHADE-123: We can't default to 'target' because it 
messes up uses of ${project.basedir}</em>
+<a class="jxr_linenumber" name="L800" href="#L800">800</a>                     
dependencyReducedPomLocation = <strong class="jxr_keyword">new</strong> File ( 
project.getBasedir(), <span 
class="jxr_string">"dependency-reduced-pom.xml"</span> );
+<a class="jxr_linenumber" name="L801" href="#L801">801</a>                 }
+<a class="jxr_linenumber" name="L802" href="#L802">802</a> 
+<a class="jxr_linenumber" name="L803" href="#L803">803</a>                 
File f = dependencyReducedPomLocation;
+<a class="jxr_linenumber" name="L804" href="#L804">804</a>                 
<strong class="jxr_keyword">if</strong> ( f.exists() )
+<a class="jxr_linenumber" name="L805" href="#L805">805</a>                 {
+<a class="jxr_linenumber" name="L806" href="#L806">806</a>                     
f.delete();
+<a class="jxr_linenumber" name="L807" href="#L807">807</a>                 }
 <a class="jxr_linenumber" name="L808" href="#L808">808</a> 
-<a class="jxr_linenumber" name="L809" href="#L809">809</a>                 
String origRelativePath = <strong class="jxr_keyword">null</strong>;
-<a class="jxr_linenumber" name="L810" href="#L810">810</a>                 
String replaceRelativePath = <strong class="jxr_keyword">null</strong>;
-<a class="jxr_linenumber" name="L811" href="#L811">811</a>                 
<strong class="jxr_keyword">if</strong> ( model.getParent() != <strong 
class="jxr_keyword">null</strong>)
-<a class="jxr_linenumber" name="L812" href="#L812">812</a>                 {
-<a class="jxr_linenumber" name="L813" href="#L813">813</a>                     
origRelativePath = model.getParent().getRelativePath();
-<a class="jxr_linenumber" name="L814" href="#L814">814</a> 
-<a class="jxr_linenumber" name="L815" href="#L815">815</a>                 }
-<a class="jxr_linenumber" name="L816" href="#L816">816</a>                 
replaceRelativePath = origRelativePath;
-<a class="jxr_linenumber" name="L817" href="#L817">817</a> 
-<a class="jxr_linenumber" name="L818" href="#L818">818</a>                 
<strong class="jxr_keyword">if</strong> ( origRelativePath == <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L819" href="#L819">819</a>                 {
-<a class="jxr_linenumber" name="L820" href="#L820">820</a>                     
origRelativePath = <span class="jxr_string">"../pom.xml"</span>;
-<a class="jxr_linenumber" name="L821" href="#L821">821</a>                 }
-<a class="jxr_linenumber" name="L822" href="#L822">822</a> 
-<a class="jxr_linenumber" name="L823" href="#L823">823</a>                 
<strong class="jxr_keyword">if</strong> ( model.getParent() != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L824" href="#L824">824</a>                 {
-<a class="jxr_linenumber" name="L825" href="#L825">825</a>                     
File parentFile = <strong class="jxr_keyword">new</strong> File( 
project.getBasedir(), model.getParent().getRelativePath() ).getCanonicalFile();
-<a class="jxr_linenumber" name="L826" href="#L826">826</a>                     
<strong class="jxr_keyword">if</strong> ( !parentFile.isFile() )
-<a class="jxr_linenumber" name="L827" href="#L827">827</a>                     
{
-<a class="jxr_linenumber" name="L828" href="#L828">828</a>                     
    parentFile = <strong class="jxr_keyword">new</strong> File( parentFile, 
<span class="jxr_string">"pom.xml"</span>);
-<a class="jxr_linenumber" name="L829" href="#L829">829</a>                     
}
-<a class="jxr_linenumber" name="L830" href="#L830">830</a> 
-<a class="jxr_linenumber" name="L831" href="#L831">831</a>                     
parentFile = parentFile.getCanonicalFile();
+<a class="jxr_linenumber" name="L809" href="#L809">809</a>                 
Writer w = WriterFactory.newXmlWriter( f );
+<a class="jxr_linenumber" name="L810" href="#L810">810</a> 
+<a class="jxr_linenumber" name="L811" href="#L811">811</a>                 
String origRelativePath = <strong class="jxr_keyword">null</strong>;
+<a class="jxr_linenumber" name="L812" href="#L812">812</a>                 
String replaceRelativePath = <strong class="jxr_keyword">null</strong>;
+<a class="jxr_linenumber" name="L813" href="#L813">813</a>                 
<strong class="jxr_keyword">if</strong> ( model.getParent() != <strong 
class="jxr_keyword">null</strong>)
+<a class="jxr_linenumber" name="L814" href="#L814">814</a>                 {
+<a class="jxr_linenumber" name="L815" href="#L815">815</a>                     
origRelativePath = model.getParent().getRelativePath();
+<a class="jxr_linenumber" name="L816" href="#L816">816</a> 
+<a class="jxr_linenumber" name="L817" href="#L817">817</a>                 }
+<a class="jxr_linenumber" name="L818" href="#L818">818</a>                 
replaceRelativePath = origRelativePath;
+<a class="jxr_linenumber" name="L819" href="#L819">819</a> 
+<a class="jxr_linenumber" name="L820" href="#L820">820</a>                 
<strong class="jxr_keyword">if</strong> ( origRelativePath == <strong 
class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L821" href="#L821">821</a>                 {
+<a class="jxr_linenumber" name="L822" href="#L822">822</a>                     
origRelativePath = <span class="jxr_string">"../pom.xml"</span>;
+<a class="jxr_linenumber" name="L823" href="#L823">823</a>                 }
+<a class="jxr_linenumber" name="L824" href="#L824">824</a> 
+<a class="jxr_linenumber" name="L825" href="#L825">825</a>                 
<strong class="jxr_keyword">if</strong> ( model.getParent() != <strong 
class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L826" href="#L826">826</a>                 {
+<a class="jxr_linenumber" name="L827" href="#L827">827</a>                     
File parentFile = <strong class="jxr_keyword">new</strong> File( 
project.getBasedir(), model.getParent().getRelativePath() ).getCanonicalFile();
+<a class="jxr_linenumber" name="L828" href="#L828">828</a>                     
<strong class="jxr_keyword">if</strong> ( !parentFile.isFile() )
+<a class="jxr_linenumber" name="L829" href="#L829">829</a>                     
{
+<a class="jxr_linenumber" name="L830" href="#L830">830</a>                     
    parentFile = <strong class="jxr_keyword">new</strong> File( parentFile, 
<span class="jxr_string">"pom.xml"</span>);
+<a class="jxr_linenumber" name="L831" href="#L831">831</a>                     
}
 <a class="jxr_linenumber" name="L832" href="#L832">832</a> 
-<a class="jxr_linenumber" name="L833" href="#L833">833</a>                     
String relPath = RelativizePath.convertToRelativePath( parentFile, f );
-<a class="jxr_linenumber" name="L834" href="#L834">834</a>                     
model.getParent().setRelativePath( relPath );
-<a class="jxr_linenumber" name="L835" href="#L835">835</a>                 }
-<a class="jxr_linenumber" name="L836" href="#L836">836</a> 
-<a class="jxr_linenumber" name="L837" href="#L837">837</a>                 
<strong class="jxr_keyword">try</strong>
-<a class="jxr_linenumber" name="L838" href="#L838">838</a>                 {
-<a class="jxr_linenumber" name="L839" href="#L839">839</a>                     
PomWriter.write( w, model, <strong class="jxr_keyword">true</strong> );
-<a class="jxr_linenumber" name="L840" href="#L840">840</a>                 }
-<a class="jxr_linenumber" name="L841" href="#L841">841</a>                 
<strong class="jxr_keyword">finally</strong>
-<a class="jxr_linenumber" name="L842" href="#L842">842</a>                 {
-<a class="jxr_linenumber" name="L843" href="#L843">843</a>                     
<strong class="jxr_keyword">if</strong> ( model.getParent() != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L844" href="#L844">844</a>                     
{
-<a class="jxr_linenumber" name="L845" href="#L845">845</a>                     
    model.getParent().setRelativePath( replaceRelativePath );
-<a class="jxr_linenumber" name="L846" href="#L846">846</a>                     
}
-<a class="jxr_linenumber" name="L847" href="#L847">847</a>                     
w.close();
-<a class="jxr_linenumber" name="L848" href="#L848">848</a>                 }
-<a class="jxr_linenumber" name="L849" href="#L849">849</a> 
-<a class="jxr_linenumber" name="L850" href="#L850">850</a>                 
MavenProject p2 = mavenProjectBuilder.build( f, localRepository, <strong 
class="jxr_keyword">null</strong> );
-<a class="jxr_linenumber" name="L851" href="#L851">851</a>                 
modified = updateExcludesInDeps( p2, dependencies, transitiveDeps );
-<a class="jxr_linenumber" name="L852" href="#L852">852</a> 
-<a class="jxr_linenumber" name="L853" href="#L853">853</a>             }
+<a class="jxr_linenumber" name="L833" href="#L833">833</a>                     
parentFile = parentFile.getCanonicalFile();
+<a class="jxr_linenumber" name="L834" href="#L834">834</a> 
+<a class="jxr_linenumber" name="L835" href="#L835">835</a>                     
String relPath = RelativizePath.convertToRelativePath( parentFile, f );
+<a class="jxr_linenumber" name="L836" href="#L836">836</a>                     
model.getParent().setRelativePath( relPath );
+<a class="jxr_linenumber" name="L837" href="#L837">837</a>                 }
+<a class="jxr_linenumber" name="L838" href="#L838">838</a> 
+<a class="jxr_linenumber" name="L839" href="#L839">839</a>                 
<strong class="jxr_keyword">try</strong>
+<a class="jxr_linenumber" name="L840" href="#L840">840</a>                 {
+<a class="jxr_linenumber" name="L841" href="#L841">841</a>                     
PomWriter.write( w, model, <strong class="jxr_keyword">true</strong> );
+<a class="jxr_linenumber" name="L842" href="#L842">842</a>                 }
+<a class="jxr_linenumber" name="L843" href="#L843">843</a>                 
<strong class="jxr_keyword">finally</strong>
+<a class="jxr_linenumber" name="L844" href="#L844">844</a>                 {
+<a class="jxr_linenumber" name="L845" href="#L845">845</a>                     
<strong class="jxr_keyword">if</strong> ( model.getParent() != <strong 
class="jxr_keyword">null</strong> )
+<a class="jxr_linenumber" name="L846" href="#L846">846</a>                     
{
+<a class="jxr_linenumber" name="L847" href="#L847">847</a>                     
    model.getParent().setRelativePath( replaceRelativePath );
+<a class="jxr_linenumber" name="L848" href="#L848">848</a>                     
}
+<a class="jxr_linenumber" name="L849" href="#L849">849</a>                     
w.close();
+<a class="jxr_linenumber" name="L850" href="#L850">850</a>                 }
+<a class="jxr_linenumber" name="L851" href="#L851">851</a> 
+<a class="jxr_linenumber" name="L852" href="#L852">852</a>                 
MavenProject p2 = mavenProjectBuilder.build( f, localRepository, <strong 
class="jxr_keyword">null</strong> );
+<a class="jxr_linenumber" name="L853" href="#L853">853</a>                 
modified = updateExcludesInDeps( p2, dependencies, transitiveDeps );
 <a class="jxr_linenumber" name="L854" href="#L854">854</a> 
-<a class="jxr_linenumber" name="L855" href="#L855">855</a>             
project.setFile( dependencyReducedPomLocation );
-<a class="jxr_linenumber" name="L856" href="#L856">856</a>         }
-<a class="jxr_linenumber" name="L857" href="#L857">857</a>     }
-<a class="jxr_linenumber" name="L858" href="#L858">858</a> 
-<a class="jxr_linenumber" name="L859" href="#L859">859</a>     <strong 
class="jxr_keyword">private</strong> String getId( Artifact artifact )
-<a class="jxr_linenumber" name="L860" href="#L860">860</a>     {
-<a class="jxr_linenumber" name="L861" href="#L861">861</a>         <strong 
class="jxr_keyword">return</strong> getId( artifact.getGroupId(), 
artifact.getArtifactId(), artifact.getType(), artifact.getClassifier() );
-<a class="jxr_linenumber" name="L862" href="#L862">862</a>     }
-<a class="jxr_linenumber" name="L863" href="#L863">863</a> 
-<a class="jxr_linenumber" name="L864" href="#L864">864</a>     <strong 
class="jxr_keyword">private</strong> String getId( Dependency dependency )
-<a class="jxr_linenumber" name="L865" href="#L865">865</a>     {
-<a class="jxr_linenumber" name="L866" href="#L866">866</a>         <strong 
class="jxr_keyword">return</strong> getId( dependency.getGroupId(), 
dependency.getArtifactId(), dependency.getType(),
-<a class="jxr_linenumber" name="L867" href="#L867">867</a>                 
dependency.getClassifier() );
-<a class="jxr_linenumber" name="L868" href="#L868">868</a>     }
-<a class="jxr_linenumber" name="L869" href="#L869">869</a> 
-<a class="jxr_linenumber" name="L870" href="#L870">870</a>     <strong 
class="jxr_keyword">private</strong> String getId( String groupId, String 
artifactId, String type, String classifier )
-<a class="jxr_linenumber" name="L871" href="#L871">871</a>     {
-<a class="jxr_linenumber" name="L872" href="#L872">872</a>         <strong 
class="jxr_keyword">return</strong> groupId + <span 
class="jxr_string">":"</span> + artifactId + <span 
class="jxr_string">":"</span> + type + <span class="jxr_string">":"</span> + ( 
( classifier != <strong class="jxr_keyword">null</strong> ) ? classifier : 
<span class="jxr_string">""</span> );
-<a class="jxr_linenumber" name="L873" href="#L873">873</a>     }
-<a class="jxr_linenumber" name="L874" href="#L874">874</a> 
-<a class="jxr_linenumber" name="L875" href="#L875">875</a>     <strong 
class="jxr_keyword">public</strong> <strong 
class="jxr_keyword">boolean</strong> updateExcludesInDeps( MavenProject 
project, List&lt;Dependency&gt; dependencies, List&lt;Dependency&gt; 
transitiveDeps )
-<a class="jxr_linenumber" name="L876" href="#L876">876</a>             <strong 
class="jxr_keyword">throws</strong> DependencyTreeBuilderException
-<a class="jxr_linenumber" name="L877" href="#L877">877</a>     {
-<a class="jxr_linenumber" name="L878" href="#L878">878</a>         
org.apache.maven.shared.dependency.tree.DependencyNode node = 
dependencyTreeBuilder.buildDependencyTree(project, localRepository, 
artifactFactory,
-<a class="jxr_linenumber" name="L879" href="#L879">879</a>                 
artifactMetadataSource, <strong class="jxr_keyword">null</strong>,
-<a class="jxr_linenumber" name="L880" href="#L880">880</a>                 
artifactCollector);
-<a class="jxr_linenumber" name="L881" href="#L881">881</a>         <strong 
class="jxr_keyword">boolean</strong> modified = false;
-<a class="jxr_linenumber" name="L882" href="#L882">882</a>         <strong 
class="jxr_keyword">for</strong> 
(org.apache.maven.shared.dependency.tree.DependencyNode n2 : node.getChildren())
-<a class="jxr_linenumber" name="L883" href="#L883">883</a>         {
-<a class="jxr_linenumber" name="L884" href="#L884">884</a>             <strong 
class="jxr_keyword">for</strong> 
(org.apache.maven.shared.dependency.tree.DependencyNode n3 : n2.getChildren())
-<a class="jxr_linenumber" name="L885" href="#L885">885</a>             {
-<a class="jxr_linenumber" name="L886" href="#L886">886</a>                 <em 
class="jxr_comment">//anything two levels deep that is marked "included"</em>
-<a class="jxr_linenumber" name="L887" href="#L887">887</a>                 <em 
class="jxr_comment">//is stuff that was excluded by the original poms, make 
sure it</em>
-<a class="jxr_linenumber" name="L888" href="#L888">888</a>                 <em 
class="jxr_comment">//remains excluded IF promoting transitives.</em>
-<a class="jxr_linenumber" name="L889" href="#L889">889</a>                 
<strong class="jxr_keyword">if</strong> (n3.getState() == 
org.apache.maven.shared.dependency.tree.DependencyNode.INCLUDED)
-<a class="jxr_linenumber" name="L890" href="#L890">890</a>                 {
-<a class="jxr_linenumber" name="L891" href="#L891">891</a>                     
<em class="jxr_comment">//check if it really isn't in the list of original 
dependencies.  Maven</em>
-<a class="jxr_linenumber" name="L892" href="#L892">892</a>                     
<em class="jxr_comment">//prior to 2.0.8 may grab versions from transients 
instead of</em>
-<a class="jxr_linenumber" name="L893" href="#L893">893</a>                     
<em class="jxr_comment">//from the direct deps in which case they would be 
marked included</em>
-<a class="jxr_linenumber" name="L894" href="#L894">894</a>                     
<em class="jxr_comment">//instead of OMITTED_FOR_DUPLICATE</em>
-<a class="jxr_linenumber" name="L895" href="#L895">895</a> 
-<a class="jxr_linenumber" name="L896" href="#L896">896</a>                     
<em class="jxr_comment">//also, if not promoting the transitives, level 2's 
would be included</em>
-<a class="jxr_linenumber" name="L897" href="#L897">897</a>                     
<strong class="jxr_keyword">boolean</strong> found = false;
-<a class="jxr_linenumber" name="L898" href="#L898">898</a>                     
<strong class="jxr_keyword">for</strong> (Dependency dep : transitiveDeps)
-<a class="jxr_linenumber" name="L899" href="#L899">899</a>                     
{
-<a class="jxr_linenumber" name="L900" href="#L900">900</a>                     
    <strong class="jxr_keyword">if</strong> 
(dep.getArtifactId().equals(n3.getArtifact().getArtifactId()) &amp;&amp; 
dep.getGroupId().equals(
-<a class="jxr_linenumber" name="L901" href="#L901">901</a>                     
            n3.getArtifact().getGroupId()))
-<a class="jxr_linenumber" name="L902" href="#L902">902</a>                     
    {
-<a class="jxr_linenumber" name="L903" href="#L903">903</a>                     
        found = <strong class="jxr_keyword">true</strong>;
-<a class="jxr_linenumber" name="L904" href="#L904">904</a>                     
    }
-<a class="jxr_linenumber" name="L905" href="#L905">905</a> 
-<a class="jxr_linenumber" name="L906" href="#L906">906</a>                     
}
+<a class="jxr_linenumber" name="L855" href="#L855">855</a>             }
+<a class="jxr_linenumber" name="L856" href="#L856">856</a> 
+<a class="jxr_linenumber" name="L857" href="#L857">857</a>             
project.setFile( dependencyReducedPomLocation );
+<a class="jxr_linenumber" name="L858" href="#L858">858</a>         }
+<a class="jxr_linenumber" name="L859" href="#L859">859</a>     }
+<a class="jxr_linenumber" name="L860" href="#L860">860</a> 
+<a class="jxr_linenumber" name="L861" href="#L861">861</a>     <strong 
class="jxr_keyword">private</strong> String getId( Artifact artifact )
+<a class="jxr_linenumber" name="L862" href="#L862">862</a>     {
+<a class="jxr_linenumber" name="L863" href="#L863">863</a>         <strong 
class="jxr_keyword">return</strong> getId( artifact.getGroupId(), 
artifact.getArtifactId(), artifact.getType(), artifact.getClassifier() );
+<a class="jxr_linenumber" name="L864" href="#L864">864</a>     }
+<a class="jxr_linenumber" name="L865" href="#L865">865</a> 
+<a class="jxr_linenumber" name="L866" href="#L866">866</a>     <strong 
class="jxr_keyword">private</strong> String getId( Dependency dependency )
+<a class="jxr_linenumber" name="L867" href="#L867">867</a>     {
+<a class="jxr_linenumber" name="L868" href="#L868">868</a>         <strong 
class="jxr_keyword">return</strong> getId( dependency.getGroupId(), 
dependency.getArtifactId(), dependency.getType(),
+<a class="jxr_linenumber" name="L869" href="#L869">869</a>                 
dependency.getClassifier() );
+<a class="jxr_linenumber" name="L870" href="#L870">870</a>     }
+<a class="jxr_linenumber" name="L871" href="#L871">871</a> 
+<a class="jxr_linenumber" name="L872" href="#L872">872</a>     <strong 
class="jxr_keyword">private</strong> String getId( String groupId, String 
artifactId, String type, String classifier )
+<a class="jxr_linenumber" name="L873" href="#L873">873</a>     {
+<a class="jxr_linenumber" name="L874" href="#L874">874</a>         <strong 
class="jxr_keyword">return</strong> groupId + <span 
class="jxr_string">":"</span> + artifactId + <span 
class="jxr_string">":"</span> + type + <span class="jxr_string">":"</span> + ( 
( classifier != <strong class="jxr_keyword">null</strong> ) ? classifier : 
<span class="jxr_string">""</span> );
+<a class="jxr_linenumber" name="L875" href="#L875">875</a>     }
+<a class="jxr_linenumber" name="L876" href="#L876">876</a> 
+<a class="jxr_linenumber" name="L877" href="#L877">877</a>     <strong 
class="jxr_keyword">public</strong> <strong 
class="jxr_keyword">boolean</strong> updateExcludesInDeps( MavenProject 
project, List&lt;Dependency&gt; dependencies, List&lt;Dependency&gt; 
transitiveDeps )
+<a class="jxr_linenumber" name="L878" href="#L878">878</a>             <strong 
class="jxr_keyword">throws</strong> DependencyTreeBuilderException
+<a class="jxr_linenumber" name="L879" href="#L879">879</a>     {
+<a class="jxr_linenumber" name="L880" href="#L880">880</a>         
org.apache.maven.shared.dependency.tree.DependencyNode node = 
dependencyTreeBuilder.buildDependencyTree(project, localRepository, 
artifactFactory,
+<a class="jxr_linenumber" name="L881" href="#L881">881</a>                 
artifactMetadataSource, <strong class="jxr_keyword">null</strong>,
+<a class="jxr_linenumber" name="L882" href="#L882">882</a>                 
artifactCollector);
+<a class="jxr_linenumber" name="L883" href="#L883">883</a>         <strong 
class="jxr_keyword">boolean</strong> modified = false;
+<a class="jxr_linenumber" name="L884" href="#L884">884</a>         <strong 
class="jxr_keyword">for</strong> 
(org.apache.maven.shared.dependency.tree.DependencyNode n2 : node.getChildren())
+<a class="jxr_linenumber" name="L885" href="#L885">885</a>         {
+<a class="jxr_linenumber" name="L886" href="#L886">886</a>             <strong 
class="jxr_keyword">for</strong> 
(org.apache.maven.shared.dependency.tree.DependencyNode n3 : n2.getChildren())
+<a class="jxr_linenumber" name="L887" href="#L887">887</a>             {
+<a class="jxr_linenumber" name="L888" href="#L888">888</a>                 <em 
class="jxr_comment">//anything two levels deep that is marked "included"</em>
+<a class="jxr_linenumber" name="L889" href="#L889">889</a>                 <em 
class="jxr_comment">//is stuff that was excluded by the original poms, make 
sure it</em>
+<a class="jxr_linenumber" name="L890" href="#L890">890</a>                 <em 
class="jxr_comment">//remains excluded IF promoting transitives.</em>
+<a class="jxr_linenumber" name="L891" href="#L891">891</a>                 
<strong class="jxr_keyword">if</strong> (n3.getState() == 
org.apache.maven.shared.dependency.tree.DependencyNode.INCLUDED)
+<a class="jxr_linenumber" name="L892" href="#L892">892</a>                 {
+<a class="jxr_linenumber" name="L893" href="#L893">893</a>                     
<em class="jxr_comment">//check if it really isn't in the list of original 
dependencies.  Maven</em>
+<a class="jxr_linenumber" name="L894" href="#L894">894</a>                     
<em class="jxr_comment">//prior to 2.0.8 may grab versions from transients 
instead of</em>
+<a class="jxr_linenumber" name="L895" href="#L895">895</a>                     
<em class="jxr_comment">//from the direct deps in which case they would be 
marked included</em>
+<a class="jxr_linenumber" name="L896" href="#L896">896</a>                     
<em class="jxr_comment">//instead of OMITTED_FOR_DUPLICATE</em>
+<a class="jxr_linenumber" name="L897" href="#L897">897</a> 
+<a class="jxr_linenumber" name="L898" href="#L898">898</a>                     
<em class="jxr_comment">//also, if not promoting the transitives, level 2's 
would be included</em>
+<a class="jxr_linenumber" name="L899" href="#L899">899</a>                     
<strong class="jxr_keyword">boolean</strong> found = false;
+<a class="jxr_linenumber" name="L900" href="#L900">900</a>                     
<strong class="jxr_keyword">for</strong> (Dependency dep : transitiveDeps)
+<a class="jxr_linenumber" name="L901" href="#L901">901</a>                     
{
+<a class="jxr_linenumber" name="L902" href="#L902">902</a>                     
    <strong class="jxr_keyword">if</strong> 
(dep.getArtifactId().equals(n3.getArtifact().getArtifactId()) &amp;&amp; 
dep.getGroupId().equals(
+<a class="jxr_linenumber" name="L903" href="#L903">903</a>                     
            n3.getArtifact().getGroupId()))
+<a class="jxr_linenumber" name="L904" href="#L904">904</a>                     
    {
+<a class="jxr_linenumber" name="L905" href="#L905">905</a>                     
        found = <strong class="jxr_keyword">true</strong>;
+<a class="jxr_linenumber" name="L906" href="#L906">906</a>                     
    }
 <a class="jxr_linenumber" name="L907" href="#L907">907</a> 
-<a class="jxr_linenumber" name="L908" href="#L908">908</a>                     
<strong class="jxr_keyword">if</strong> (!found)
-<a class="jxr_linenumber" name="L909" href="#L909">909</a>                     
{
-<a class="jxr_linenumber" name="L910" href="#L910">910</a>                     
    <strong class="jxr_keyword">for</strong> (Dependency dep : dependencies)
-<a class="jxr_linenumber" name="L911" href="#L911">911</a>                     
    {
-<a class="jxr_linenumber" name="L912" href="#L912">912</a>                     
        <strong class="jxr_keyword">if</strong> 
(dep.getArtifactId().equals(n2.getArtifact().getArtifactId())
-<a class="jxr_linenumber" name="L913" href="#L913">913</a>                     
                &amp;&amp; 
dep.getGroupId().equals(n2.getArtifact().getGroupId()))
-<a class="jxr_linenumber" name="L914" href="#L914">914</a>                     
        {
-<a class="jxr_linenumber" name="L915" href="#L915">915</a>                     
            Exclusion exclusion = <strong class="jxr_keyword">new</strong> 
Exclusion();
-<a class="jxr_linenumber" name="L916" href="#L916">916</a>                     
            exclusion.setArtifactId(n3.getArtifact().getArtifactId());
-<a class="jxr_linenumber" name="L917" href="#L917">917</a>                     
            exclusion.setGroupId(n3.getArtifact().getGroupId());
-<a class="jxr_linenumber" name="L918" href="#L918">918</a>                     
            dep.addExclusion(exclusion);
-<a class="jxr_linenumber" name="L919" href="#L919">919</a>                     
            modified = <strong class="jxr_keyword">true</strong>;
-<a class="jxr_linenumber" name="L920" href="#L920">920</a>                     
            <strong class="jxr_keyword">break</strong>;
-<a class="jxr_linenumber" name="L921" href="#L921">921</a>                     
        }
-<a class="jxr_linenumber" name="L922" href="#L922">922</a>                     
    }
-<a class="jxr_linenumber" name="L923" href="#L923">923</a>                     
}
-<a class="jxr_linenumber" name="L924" href="#L924">924</a>                 }
-<a class="jxr_linenumber" name="L925" href="#L925">925</a>             }
-<a class="jxr_linenumber" name="L926" href="#L926">926</a>         }
-<a class="jxr_linenumber" name="L927" href="#L927">927</a>         <strong 
class="jxr_keyword">return</strong> modified;
-<a class="jxr_linenumber" name="L928" href="#L928">928</a>     }
-<a class="jxr_linenumber" name="L929" href="#L929">929</a> 
-<a class="jxr_linenumber" name="L930" href="#L930">930</a> 
-<a class="jxr_linenumber" name="L931" href="#L931">931</a>     <strong 
class="jxr_keyword">protected</strong> Builder buildOSGiBundle(MavenProject 
currentProject, Map&lt;String, String&gt; originalInstructions,
-<a class="jxr_linenumber" name="L932" href="#L932">932</a>                     
                  <a 
href="../../../../org/apache/felix/bundleplugin/BundlePlugin.html">ClassPathItem</a>[]
 classpath) <strong class="jxr_keyword">throws</strong> Exception
-<a class="jxr_linenumber" name="L933" href="#L933">933</a>     {
-<a class="jxr_linenumber" name="L934" href="#L934">934</a>         Builder 
builder = getOSGiBuilder( currentProject, originalInstructions, classpath );
-<a class="jxr_linenumber" name="L935" href="#L935">935</a> 
-<a class="jxr_linenumber" name="L936" href="#L936">936</a>         
addMavenInstructions( currentProject, builder );
+<a class="jxr_linenumber" name="L908" href="#L908">908</a>                     
}
+<a class="jxr_linenumber" name="L909" href="#L909">909</a> 
+<a class="jxr_linenumber" name="L910" href="#L910">910</a>                     
<strong class="jxr_keyword">if</strong> (!found)
+<a class="jxr_linenumber" name="L911" href="#L911">911</a>                     
{
+<a class="jxr_linenumber" name="L912" href="#L912">912</a>                     
    <strong class="jxr_keyword">for</strong> (Dependency dep : dependencies)
+<a class="jxr_linenumber" name="L913" href="#L913">913</a>                     
    {
+<a class="jxr_linenumber" name="L914" href="#L914">914</a>                     
        <strong class="jxr_keyword">if</strong> 
(dep.getArtifactId().equals(n2.getArtifact().getArtifactId())
+<a class="jxr_linenumber" name="L915" href="#L915">915</a>                     
                &amp;&amp; 
dep.getGroupId().equals(n2.getArtifact().getGroupId()))
+<a class="jxr_linenumber" name="L916" href="#L916">916</a>                     
        {
+<a class="jxr_linenumber" name="L917" href="#L917">917</a>                     
            Exclusion exclusion = <strong class="jxr_keyword">new</strong> 
Exclusion();
+<a class="jxr_linenumber" name="L918" href="#L918">918</a>                     
            exclusion.setArtifactId(n3.getArtifact().getArtifactId());
+<a class="jxr_linenumber" name="L919" href="#L919">919</a>                     
            exclusion.setGroupId(n3.getArtifact().getGroupId());
+<a class="jxr_linenumber" name="L920" href="#L920">920</a>                     
            dep.addExclusion(exclusion);
+<a class="jxr_linenumber" name="L921" href="#L921">921</a>                     
            modified = <strong class="jxr_keyword">true</strong>;
+<a class="jxr_linenumber" name="L922" href="#L922">922</a>                     
            <strong class="jxr_keyword">break</strong>;
+<a class="jxr_linenumber" name="L923" href="#L923">923</a>                     
        }
+<a class="jxr_linenumber" name="L924" href="#L924">924</a>                     
    }
+<a class="jxr_linenumber" name="L925" href="#L925">925</a>                     
}
+<a class="jxr_linenumber" name="L926" href="#L926">926</a>                 }
+<a class="jxr_linenumber" name="L927" href="#L927">927</a>             }
+<a class="jxr_linenumber" name="L928" href="#L928">928</a>         }
+<a class="jxr_linenumber" name="L929" href="#L929">929</a>         <strong 
class="jxr_keyword">return</strong> modified;
+<a class="jxr_linenumber" name="L930" href="#L930">930</a>     }
+<a class="jxr_linenumber" name="L931" href="#L931">931</a> 
+<a class="jxr_linenumber" name="L932" href="#L932">932</a> 
+<a class="jxr_linenumber" name="L933" href="#L933">933</a>     <strong 
class="jxr_keyword">protected</strong> Builder buildOSGiBundle(MavenProject 
currentProject, Map&lt;String, String&gt; originalInstructions,
+<a class="jxr_linenumber" name="L934" href="#L934">934</a>                     
                  <a 
href="../../../../org/apache/felix/bundleplugin/BundlePlugin.html">ClassPathItem</a>[]
 classpath) <strong class="jxr_keyword">throws</strong> Exception
+<a class="jxr_linenumber" name="L935" href="#L935">935</a>     {
+<a class="jxr_linenumber" name="L936" href="#L936">936</a>         Builder 
builder = getOSGiBuilder( currentProject, originalInstructions, classpath );
 <a class="jxr_linenumber" name="L937" href="#L937">937</a> 
-<a class="jxr_linenumber" name="L938" href="#L938">938</a>         
builder.build();
+<a class="jxr_linenumber" name="L938" href="#L938">938</a>         
addMavenInstructions( currentProject, builder );
 <a class="jxr_linenumber" name="L939" href="#L939">939</a> 
-<a class="jxr_linenumber" name="L940" href="#L940">940</a>         
mergeMavenManifest(currentProject, builder);
+<a class="jxr_linenumber" name="L940" href="#L940">940</a>         
builder.build();
 <a class="jxr_linenumber" name="L941" href="#L941">941</a> 
-<a class="jxr_linenumber" name="L942" href="#L942">942</a>         <strong 
class="jxr_keyword">return</strong> builder;
-<a class="jxr_linenumber" name="L943" href="#L943">943</a>     }
-<a class="jxr_linenumber" name="L944" href="#L944">944</a> 
-<a class="jxr_linenumber" name="L945" href="#L945">945</a> 
-<a class="jxr_linenumber" name="L946" href="#L946">946</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> StringBuilder dumpInstructions( Properties 
properties, StringBuilder buf )
-<a class="jxr_linenumber" name="L947" href="#L947">947</a>     {
-<a class="jxr_linenumber" name="L948" href="#L948">948</a>         <strong 
class="jxr_keyword">try</strong>
-<a class="jxr_linenumber" name="L949" href="#L949">949</a>         {
-<a class="jxr_linenumber" name="L950" href="#L950">950</a>             
buf.append( <span 
class="jxr_string">"#-----------------------------------------------------------------------"</span>
 + NL );
-<a class="jxr_linenumber" name="L951" href="#L951">951</a>             
Properties stringProperties = <strong class="jxr_keyword">new</strong> 
Properties();
-<a class="jxr_linenumber" name="L952" href="#L952">952</a>             <strong 
class="jxr_keyword">for</strong> ( Enumeration&lt;String&gt; e = 
(Enumeration&lt;String&gt;) properties.propertyNames(); e.hasMoreElements(); )
-<a class="jxr_linenumber" name="L953" href="#L953">953</a>             {
-<a class="jxr_linenumber" name="L954" href="#L954">954</a>                 <em 
class="jxr_comment">// we can only store String properties</em>
-<a class="jxr_linenumber" name="L955" href="#L955">955</a>                 
String key = e.nextElement();
-<a class="jxr_linenumber" name="L956" href="#L956">956</a>                 
String value = properties.getProperty( key );
-<a class="jxr_linenumber" name="L957" href="#L957">957</a>                 
<strong class="jxr_keyword">if</strong> ( value != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L958" href="#L958">958</a>                 {
-<a class="jxr_linenumber" name="L959" href="#L959">959</a>                     
stringProperties.setProperty( key, value );
-<a class="jxr_linenumber" name="L960" href="#L960">960</a>                 }
-<a class="jxr_linenumber" name="L961" href="#L961">961</a>             }
-<a class="jxr_linenumber" name="L962" href="#L962">962</a>             
ByteArrayOutputStream out = <strong class="jxr_keyword">new</strong> 
ByteArrayOutputStream();
-<a class="jxr_linenumber" name="L963" href="#L963">963</a>             
stringProperties.store( out, <strong class="jxr_keyword">null</strong> ); <em 
class="jxr_comment">// properties encoding is 8859_1</em>
-<a class="jxr_linenumber" name="L964" href="#L964">964</a>             
buf.append( out.toString( <span class="jxr_string">"8859_1"</span> ) );
-<a class="jxr_linenumber" name="L965" href="#L965">965</a>             
buf.append(<span 
class="jxr_string">"#-----------------------------------------------------------------------"</span>).append(NL);
-<a class="jxr_linenumber" name="L966" href="#L966">966</a>         }
-<a class="jxr_linenumber" name="L967" href="#L967">967</a>         <strong 
class="jxr_keyword">catch</strong> ( Throwable e )
-<a class="jxr_linenumber" name="L968" href="#L968">968</a>         {
-<a class="jxr_linenumber" name="L969" href="#L969">969</a>             <em 
class="jxr_comment">// ignore...</em>
-<a class="jxr_linenumber" name="L970" href="#L970">970</a>         }
-<a class="jxr_linenumber" name="L971" href="#L971">971</a>         <strong 
class="jxr_keyword">return</strong> buf;
-<a class="jxr_linenumber" name="L972" href="#L972">972</a>     }
-<a class="jxr_linenumber" name="L973" href="#L973">973</a> 
-<a class="jxr_linenumber" name="L974" href="#L974">974</a> 
-<a class="jxr_linenumber" name="L975" href="#L975">975</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> StringBuilder dumpClasspath( 
List&lt;Jar&gt; classpath, StringBuilder buf )
-<a class="jxr_linenumber" name="L976" href="#L976">976</a>     {
-<a class="jxr_linenumber" name="L977" href="#L977">977</a>         <strong 
class="jxr_keyword">try</strong>
-<a class="jxr_linenumber" name="L978" href="#L978">978</a>         {
-<a class="jxr_linenumber" name="L979" href="#L979">979</a>             
buf.append(<span 
class="jxr_string">"#-----------------------------------------------------------------------"</span>).append(NL);
-<a class="jxr_linenumber" name="L980" href="#L980">980</a>             
buf.append(<span class="jxr_string">"-classpath:&#92;&#92;"</span>).append(NL);
-<a class="jxr_linenumber" name="L981" href="#L981">981</a>             <strong 
class="jxr_keyword">for</strong> ( Iterator&lt;Jar&gt; i = 
classpath.iterator(); i.hasNext(); )
-<a class="jxr_linenumber" name="L982" href="#L982">982</a>             {
-<a class="jxr_linenumber" name="L983" href="#L983">983</a>                 
File path = i.next().getSource();
-<a class="jxr_linenumber" name="L984" href="#L984">984</a>                 
<strong class="jxr_keyword">if</strong> ( path != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L985" href="#L985">985</a>                 {
-<a class="jxr_linenumber" name="L986" href="#L986">986</a>                     
buf.append(' ').append(path.toString()).append(i.hasNext() ? <span 
class="jxr_string">",&#92;&#92;"</span> : <span 
class="jxr_string">""</span>).append(NL);
-<a class="jxr_linenumber" name="L987" href="#L987">987</a>                 }
-<a class="jxr_linenumber" name="L988" href="#L988">988</a>             }
-<a class="jxr_linenumber" name="L989" href="#L989">989</a>             
buf.append(<span 
class="jxr_string">"#-----------------------------------------------------------------------"</span>).append(NL);
-<a class="jxr_linenumber" name="L990" href="#L990">990</a>         }
-<a class="jxr_linenumber" name="L991" href="#L991">991</a>         <strong 
class="jxr_keyword">catch</strong> ( Throwable e )
-<a class="jxr_linenumber" name="L992" href="#L992">992</a>         {
-<a class="jxr_linenumber" name="L993" href="#L993">993</a>             <em 
class="jxr_comment">// ignore...</em>
-<a class="jxr_linenumber" name="L994" href="#L994">994</a>         }
-<a class="jxr_linenumber" name="L995" href="#L995">995</a>         <strong 
class="jxr_keyword">return</strong> buf;
-<a class="jxr_linenumber" name="L996" href="#L996">996</a>     }
-<a class="jxr_linenumber" name="L997" href="#L997">997</a> 
-<a class="jxr_linenumber" name="L998" href="#L998">998</a> 
-<a class="jxr_linenumber" name="L999" href="#L999">999</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> StringBuilder dumpManifest( Manifest 
manifest, StringBuilder buf )
-<a class="jxr_linenumber" name="L1000" href="#L1000">1000</a>     {
-<a class="jxr_linenumber" name="L1001" href="#L1001">1001</a>         <strong 
class="jxr_keyword">try</strong>
-<a class="jxr_linenumber" name="L1002" href="#L1002">1002</a>         {
-<a class="jxr_linenumber" name="L1003" href="#L1003">1003</a>             
buf.append(<span 
class="jxr_string">"#-----------------------------------------------------------------------"</span>).append(NL);
-<a class="jxr_linenumber" name="L1004" href="#L1004">1004</a>             
ByteArrayOutputStream out = <strong class="jxr_keyword">new</strong> 
ByteArrayOutputStream();
-<a class="jxr_linenumber" name="L1005" href="#L1005">1005</a>             
ManifestWriter.outputManifest(manifest, out, <strong 
class="jxr_keyword">true</strong>); <em class="jxr_comment">// manifest 
encoding is UTF8</em>
-<a class="jxr_linenumber" name="L1006" href="#L1006">1006</a>             
buf.append( out.toString( <span class="jxr_string">"UTF8"</span> ) );
-<a class="jxr_linenumber" name="L1007" href="#L1007">1007</a>             
buf.append(<span 
class="jxr_string">"#-----------------------------------------------------------------------"</span>).append(NL);
-<a class="jxr_linenumber" name="L1008" href="#L1008">1008</a>         }
-<a class="jxr_linenumber" name="L1009" href="#L1009">1009</a>         <strong 
class="jxr_keyword">catch</strong> ( Throwable e )
-<a class="jxr_linenumber" name="L1010" href="#L1010">1010</a>         {
-<a class="jxr_linenumber" name="L1011" href="#L1011">1011</a>             <em 
class="jxr_comment">// ignore...</em>
-<a class="jxr_linenumber" name="L1012" href="#L1012">1012</a>         }
-<a class="jxr_linenumber" name="L1013" href="#L1013">1013</a>         <strong 
class="jxr_keyword">return</strong> buf;
-<a class="jxr_linenumber" name="L1014" href="#L1014">1014</a>     }
-<a class="jxr_linenumber" name="L1015" href="#L1015">1015</a> 
-<a class="jxr_linenumber" name="L1016" href="#L1016">1016</a> 
-<a class="jxr_linenumber" name="L1017" href="#L1017">1017</a>     <strong 
class="jxr_keyword">protected</strong> <strong 
class="jxr_keyword">static</strong> <strong class="jxr_keyword">void</strong> 
includeMavenResources( MavenProject currentProject, Analyzer analyzer, Log log )
-<a class="jxr_linenumber" name="L1018" href="#L1018">1018</a>     {
-<a class="jxr_linenumber" name="L1019" href="#L1019">1019</a>         <em 
class="jxr_comment">// pass maven resource paths onto BND analyzer</em>
-<a class="jxr_linenumber" name="L1020" href="#L1020">1020</a>         <strong 
class="jxr_keyword">final</strong> String mavenResourcePaths = 
getMavenResourcePaths( currentProject, false );
-<a class="jxr_linenumber" name="L1021" href="#L1021">1021</a>         <strong 
class="jxr_keyword">final</strong> String mavenTestResourcePaths = 
getMavenResourcePaths( currentProject, <strong 
class="jxr_keyword">true</strong> );
-<a class="jxr_linenumber" name="L1022" href="#L1022">1022</a>         <strong 
class="jxr_keyword">final</strong> String includeResource = 
analyzer.getProperty( Analyzer.INCLUDE_RESOURCE );
-<a class="jxr_linenumber" name="L1023" href="#L1023">1023</a>         <strong 
class="jxr_keyword">if</strong> ( includeResource != <strong 
class="jxr_keyword">null</strong> )
-<a class="jxr_linenumber" name="L1024" href="#L1024">1024</a>         {
-<a class="jxr_linenumber" name="L1025" href="#L1025">1025</a>             
<strong class="jxr_keyword">if</strong> ( includeResource.contains( 
MAVEN_RESOURCES ) || includeResource.contains( MAVEN_TEST_RESOURCES ) )
-<a class="jxr_linenumber" name="L1026" href="#L1026">1026</a>             {
-<a class="jxr_linenumber" name="L1027" href="#L1027">1027</a>                 
String combinedResource = StringUtils.replace( includeResource, 
MAVEN_RESOURCES, mavenResourcePaths );
-<a class="jxr_linenumber" name="L1028" href="#L1028">1028</a>                 
combinedResource = StringUtils.replace( combinedResource, MAVEN_TEST_RESOURCES, 
mavenTestResourcePaths );
-<a class="jxr_linenumber" name="L1029" href="#L1029">1029</a>                 
<strong class="jxr_keyword">if</strong> ( combinedResource.length() &gt; 0 )
-<a class="jxr_linenumber" name="L1030" href="#L1030">1030</a>                 {
-<a class="jxr_linenumber" name="L1031" href="#L1031">1031</a>                  
   analyzer.setProperty( Analyzer.INCLUDE_RESOURCE, combinedResource );
-<a class="jxr_linenumber" name="L1032" href="#L1032">1032</a>                 }
-<a class="jxr_linenumber" name="L1033" href="#L1033">1033</a>                 
<strong class="jxr_keyword">else</strong>
-<a class="jxr_linenumber" name="L1034" href="#L1034">1034</a>                 {
-<a class="jxr_linenumber" name="L1035" href="#L1035">1035</a>                  
   analyzer.unsetProperty( Analyzer.INCLUDE_RESOURCE );
-<a class="jxr_linenumber" name="L1036" href="#L1036">1036</a>                 }
-<a class="jxr_linenumber" name="L1037" href="#L1037">1037</a>             }
-<a class="jxr_linenumber" name="L1038" href="#L1038">1038</a>             
<strong class="jxr_keyword">else</strong> <strong 
class="jxr_keyword">if</strong> ( mavenResourcePaths.length() &gt; 0 )
-<a class="jxr_linenumber" name="L1039" href="#L1039">1039</a>             {

[... 2347 lines stripped ...]

Reply via email to