refactor progress reporting from dependency on org.eclipse.core.runtime.IProgressMonitor (FELIX-1509)


git-svn-id: https://svn.apache.org/repos/asf/felix/trunk@981796 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/sigil/common/core/sigil.properties b/sigil/common/core/sigil.properties
index 4d52aab..801ce44 100644
--- a/sigil/common/core/sigil.properties
+++ b/sigil/common/core/sigil.properties
@@ -15,7 +15,8 @@
 	org.apache.felix.sigil.common.config*, \
 	org.apache.felix.sigil.common.core*, \
 	org.apache.felix.sigil.common.model*, \
-	org.apache.felix.sigil.common.repository*,
+	org.apache.felix.sigil.common.repository*, \
+	org.apache.felix.sigil.common.progress*,
 
 -resources: \
 	profiles, \
@@ -40,6 +41,7 @@
 	org.apache.felix.sigil.common.model.eclipse, \
 	org.apache.felix.sigil.common.model.osgi, \
 	org.apache.felix.sigil.common.repository, \
+	org.apache.felix.sigil.common.progress, \
 
 -imports: \
 	aQute.lib.osgi;resolve=compile, \
@@ -53,12 +55,8 @@
 	org.apache.felix.sigil.common.model.osgi, \
 	org.apache.felix.sigil.common.osgi, \
 	org.apache.felix.sigil.common.repository, \
-	org.eclipse.core.runtime, \
 	org.osgi.framework, \
 
--requires: \
-	org.eclipse.equinox.common;version=3.4.0, \
-
 header;Bundle-ActivationPolicy: lazy
 
 # end
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/license/LicensePolicy.java b/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/license/LicensePolicy.java
index d393b0a..06eefd3 100644
--- a/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/license/LicensePolicy.java
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/license/LicensePolicy.java
@@ -21,7 +21,7 @@
 
 import org.apache.felix.sigil.common.core.licence.ILicensePolicy;
 import org.apache.felix.sigil.common.model.eclipse.ISigilBundle;
-import org.eclipse.core.runtime.IProgressMonitor;
+import org.apache.felix.sigil.common.progress.IProgress;
 
 public class LicensePolicy implements ILicensePolicy
 {
@@ -50,7 +50,7 @@
 
     }
 
-    public void save(IProgressMonitor monitor)
+    public void save(IProgress progress)
     {
         // TODO Auto-generated method stub
 
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/model/eclipse/SigilBundle.java b/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/model/eclipse/SigilBundle.java
index 98d1146..a5f5a4c 100644
--- a/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/model/eclipse/SigilBundle.java
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/core/internal/model/eclipse/SigilBundle.java
@@ -43,8 +43,7 @@
 import org.apache.felix.sigil.common.model.osgi.IBundleModelElement;
 import org.apache.felix.sigil.common.model.osgi.IPackageExport;
 import org.apache.felix.sigil.common.model.osgi.IPackageImport;
-import org.eclipse.core.runtime.IProgressMonitor;
-import org.eclipse.core.runtime.SubMonitor;
+import org.apache.felix.sigil.common.progress.IProgress;
 import org.osgi.framework.Version;
 
 /**
@@ -74,17 +73,17 @@
         packages = new String[0];
     }
 
-    public void synchronize(IProgressMonitor monitor) throws IOException
+    public void synchronize(IProgress progress) throws IOException
     {
-        SubMonitor progress = SubMonitor.convert(monitor, 100);
-        progress.subTask("Synchronizing " + bundle.getSymbolicName() + " binary");
+        progress = progress.newTask(100);
+        progress.report("Synchronizing " + bundle.getSymbolicName() + " binary");
         sync(location, bundle.getUpdateLocation(), progress.newChild(45));
 
         if (bundle.getSourceLocation() != null)
         {
             try
             {
-                progress.subTask("Synchronizing " + bundle.getSymbolicName() + " source");
+                progress.report("Synchronizing " + bundle.getSymbolicName() + " source");
                 sync(sourcePathLocation, bundle.getSourceLocation(),
                     progress.newChild(45));
             }
@@ -99,7 +98,7 @@
         {
             try
             {
-                progress.subTask("Synchronizing " + bundle.getSymbolicName() + " licence");
+                progress.report("Synchronizing " + bundle.getSymbolicName() + " licence");
                 sync(licencePathLocation, bundle.getLicenseURI(), progress.newChild(10));
             }
             catch (IOException e)
@@ -133,7 +132,7 @@
         return location == null || location.exists();
     }
 
-    private static void sync(File local, URI remote, IProgressMonitor monitor)
+    private static void sync(File local, URI remote, IProgress progress)
         throws IOException
     {
         try
@@ -146,7 +145,8 @@
                     URLConnection connection = url.openConnection();
                     int contentLength = connection.getContentLength();
 
-                    monitor.beginTask("Downloading from " + url.getHost(), contentLength);
+                    progress = progress.newTask(contentLength);
+                    progress.report("Downloading from " + url.getHost());
 
                     InputStream in = null;
                     OutputStream out = null;
@@ -162,7 +162,7 @@
                         in = conn.getInputStream();
                         local.getParentFile().mkdirs();
                         out = new FileOutputStream(local);
-                        stream(in, out, monitor);
+                        stream(in, out, progress);
                     }
                     finally
                     {
@@ -174,7 +174,7 @@
                         {
                             out.close();
                         }
-                        monitor.done();
+                        progress.done();
                     }
                 }
             }
@@ -186,13 +186,13 @@
         }
     }
 
-    private static void stream(InputStream in, OutputStream out, IProgressMonitor monitor)
+    private static void stream(InputStream in, OutputStream out, IProgress progress)
         throws IOException
     {
         byte[] b = new byte[1024];
         for (;;)
         {
-            if (monitor.isCanceled())
+            if (progress.isCanceled())
             {
                 throw new InterruptedIOException("User canceled download");
             }
@@ -200,7 +200,7 @@
             if (r == -1)
                 break;
             out.write(b, 0, r);
-            monitor.worked(r);
+            progress.worked(r);
         }
 
         out.flush();
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/core/licence/ILicensePolicy.java b/sigil/common/core/src/org/apache/felix/sigil/common/core/licence/ILicensePolicy.java
index eefef3c..450e6f0 100644
--- a/sigil/common/core/src/org/apache/felix/sigil/common/core/licence/ILicensePolicy.java
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/core/licence/ILicensePolicy.java
@@ -20,7 +20,7 @@
 package org.apache.felix.sigil.common.core.licence;
 
 import org.apache.felix.sigil.common.model.eclipse.ISigilBundle;
-import org.eclipse.core.runtime.IProgressMonitor;
+import org.apache.felix.sigil.common.progress.IProgress;
 
 public interface ILicensePolicy
 {
@@ -30,5 +30,5 @@
 
     boolean accept(ISigilBundle bundle);
 
-    void save(IProgressMonitor monitor);
+    void save(IProgress progress);
 }
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/BundleResolver.java b/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/BundleResolver.java
index b7c8bf8..7028461 100644
--- a/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/BundleResolver.java
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/BundleResolver.java
@@ -42,6 +42,7 @@
 import org.apache.felix.sigil.common.model.osgi.IPackageExport;
 import org.apache.felix.sigil.common.model.osgi.IPackageImport;
 import org.apache.felix.sigil.common.model.osgi.IRequiredBundle;
+import org.apache.felix.sigil.common.progress.IProgress;
 import org.apache.felix.sigil.common.repository.IBundleRepository;
 import org.apache.felix.sigil.common.repository.IBundleResolver;
 import org.apache.felix.sigil.common.repository.IRepositoryManager;
@@ -49,8 +50,6 @@
 import org.apache.felix.sigil.common.repository.IResolutionMonitor;
 import org.apache.felix.sigil.common.repository.ResolutionConfig;
 import org.apache.felix.sigil.common.repository.ResolutionException;
-import org.eclipse.core.runtime.IProgressMonitor;
-import org.eclipse.core.runtime.SubMonitor;
 import org.osgi.framework.Version;
 
 public class BundleResolver implements IBundleResolver
@@ -279,14 +278,14 @@
             return true;
         }
 
-        public void synchronize(IProgressMonitor monitor)
+        public void synchronize(IProgress progress)
         {
             Set<ISigilBundle> bundles = getBundles();
-            SubMonitor progress = SubMonitor.convert(monitor, bundles.size());
+            progress = progress.newTask(bundles.size());
 
             for (ISigilBundle b : bundles)
             {
-                if (monitor.isCanceled())
+                if (progress.isCanceled())
                 {
                     break;
                 }
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/ProgressWrapper.java b/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/ProgressWrapper.java
deleted file mode 100644
index e1db339..0000000
--- a/sigil/common/core/src/org/apache/felix/sigil/common/core/repository/ProgressWrapper.java
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements.  See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership.  The ASF licenses this file
- * to you 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.
- */
-
-package org.apache.felix.sigil.common.core.repository;
-
-import org.eclipse.core.runtime.IProgressMonitor;
-import org.apache.felix.sigil.common.repository.IResolutionMonitor;
-
-public class ProgressWrapper implements IProgressMonitor
-{
-
-    private IResolutionMonitor monitor;
-
-    public ProgressWrapper(IResolutionMonitor monitor)
-    {
-        this.monitor = monitor;
-    }
-
-    public boolean isCanceled()
-    {
-        return monitor.isCanceled();
-    }
-
-    public void beginTask(String name, int totalWork)
-    {
-        // TODO Auto-generated method stub
-
-    }
-
-    public void done()
-    {
-        // TODO Auto-generated method stub
-
-    }
-
-    public void internalWorked(double work)
-    {
-        // TODO Auto-generated method stub
-
-    }
-
-    public void setCanceled(boolean value)
-    {
-        // TODO Auto-generated method stub
-
-    }
-
-    public void setTaskName(String name)
-    {
-        // TODO Auto-generated method stub
-
-    }
-
-    public void subTask(String name)
-    {
-        // TODO Auto-generated method stub
-
-    }
-
-    public void worked(int work)
-    {
-        // TODO Auto-generated method stub
-
-    }
-}
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/model/eclipse/ISigilBundle.java b/sigil/common/core/src/org/apache/felix/sigil/common/model/eclipse/ISigilBundle.java
index 5dcde31..a597ac9 100644
--- a/sigil/common/core/src/org/apache/felix/sigil/common/model/eclipse/ISigilBundle.java
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/model/eclipse/ISigilBundle.java
@@ -23,13 +23,13 @@
 import java.io.IOException;
 import java.util.Collection;
 
-import org.eclipse.core.runtime.IProgressMonitor;
 import org.apache.felix.sigil.common.config.Resource;
 import org.apache.felix.sigil.common.model.ICompoundModelElement;
 import org.apache.felix.sigil.common.model.osgi.IBundleModelElement;
 import org.apache.felix.sigil.common.model.osgi.IPackageExport;
 import org.apache.felix.sigil.common.model.osgi.IPackageImport;
 import org.apache.felix.sigil.common.model.osgi.IVersionedModelElement;
+import org.apache.felix.sigil.common.progress.IProgress;
 
 /**
  * @author dave
@@ -37,7 +37,7 @@
  */
 public interface ISigilBundle extends ICompoundModelElement, IVersionedModelElement
 {
-    void synchronize(IProgressMonitor monitor) throws IOException;
+    void synchronize(IProgress progress) throws IOException;
 
     boolean isSynchronized();
 
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/progress/IProgress.java b/sigil/common/core/src/org/apache/felix/sigil/common/progress/IProgress.java
new file mode 100644
index 0000000..93a8dc1
--- /dev/null
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/progress/IProgress.java
@@ -0,0 +1,62 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements.  See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership.  The ASF licenses this file
+ * to you 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.
+ */
+
+package org.apache.felix.sigil.common.progress;
+
+/**
+ * @author dave
+ *
+ */
+public interface IProgress
+{
+
+    /**
+     * @return
+     */
+    boolean isCanceled();
+
+    /**
+     * @param totalWork
+     * @return
+     */
+    IProgress newChild(int totalWork);
+    
+    /**
+     * @param name
+     * @param totalWork
+     * @return
+     */
+    IProgress newTask(int totalWork);
+    
+    /**
+     * @param msg
+     */
+    void report(String msg);
+
+    /**
+     * @param work
+     */
+    void worked(int work);
+
+    /**
+     * 
+     */
+    void done();
+
+}
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/repository/IResolution.java b/sigil/common/core/src/org/apache/felix/sigil/common/repository/IResolution.java
index 9a63899..f9b053f 100644
--- a/sigil/common/core/src/org/apache/felix/sigil/common/repository/IResolution.java
+++ b/sigil/common/core/src/org/apache/felix/sigil/common/repository/IResolution.java
@@ -22,9 +22,9 @@
 import java.util.List;
 import java.util.Set;
 
-import org.eclipse.core.runtime.IProgressMonitor;
 import org.apache.felix.sigil.common.model.IModelElement;
 import org.apache.felix.sigil.common.model.eclipse.ISigilBundle;
+import org.apache.felix.sigil.common.progress.IProgress;
 
 public interface IResolution
 {
@@ -34,7 +34,7 @@
 
     List<IModelElement> getMatchedRequirements(ISigilBundle bundle);
 
-    void synchronize(IProgressMonitor monitor);
+    void synchronize(IProgress progress);
 
     boolean isSynchronized();
 }
diff --git a/sigil/common/core/src/org/apache/felix/sigil/common/repository/ResolutionMonitorAdapter.java b/sigil/common/core/src/org/apache/felix/sigil/common/repository/ResolutionMonitorAdapter.java
deleted file mode 100644
index 9e5db18..0000000
--- a/sigil/common/core/src/org/apache/felix/sigil/common/repository/ResolutionMonitorAdapter.java
+++ /dev/null
@@ -1,52 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements.  See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership.  The ASF licenses this file
- * to you 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.
- */
-
-package org.apache.felix.sigil.common.repository;
-
-import org.eclipse.core.runtime.IProgressMonitor;
-import org.apache.felix.sigil.common.model.IModelElement;
-import org.apache.felix.sigil.common.model.eclipse.ISigilBundle;
-
-public class ResolutionMonitorAdapter implements IResolutionMonitor
-{
-
-    private IProgressMonitor monitor;
-
-    public ResolutionMonitorAdapter(IProgressMonitor monitor)
-    {
-        this.monitor = monitor;
-    }
-
-    public boolean isCanceled()
-    {
-        return monitor.isCanceled();
-    }
-
-    public void startResolution(IModelElement requirement)
-    {
-        monitor.subTask("Resolving " + requirement);
-    }
-
-    public void endResolution(IModelElement requirement, ISigilBundle provider)
-    {
-        monitor.subTask((provider == null ? "Failed to resolve " : "Resolved ")
-            + requirement);
-    }
-
-}