src/Pure/System/platform.scala
changeset 72249 4bf8a8a2d2ad
parent 72149 36a34f3a8cb8
child 72250 13976f92a2d0
--- a/src/Pure/System/platform.scala	Thu Sep 10 16:04:12 2020 +0200
+++ b/src/Pure/System/platform.scala	Thu Sep 10 21:07:58 2020 +0200
@@ -70,20 +70,35 @@
   val jvm_name: String = System.getProperty("java.vm.name", "")
 
 
+  /* memory status */
+
+  sealed case class Memory_Status(heap_size: Long, heap_free: Long)
+  {
+    def heap_used: Long = (heap_size - heap_free) max 0
+    def heap_used_fraction: Double =
+      if (heap_size == 0) 0.0 else heap_used.toDouble / heap_size
+  }
+
+  def memory_status(): Memory_Status =
+  {
+    val heap_size = Runtime.getRuntime.totalMemory()
+    val heap_used = heap_size - Runtime.getRuntime.freeMemory()
+    Memory_Status(heap_size, heap_used)
+  }
+
+
   /* JVM statistics */
 
   def jvm_statistics(): Properties.T =
   {
-    val heap_size = Runtime.getRuntime.totalMemory()
-    val heap_used = heap_size - Runtime.getRuntime.freeMemory()
-
+    val status = memory_status()
     val threads = Thread.activeCount()
     val workers = Isabelle_Thread.pool.getPoolSize
     val workers_active = Isabelle_Thread.pool.getActiveCount
 
     List(
-      "java_heap_size" -> heap_size.toString,
-      "java_heap_used" -> heap_used.toString,
+      "java_heap_size" -> status.heap_size.toString,
+      "java_heap_used" -> status.heap_used.toString,
       "java_threads_total" -> threads.toString,
       "java_workers_total" -> workers.toString,
       "java_workers_active" -> workers_active.toString)