Author: brett
Date: Mon Jun 20 08:21:50 2005
New Revision: 191492

URL: http://svn.apache.org/viewcvs?rev=191492&view=rev
Log:
PR: MNG-418

use a silent transfer monitor in batch mode

Added:
    
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/BatchModeDownloadMonitor.java
Modified:
    
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/ConsoleDownloadMonitor.java
    
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/MavenCli.java

Added: 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/BatchModeDownloadMonitor.java
URL: 
http://svn.apache.org/viewcvs/maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/BatchModeDownloadMonitor.java?rev=191492&view=auto
==============================================================================
--- 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/BatchModeDownloadMonitor.java
 (added)
+++ 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/BatchModeDownloadMonitor.java
 Mon Jun 20 08:21:50 2005
@@ -0,0 +1,79 @@
+package org.apache.maven.cli;
+
+/*
+ * Copyright 2001-2005 The Apache Software Foundation.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import org.apache.maven.wagon.WagonConstants;
+import org.apache.maven.wagon.events.TransferEvent;
+import org.apache.maven.wagon.events.TransferListener;
+import org.codehaus.plexus.logging.AbstractLogEnabled;
+
+/**
+ * Console download progress meter.
+ *
+ * @author <a href="mailto:[EMAIL PROTECTED]">Brett Porter</a>
+ * @version $Id: ConsoleDownloadMonitor.java 169548 2005-05-11 01:04:50Z brett 
$
+ */
+public class BatchModeDownloadMonitor
+    extends AbstractLogEnabled
+    implements TransferListener
+{
+    public void transferInitiated( TransferEvent transferEvent )
+    {
+        String message = transferEvent.getRequestType() == 
TransferEvent.REQUEST_PUT ? "Uploading" : "Downloading";
+
+        String url = transferEvent.getWagon().getRepository().getUrl();
+
+        // TODO: can't use getLogger() because this isn't currently 
instantiated as a component
+        System.out.println( message + ": " + url + "/" + 
transferEvent.getResource().getName() );
+    }
+
+    public void transferStarted( TransferEvent transferEvent )
+    {
+        // This space left intentionally blank
+    }
+
+    public void transferProgress( TransferEvent transferEvent, byte[] buffer, 
int length )
+    {
+        // This space left intentionally blank
+    }
+
+    public void transferCompleted( TransferEvent transferEvent )
+    {
+        long contentLength = transferEvent.getResource().getContentLength();
+        if ( contentLength != WagonConstants.UNKNOWN_LENGTH )
+        {
+            String type = ( transferEvent.getRequestType() == 
TransferEvent.REQUEST_PUT ? "uploaded" : "downloaded" );
+            String l = contentLength >= 1024 ? ( contentLength / 1024 ) + "K" 
: contentLength + "b";
+            System.out.println( l + " " + type );
+        }
+    }
+
+    public void transferError( TransferEvent transferEvent )
+    {
+        // TODO: can't use getLogger() because this isn't currently 
instantiated as a component
+        transferEvent.getException().printStackTrace();
+    }
+
+    public void debug( String message )
+    {
+        // TODO: can't use getLogger() because this isn't currently 
instantiated as a component
+//        getLogger().debug( message );
+    }
+}
+
+
+

Modified: 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/ConsoleDownloadMonitor.java
URL: 
http://svn.apache.org/viewcvs/maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/ConsoleDownloadMonitor.java?rev=191492&r1=191491&r2=191492&view=diff
==============================================================================
--- 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/ConsoleDownloadMonitor.java
 (original)
+++ 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/ConsoleDownloadMonitor.java
 Mon Jun 20 08:21:50 2005
@@ -55,15 +55,27 @@
         long total = transferEvent.getResource().getContentLength();
         complete += length;
         // TODO [BP]: Sys.out may no longer be appropriate, but will \r work 
with getLogger()?
-        System.out.print( ( complete / 1024 ) + "/" +
-                          ( total == WagonConstants.UNKNOWN_LENGTH ? "?" : ( 
total / 1024 ) + "K" ) + "\r" );
+        if ( total >= 1024 )
+        {
+            System.out.print(
+                ( complete / 1024 ) + "/" + ( total == 
WagonConstants.UNKNOWN_LENGTH ? "?" : ( total / 1024 ) + "K" ) +
+                    "\r" );
+        }
+        else
+        {
+            System.out.print( complete + "/" + ( total == 
WagonConstants.UNKNOWN_LENGTH ? "?" : total + "b" ) + "\r" );
+        }
     }
 
     public void transferCompleted( TransferEvent transferEvent )
     {
-        System.out.println(
-            ( complete / 1024 ) + "K " +
-            ( transferEvent.getRequestType() == TransferEvent.REQUEST_PUT ? 
"uploaded" : "downloaded" ) );
+        long contentLength = transferEvent.getResource().getContentLength();
+        if ( contentLength != WagonConstants.UNKNOWN_LENGTH )
+        {
+            String type = ( transferEvent.getRequestType() == 
TransferEvent.REQUEST_PUT ? "uploaded" : "downloaded" );
+            String l = contentLength >= 1024 ? ( contentLength / 1024 ) + "K" 
: contentLength + "b";
+            System.out.println( l + " " + type );
+        }
     }
 
     public void transferError( TransferEvent transferEvent )

Modified: 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/MavenCli.java
URL: 
http://svn.apache.org/viewcvs/maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/MavenCli.java?rev=191492&r1=191491&r2=191492&view=diff
==============================================================================
--- 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/MavenCli.java
 (original)
+++ 
maven/components/trunk/maven-core/src/main/java/org/apache/maven/cli/MavenCli.java
 Mon Jun 20 08:21:50 2005
@@ -224,7 +224,7 @@
 
             request = createRequest( projectFiles, embedder, commandLine, 
settings, eventDispatcher, manager );
 
-            maven = createMavenInstance( embedder );
+            maven = createMavenInstance( embedder, 
settings.isInteractiveMode() );
         }
         catch ( ComponentLookupException e )
         {
@@ -346,12 +346,19 @@
         return files;
     }
 
-    private static Maven createMavenInstance( Embedder embedder )
+    private static Maven createMavenInstance( Embedder embedder, boolean 
interactive )
         throws ComponentLookupException
     {
         // TODO [BP]: doing this here as it is CLI specific, though it doesn't 
feel like the right place (likewise logger).
         WagonManager wagonManager = (WagonManager) embedder.lookup( 
WagonManager.ROLE );
-        wagonManager.setDownloadMonitor( new ConsoleDownloadMonitor() );
+        if ( interactive )
+        {
+            wagonManager.setDownloadMonitor( new ConsoleDownloadMonitor() );
+        }
+        else
+        {
+            wagonManager.setDownloadMonitor( new BatchModeDownloadMonitor() );
+        }
 
         return (Maven) embedder.lookup( Maven.ROLE );
     }



---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to