about summary refs log tree commit diff
path: root/src/rt/rust_gc.cpp
diff options
context:
space:
mode:
authorPatrick Walton <pcwalton@mimiga.net>2011-09-23 11:02:04 -0700
committerPatrick Walton <pcwalton@mimiga.net>2011-09-23 11:04:14 -0700
commitdbdeff659fb30fd845490cf215b5733e1e064d46 (patch)
tree69d321dad8396d8f2ca5d61255253d30e50249b7 /src/rt/rust_gc.cpp
parentf8007b5535938be4f8b774177bc96dda2e9f5a71 (diff)
downloadrust-dbdeff659fb30fd845490cf215b5733e1e064d46.tar.gz
rust-dbdeff659fb30fd845490cf215b5733e1e064d46.zip
rt: Factor out the logic that handles the various magic debug environment variables
Diffstat (limited to 'src/rt/rust_gc.cpp')
-rw-r--r--src/rt/rust_gc.cpp10
1 files changed, 3 insertions, 7 deletions
diff --git a/src/rt/rust_gc.cpp b/src/rt/rust_gc.cpp
index 6e6a5dd766f..6e698de59db 100644
--- a/src/rt/rust_gc.cpp
+++ b/src/rt/rust_gc.cpp
@@ -7,6 +7,7 @@
 #include <stdint.h>
 
 #include "rust_abi.h"
+#include "rust_debug.h"
 #include "rust_gc.h"
 #include "rust_internal.h"
 #include "rust_shape.h"
@@ -180,14 +181,9 @@ maybe_gc(rust_task *task) {
     if (*safe_point_data == NULL)
         return;
 
-    // FIXME: We ought to lock this.
-    static int zeal = -1;
-    if (zeal == -1) {
-        char *ev = getenv("RUST_GC_ZEAL");
-        zeal = ev && ev[0] != '\0' && ev[0] != '0';
-    }
+    static debug::flag zeal("RUST_GC_ZEAL");
 
-    if (zeal) {
+    if (*zeal) {
         gc gc(task);
         gc.run();
     }