5cd022d6c0
This can be used to import a dynamic shared object and return an arbitrary value, including new primops. This can be used both to test new primops without having to recompile nix every time, and to build specialized primops that probably don't belong upstream (e.g. a function that calls out to gpg to decrypt a nixops secret as-needed). The imported function should initialize the Value & as needed. A single import can define multiple values by creating an attrset or list, of course. An example initialization function might look like: extern "C" void initialize(nix::EvalState & state, nix::Value & v) { v.type = nix::tPrimOp; v.primOp = NEW nix::PrimOp(myFun, 1, state.symbols.create("myFun")); } Then `builtins.importNative ./example.so "initialize"` will evaluate to the primop defined in the myFun function.
31 lines
1,015 B
Makefile
31 lines
1,015 B
Makefile
libraries += libexpr
|
|
|
|
libexpr_NAME = libnixexpr
|
|
|
|
libexpr_DIR := $(d)
|
|
|
|
libexpr_SOURCES := $(wildcard $(d)/*.cc) $(d)/lexer-tab.cc $(d)/parser-tab.cc
|
|
|
|
libexpr_LIBS = libutil libstore libformat
|
|
|
|
libexpr_LDFLAGS = -ldl
|
|
|
|
# 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
|
|
$(trace-gen) bison -v -o $(libexpr_DIR)/parser-tab.cc $< -d
|
|
|
|
$(d)/lexer-tab.cc $(d)/lexer-tab.hh: $(d)/lexer.l
|
|
$(trace-gen) flex --outfile $(libexpr_DIR)/lexer-tab.cc --header-file=$(libexpr_DIR)/lexer-tab.hh $<
|
|
|
|
$(d)/lexer-tab.o: $(d)/lexer-tab.hh $(d)/parser-tab.hh
|
|
|
|
$(d)/parser-tab.o: $(d)/lexer-tab.hh $(d)/parser-tab.hh
|
|
|
|
clean-files += $(d)/parser-tab.cc $(d)/parser-tab.hh $(d)/lexer-tab.cc $(d)/lexer-tab.hh
|
|
|
|
dist-files += $(d)/parser-tab.cc $(d)/parser-tab.hh $(d)/lexer-tab.cc $(d)/lexer-tab.hh
|