Node Bindings for LLVM. The API is mostly identical to the one of LLVM (when possible and not to cumbersom). All supported methods with their signatures are listed in the TypeScript definition file.
Install the packages using npm or yarn.
npm install --save llvm-nodeRequire llvm-node and you're good to go
import * as llvm from "llvm-node";
// or
const llvm = require("llvm-node");
const context = new llvm.LLVMContext();
const module = new llvm.Module("test", context);
const intType = llvm.Type.getInt32Ty(context);
const initializer = llvm.ConstantInt.get(context, 0);
const globalVariable = new llvm.GlobalVariable(module, intType, true, llvm.LinkageTypes.InternalLinkage, initializer);
const ll = module.print(); // prints IR
llvm.writeBitcodeToFile(module, biteCodeFileName); // Writes file to diskYou can use the npm configuration options to set the path to the LLVM cmake directory. This is needed if you don't want to use the system default LLVM installation --- e.g. when you want to compile againt the latest dev version.
To change the LLVM version use:
npm config set cmake_LLVM_DIR $(path-to-llvm/bin/llvm-config --cmakedir)If you want to change the value just for a single project use an .npmrc file in your project.
If you want to use Value.dump or Module.dump you need to use the debug build of the library (and, as well, of LLVM).
In this case, run node-gyp build --debug or if using npm install run npm_config_DEBUG=true npm install llvm-node.
There variables can also be set using npm set:
npm config set [--global] DEBUG True
- Install the C++ Extension
- Install the Cmake Tools Extension
- Configure the LLVM directory in the user settings by adding the following entry
"cmake.configureSettings": {
"LLVM_DIR": "/usr/local/Cellar/llvm/7.0.0/lib/cmake/llvm" // Output of llvm-config --cmakedir
}- Run the
CMake:ConfigureCommand in Visual Studio Code - Run
yarn configurefrom the command line - Run
CMake:Buildcommand in Visual Studio Code