]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/deploy/VersionedDirSync.java
Update license header
[gpl/argeo-slc.git] / runtime / org.argeo.slc.core / src / main / java / org / argeo / slc / core / deploy / VersionedDirSync.java
index 212eb367c24c5b8c2a69790fdc95eca3cab0da06..ee84cf9ecc0632bc09062a051d14e0222b6956c5 100644 (file)
 package org.argeo.slc.core.deploy;
 
 import java.io.File;
+import java.io.IOException;
 
+import org.apache.commons.io.FileUtils;
 import org.apache.commons.logging.Log;
 import org.apache.commons.logging.LogFactory;
+import org.argeo.slc.SlcException;
 import org.argeo.slc.deploy.VersioningDriver;
 
 /**
@@ -32,9 +35,22 @@ public class VersionedDirSync implements Runnable {
        private VersioningDriver versioningDriver;
        private File dir;
        private String url;
+       private Boolean clean = false;
+
+       private Boolean changed = null;
 
        public void run() {
-               versioningDriver.checkout(url, dir, true);
+               changed = null;
+               if (clean) {
+                       try {
+                               FileUtils.deleteDirectory(dir);
+                       } catch (IOException e) {
+                               throw new SlcException("Cannot delete checkout directory "
+                                               + dir, e);
+                       }
+                       dir.mkdirs();
+               }
+               changed = versioningDriver.checkout(url, dir, true);
                if (log.isDebugEnabled())
                        log.debug("Synchronized " + url + " to " + dir);
        }
@@ -51,4 +67,16 @@ public class VersionedDirSync implements Runnable {
                this.url = url;
        }
 
+       /** Delete before checkout */
+       public void setClean(Boolean clean) {
+               this.clean = clean;
+       }
+
+       /** Whether last call has changed the directory */
+       public Boolean getChanged() {
+               if (changed == null)
+                       throw new SlcException("Sync has not run");
+               return changed;
+       }
+
 }