hardlink within JVM;
authorwenzelm
Sun, 22 Jan 2017 15:02:06 +0100
changeset 64934 795055a0be98
parent 64933 4c96995e20cb
child 64935 9437a117408b
hardlink within JVM; clarified file attributes;
src/Pure/Admin/build_jdk.scala
src/Pure/General/file.scala
--- a/src/Pure/Admin/build_jdk.scala	Sun Jan 22 13:58:26 2017 +0100
+++ b/src/Pure/Admin/build_jdk.scala	Sun Jan 22 15:02:06 2017 +0100
@@ -8,6 +8,7 @@
 
 
 import java.nio.file.Files
+import java.nio.file.attribute.PosixFilePermission
 
 import scala.util.matching.Regex
 
@@ -168,16 +169,17 @@
           File.move(dir + Path.explode(platform.name), component_dir)
 
         for (file <- File.find_files(component_dir.file, include_dirs = true)) {
-          import java.nio.file.attribute.PosixFilePermission._
           val path = file.toPath
           val perms = Files.getPosixFilePermissions(path)
-          perms.add(OWNER_READ)
-          perms.add(GROUP_READ)
-          perms.add(OTHERS_READ)
+          perms.add(PosixFilePermission.OWNER_READ)
+          perms.add(PosixFilePermission.GROUP_READ)
+          perms.add(PosixFilePermission.OTHERS_READ)
+          perms.add(PosixFilePermission.OWNER_WRITE)
           if (file.isDirectory) {
-            perms.add(OWNER_EXECUTE)
-            perms.add(GROUP_EXECUTE)
-            perms.add(OTHERS_EXECUTE)
+            perms.add(PosixFilePermission.OWNER_WRITE)
+            perms.add(PosixFilePermission.OWNER_EXECUTE)
+            perms.add(PosixFilePermission.GROUP_EXECUTE)
+            perms.add(PosixFilePermission.OTHERS_EXECUTE)
           }
           Files.setPosixFilePermissions(path, perms)
         }
@@ -186,24 +188,20 @@
           file => file.getName.startsWith("._")).foreach(_.delete)
 
         progress.echo("Sharing ...")
-        Isabelle_System.bash(cwd = component_dir.file,
-          script = """
-            cd x86-linux
-            for FILE in $(find . -type f)
-            do
-              for OTHER in \
-                "../x86_64-linux/$FILE" \
-                "../x86-windows/$FILE" \
-                "../x86_64-windows/$FILE" \
-                "../x86_64-darwin/Contents/Home/$FILE"
-              do
-                if cmp -s "$FILE" "$OTHER"
-                then
-                  ln -f "$FILE" "$OTHER"
-                fi
-              done
-            done
-          """).check
+        val main_dir :: other_dirs =
+          jdk_platforms.map(platform => (component_dir + Path.explode(platform.name)).file.toPath)
+        for {
+          file1 <- File.find_files(main_dir.toFile).iterator
+          path1 = file1.toPath
+          dir2 <- other_dirs.iterator
+        } {
+          val path2 = dir2.resolve(main_dir.relativize(path1))
+          val file2 = path2.toFile
+          if (file2.isFile && File.eq_content(file1, file2)) {
+            file2.delete
+            Files.createLink(path2, path1)
+          }
+        }
 
         progress.echo("Archiving ...")
         Isabelle_System.bash("tar -C " + File.bash_path(dir) + " -czf " +
--- a/src/Pure/General/file.scala	Sun Jan 22 13:58:26 2017 +0100
+++ b/src/Pure/General/file.scala	Sun Jan 22 15:02:06 2017 +0100
@@ -248,6 +248,16 @@
   def eq(path1: Path, path2: Path): Boolean = eq(path1.file, path2.file)
 
 
+  /* eq_content */
+
+  def eq_content(file1: JFile, file2: JFile): Boolean =
+    if (eq(file1, file2)) true
+    else if (file1.length != file2.length) false
+    else Bytes.read(file1) == Bytes.read(file2)
+
+  def eq_content(path1: Path, path2: Path): Boolean = eq_content(path1.file, path2.file)
+
+
   /* copy */
 
   def copy(src: JFile, dst: JFile)