You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@ant.apache.org by hi...@apache.org on 2010/12/20 11:52:08 UTC

svn commit: r1051053 - in /ant/ivy/core/trunk/src/java/org/apache/ivy: osgi/core/OSGiManifestParser.java plugins/parser/ModuleDescriptorParserRegistry.java

Author: hibou
Date: Mon Dec 20 10:52:08 2010
New Revision: 1051053

URL: http://svn.apache.org/viewvc?rev=1051053&view=rev
Log:
Add the OSGi manifest parser part of the default parsers

Modified:
    ant/ivy/core/trunk/src/java/org/apache/ivy/osgi/core/OSGiManifestParser.java
    ant/ivy/core/trunk/src/java/org/apache/ivy/plugins/parser/ModuleDescriptorParserRegistry.java

Modified: ant/ivy/core/trunk/src/java/org/apache/ivy/osgi/core/OSGiManifestParser.java
URL: http://svn.apache.org/viewvc/ant/ivy/core/trunk/src/java/org/apache/ivy/osgi/core/OSGiManifestParser.java?rev=1051053&r1=1051052&r2=1051053&view=diff
==============================================================================
--- ant/ivy/core/trunk/src/java/org/apache/ivy/osgi/core/OSGiManifestParser.java (original)
+++ ant/ivy/core/trunk/src/java/org/apache/ivy/osgi/core/OSGiManifestParser.java Mon Dec 20 10:52:08 2010
@@ -22,16 +22,27 @@ import java.io.IOException;
 import java.io.InputStream;
 import java.net.URL;
 import java.text.ParseException;
+import java.util.Date;
 import java.util.Locale;
 import java.util.jar.Manifest;
 
+import org.apache.ivy.core.module.descriptor.Artifact;
+import org.apache.ivy.core.module.descriptor.DefaultArtifact;
 import org.apache.ivy.core.module.descriptor.ModuleDescriptor;
-import org.apache.ivy.plugins.parser.AbstractModuleDescriptorParser;
+import org.apache.ivy.core.module.id.ModuleRevisionId;
+import org.apache.ivy.plugins.parser.ModuleDescriptorParser;
 import org.apache.ivy.plugins.parser.ParserSettings;
 import org.apache.ivy.plugins.parser.xml.XmlModuleDescriptorWriter;
 import org.apache.ivy.plugins.repository.Resource;
+import org.apache.ivy.plugins.repository.url.URLResource;
 
-public class OSGiManifestParser extends AbstractModuleDescriptorParser {
+public class OSGiManifestParser implements ModuleDescriptorParser {
+
+    private static final OSGiManifestParser INSTANCE = new OSGiManifestParser();
+
+    public static OSGiManifestParser getInstance() {
+        return INSTANCE;
+    }
 
     private ExecutionEnvironmentProfileProvider profileProvider;
 
@@ -64,4 +75,21 @@ public class OSGiManifestParser extends 
         }
     }
 
+    public ModuleDescriptor parseDescriptor(ParserSettings ivySettings, URL descriptorURL,
+            boolean validate) throws ParseException, IOException {
+        URLResource resource = new URLResource(descriptorURL);
+        return parseDescriptor(ivySettings, descriptorURL, resource, validate);
+    }
+
+    public String getType() {
+        return "manifest";
+    }
+
+    public Artifact getMetadataArtifact(ModuleRevisionId mrid, Resource res) {
+        return DefaultArtifact.newIvyArtifact(mrid, new Date(res.getLastModified()));
+    }
+
+    public String toString() {
+        return "manifest parser";
+    }
 }

Modified: ant/ivy/core/trunk/src/java/org/apache/ivy/plugins/parser/ModuleDescriptorParserRegistry.java
URL: http://svn.apache.org/viewvc/ant/ivy/core/trunk/src/java/org/apache/ivy/plugins/parser/ModuleDescriptorParserRegistry.java?rev=1051053&r1=1051052&r2=1051053&view=diff
==============================================================================
--- ant/ivy/core/trunk/src/java/org/apache/ivy/plugins/parser/ModuleDescriptorParserRegistry.java (original)
+++ ant/ivy/core/trunk/src/java/org/apache/ivy/plugins/parser/ModuleDescriptorParserRegistry.java Mon Dec 20 10:52:08 2010
@@ -27,6 +27,7 @@ import java.util.LinkedList;
 import java.util.List;
 
 import org.apache.ivy.core.module.descriptor.ModuleDescriptor;
+import org.apache.ivy.osgi.core.OSGiManifestParser;
 import org.apache.ivy.plugins.parser.m2.PomModuleDescriptorParser;
 import org.apache.ivy.plugins.parser.xml.XmlModuleDescriptorParser;
 import org.apache.ivy.plugins.repository.Resource;
@@ -44,6 +45,7 @@ public final class ModuleDescriptorParse
 
     private ModuleDescriptorParserRegistry() {
         parsers.add(PomModuleDescriptorParser.getInstance());
+        parsers.add(OSGiManifestParser.getInstance());
         parsers.add(XmlModuleDescriptorParser.getInstance());
     }