From 27b5c1a52b04a14aa6433c7964a2146538fe060f Mon Sep 17 00:00:00 2001 From: Olivier Lamy Date: Sat, 11 Jun 2011 21:31:07 +0000 Subject: fix cli module git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1134775 13f79535-47bb-0310-9956-ffa450edef68 --- .../org/apache/maven/archiva/cli/ArchivaCli.java | 17 +++++++++-- .../maven/archiva/cli/ArtifactCountConsumer.java | 25 ++++++++-------- .../src/main/resources/META-INF/spring-context.xml | 33 ++++++++++++++++++++++ 3 files changed, 62 insertions(+), 13 deletions(-) create mode 100644 archiva-cli/src/main/resources/META-INF/spring-context.xml diff --git a/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArchivaCli.java b/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArchivaCli.java index 52ed03113..a5e5adc06 100644 --- a/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArchivaCli.java +++ b/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArchivaCli.java @@ -47,6 +47,7 @@ import java.net.MalformedURLException; import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; +import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Properties; @@ -242,8 +243,20 @@ public class ArchivaCli private Map getConsumers() throws PlexusSisuBridgeException { - PlexusSisuBridge plexusSisuBridge = applicationContext.getBean( PlexusSisuBridge.class ); - return plexusSisuBridge.lookupMap( KnownRepositoryContentConsumer.class ); + Map beans = + applicationContext.getBeansOfType( KnownRepositoryContentConsumer.class ); + // we use a naming conventions knownRepositoryContentConsumer#hint + // with plexus we used only hint so remove before# + + Map smallNames = + new HashMap( beans.size() ); + + for ( Map.Entry entry : beans.entrySet() ) + { + smallNames.put( StringUtils.substringAfterLast( entry.getKey(), "#" ), entry.getValue() ); + } + + return smallNames; } private void doConversion( String properties ) diff --git a/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArtifactCountConsumer.java b/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArtifactCountConsumer.java index bfc5f6ebc..dc4ef7814 100644 --- a/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArtifactCountConsumer.java +++ b/archiva-cli/src/main/java/org/apache/maven/archiva/cli/ArtifactCountConsumer.java @@ -19,33 +19,36 @@ package org.apache.maven.archiva.cli; * under the License. */ +import org.apache.maven.archiva.consumers.KnownRepositoryContentConsumer; +import org.springframework.context.annotation.Scope; +import org.springframework.stereotype.Service; + import java.util.ArrayList; import java.util.List; -import org.apache.maven.archiva.consumers.KnownRepositoryContentConsumer; - /** - * ArtifactCountConsumer + * ArtifactCountConsumer * * @version $Id$ - * - * @plexus.component role="org.apache.maven.archiva.consumers.KnownRepositoryContentConsumer" - * role-hint="count-artifacts" - * instantiation-strategy="per-lookup" + * plexus.component role="org.apache.maven.archiva.consumers.KnownRepositoryContentConsumer" + * role-hint="count-artifacts" + * instantiation-strategy="per-lookup" */ +@Service("knownRepositoryContentConsumer#count-artifacts") +@Scope("prototype") public class ArtifactCountConsumer extends AbstractProgressConsumer implements KnownRepositoryContentConsumer { /** - * @plexus.configuration default-value="count-artifacts" + * plexus.configuration default-value="count-artifacts" */ - private String id; + private String id = "count-artifacts"; /** - * @plexus.configuration default-value="Count Artifacts" + * plexus.configuration default-value="Count Artifacts" */ - private String description; + private String description = "Count Artifacts"; private List includes; diff --git a/archiva-cli/src/main/resources/META-INF/spring-context.xml b/archiva-cli/src/main/resources/META-INF/spring-context.xml new file mode 100644 index 000000000..11fa0dda2 --- /dev/null +++ b/archiva-cli/src/main/resources/META-INF/spring-context.xml @@ -0,0 +1,33 @@ + + + + + + + + + \ No newline at end of file -- cgit v1.2.3