src/Pure/Admin/build_history.scala
changeset 78492 aeda5a004d89
parent 78439 001d423daf7c
child 78610 fd1fec53665b
--- a/src/Pure/Admin/build_history.scala	Tue Aug 08 18:52:09 2023 +0200
+++ b/src/Pure/Admin/build_history.scala	Tue Aug 08 23:51:01 2023 +0200
@@ -16,10 +16,14 @@
 
   /* augment settings */
 
+  def make_64_32(platform: String): String =
+    platform.replace("x86_64-", "x86_64_32-").replace("arm64-", "arm64_32-")
+
   def augment_settings(
     other_isabelle: Other_Isabelle,
     threads: Int,
     arch_64: Boolean,
+    arch_apple: Boolean,
     heap: Int,
     max_heap: Option[Int],
     more_settings: List[String]
@@ -31,7 +35,9 @@
       val windows_64_32 = "x86_64_32-windows"
       val platform_32 = other_isabelle.getenv("ISABELLE_PLATFORM32")
       val platform_64 = other_isabelle.getenv("ISABELLE_PLATFORM64")
-      val platform_64_32 = platform_64.replace("x86_64-", "x86_64_32-")
+      val platform_64_32 = make_64_32(platform_64)
+      val platform_apple_64 = other_isabelle.getenv("ISABELLE_APPLE_PLATFORM64")
+      val platform_apple_64_32 = make_64_32(platform_apple_64)
 
       val polyml_home =
         try { Path.explode(other_isabelle.getenv("ML_HOME")).dir }
@@ -55,6 +61,12 @@
           else if (check_dir(windows_32)) windows_32
           else err(windows_32)
         }
+        else if (arch_apple && arch_64) {
+          if (check_dir(platform_apple_64)) platform_apple_64 else err(platform_apple_64)
+        }
+        else if (arch_apple) {
+          if (check_dir(platform_apple_64_32)) platform_apple_64_32 else err(platform_apple_64_32)
+        }
         else if (arch_64) {
           if (check_dir(platform_64)) platform_64 else err(platform_64)
         }
@@ -112,6 +124,7 @@
     multicore_base: Boolean = false,
     multicore_list: List[(Int, Int)] = List(default_multicore),
     arch_64: Boolean = false,
+    arch_apple: Boolean = false,
     heap: Int = default_heap,
     max_heap: Option[Int] = None,
     more_settings: List[String] = Nil,
@@ -199,7 +212,8 @@
       other_isabelle.init_settings(component_settings)
       resolve_components()
       val ml_platform =
-        augment_settings(other_isabelle, threads, arch_64, heap, max_heap, more_settings)
+        augment_settings(
+          other_isabelle, threads, arch_64, arch_apple, heap, max_heap, more_settings)
 
       File.write(other_isabelle.etc_preferences, cat_lines(more_preferences))
 
@@ -413,6 +427,7 @@
       var afp_partition = 0
       var clean_archives = false
       var component_repository = Components.static_component_repository
+      var arch_apple = false
       var more_settings: List[String] = Nil
       var more_preferences: List[String] = Nil
       var fresh = false
@@ -432,8 +447,8 @@
     -B           first multicore build serves as base for scheduling information
     -C DIR       base directory for Isabelle components (default: """ +
       quote(Components.dynamic_components_base) + """)
-    -H SIZE      minimal ML heap in MB (default: """ + default_heap + """ for x86, """ +
-      default_heap * 2 + """ for x86_64)
+    -H SIZE      minimal ML heap in MB (default: """ + default_heap + """ for 32bit, """ +
+      default_heap * 2 + """ for 64bit)
     -M MULTICORE multicore configurations (see below)
     -N NAME      alternative ISABELLE_IDENTIFIER (default: """ + default_isabelle_identifier + """)
     -O PLATFORMS clean resolved components, retaining only the given list
@@ -443,11 +458,12 @@
     -R URL       remote repository for Isabelle components (default: """ +
       Components.static_component_repository + """)
     -U SIZE      maximal ML heap in MB (default: unbounded)
+    -a           processor architecture is Apple Silicon (ARM64)
     -e TEXT      additional text for generated etc/settings
     -f           fresh build of Isabelle/Scala components (recommended)
     -h NAME      override local hostname
     -i TEXT      initial text for generated etc/settings
-    -m ARCH      processor architecture (32=x86, 64=x86_64, default: x86)
+    -m ARCH      processor architecture (32, 64, default: 32)
     -n           no build: sync only
     -o FILE      output file for log names (default: stdout)
     -p TEXT      additional text for generated etc/preferences
@@ -473,13 +489,14 @@
         "Q" -> (_ => clean_archives = true),
         "R:" -> (arg => component_repository = arg),
         "U:" -> (arg => max_heap = Some(Value.Int.parse(arg))),
+        "a" -> (_ => arch_apple = true),
         "e:" -> (arg => more_settings = more_settings ::: List(arg)),
         "f" -> (_ => fresh = true),
         "h:" -> (arg => hostname = arg),
         "m:" ->
           {
-            case "32" | "x86" => arch_64 = false
-            case "64" | "x86_64" => arch_64 = true
+            case "32" => arch_64 = false
+            case "64" => arch_64 = true
             case bad => error("Bad processor architecture: " + quote(bad))
           },
         "o:" -> (arg => output_file = arg),
@@ -505,7 +522,7 @@
           component_repository = component_repository, components_base = components_base,
           clean_platforms = clean_platforms, clean_archives = clean_archives,
           fresh = fresh, hostname = hostname, multicore_base = multicore_base,
-          multicore_list = multicore_list, arch_64 = arch_64,
+          multicore_list = multicore_list, arch_64 = arch_64, arch_apple = arch_apple,
           heap = heap.getOrElse(if (arch_64) default_heap * 2 else default_heap),
           max_heap = max_heap, more_settings = more_settings,
           more_preferences = more_preferences, verbose = verbose, build_tags = build_tags,