aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2013-11-23 20:19:36 +0000
committerEelco Dolstra <eelco.dolstra@logicblox.com>2013-11-23 20:19:36 +0000
commit5a1114ecdbbd115ec8aeb1a98326d793ff3e8058 (patch)
treefc14cd61a7bfc2b53b28957e0c6f60ac40d1b7d9 /src/libexpr
parent06a8ac96e79547c092debfe3b93d78bcb862edc2 (diff)
Drop the dependency on libgc in libmain
Instead, libexpr now depends on libgc. This means commands like nix-store that don't do any evaluation no longer require libgc.
Diffstat (limited to 'src/libexpr')
-rw-r--r--src/libexpr/Makefile.new5
-rw-r--r--src/libexpr/eval.cc17
2 files changed, 22 insertions, 0 deletions
diff --git a/src/libexpr/Makefile.new b/src/libexpr/Makefile.new
index ded112107..cbae11c53 100644
--- a/src/libexpr/Makefile.new
+++ b/src/libexpr/Makefile.new
@@ -9,6 +9,11 @@ libexpr_SOURCES = \
libexpr_LIBS = libutil libstore libformat
+# The dependency on libgc must be propagated (i.e. meaning that
+# programs/libraries that use libexpr must explicitly pass -lgc),
+# because inline functions in libexpr's header files call libgc.
+libexpr_LDFLAGS_PROPAGATED = $(BDW_GC_LIBS)
+
$(d)/parser-tab.cc $(d)/parser-tab.hh: $(d)/parser.y
bison -v -o $(libexpr_DIR)/parser-tab.cc $< -d
diff --git a/src/libexpr/eval.cc b/src/libexpr/eval.cc
index e4a0d7fd2..12c6aa8dc 100644
--- a/src/libexpr/eval.cc
+++ b/src/libexpr/eval.cc
@@ -129,6 +129,14 @@ string showType(const Value & v)
}
+/* Called when the Boehm GC runs out of memory. */
+static void * oomHandler(size_t requested)
+{
+ /* Convert this to a proper C++ exception. */
+ throw std::bad_alloc();
+}
+
+
EvalState::EvalState()
: sWith(symbols.create("<with>"))
, sOutPath(symbols.create("outPath"))
@@ -158,6 +166,14 @@ EvalState::EvalState()
#if HAVE_BOEHMGC
static bool gcInitialised = false;
if (!gcInitialised) {
+
+ /* Initialise the Boehm garbage collector. This isn't
+ necessary on most platforms, but for portability we do it
+ anyway. */
+ GC_INIT();
+
+ GC_oom_fn = oomHandler;
+
/* Set the initial heap size to something fairly big (25% of
physical RAM, up to a maximum of 384 MiB) so that in most
cases we don't need to garbage collect at all. (Collection
@@ -181,6 +197,7 @@ EvalState::EvalState()
debug(format("setting initial heap size to %1% bytes") % size);
GC_expand_hp(size);
}
+
gcInitialised = true;
}
#endif