A BQN implementation in C
CBQN-specific documentation • source code overview
make- Third-party packages and other ways to run BQN are listed here
make CC=ccif clang isn't installedmake FFI=0if your system doesn't have libffi (ifpkg-configdoesn't exist, extra configuration may be necessary to allow CBQN to find libffi)- Use
gmakeon BSD (aNO_LDL=1make arg may be useful if the build complains about-ldl) make cleanif anything breaks and you want a clean build slate- Run
sudo make installafterwards to install into/usr/local/bin/bqn(aPREFIX=/some/pathargument will install to/some/path/bin/bqn);sudo make uninstallto uninstall make REPLXX=1to enable replxx (syntax highlighting & some system & variable name completion)
./BQN somefile.bqnto execute a file, orrlwrap ./BQNfor a REPL (or just./BQNif replxx is enabled)
- Different build types:
make o3--O3, the default buildmake o3n--O3 -march=nativemake o3g--O3 -gmake debug- unoptimized build with extra assertion checks (incl.-g)make debug1- debug build without parallel compilation. Useful if everything errors, and you don't want error messages from multiple threads to be printed at the same time.make heapverify- verify that refcounting is done correctlymake o3n-singeli- a Singeli build, currently only for x86-64 CPUs supporting AVX2 & BMI2make shared-o3- produce the shared librarylibcbqn.somake c- a build with no flags, for manual customizingmake shared-c- likemake cbut for a shared librarymake single-(o3|o3g|debug|c)- compile everything as a single translation unit. Will take longer to compile & won't have incremental compilation, and isn't supported for many configurations.make emcc-o3- build with Emscriptenemcc
- Output executable/library location can be changed with
OUTPUT=output/path/file.
Foremcc-o3, that will be used as a directory to add theBQN.jsandBQN.wasmfiles to. - For any of the above (especially
make c), you can add extra compiler flags withf=..., e.g.
make f='-O3 -DSOME_MACRO=whatever -some_other_cc_flag' cormake debug f=-O2.- Linker flags can be added with
lf=..., and flags for both withCCFLAGS=...; for replxx compilation,REPLXX_FLAGS=...will change the C++ flags. - If you want to use custom build types but your system doesn't have
shasumorsha256sum, addforce_build_dir=build/obj/some_identifier. That directory will be used to store incremental build object files. Macros that you may want to define are listed insrc/h.h.
- Linker flags can be added with
- Adding
builddir=1to the make argument list will give you the build directory of the current configuration. Addingclean=1will clean that directory. - Use
j=8instead of-j8to override the default parallel job count (which is currently4). - Tests can be run with
./BQN path/to/mlochbaum/BQN/test/this.bqn(add-noerrif usingmake heapverify). - Git submodules are used for Singeli, replxx, and bytecode. It's possible to override those by, respectively, linking/copying a local version to
build/singeliLocal,build/replxxLocal, andbuild/bytecodeLocal.
CBQN uses the self-hosted BQN compiler & some parts of the runtime, and therefore needs to be bootstrapped.
By default, the CBQN will use precompiled bytecode. In order to build everything from source, you need to:
- get another BQN implementation; dzaima/BQN is one that is completely implemented in Java (clone it & run
./build). - clone mlochbaum/BQN.
- From within CBQNs directory, run
mkdir -p build/bytecodeLocal/gen - Run
said-other-bqn-impl ./build/genRuntime path/to/mlochbaum/BQN build/bytecodeLocal
In the case of the Java impl,java -jar path/to/dzaima/BQN/BQN.jar ./build/genRuntime ~/git/BQN build/bytecodeLocal
CBQN requires either gcc or clang as the C compiler (though it defaults to clang, as optimizations are written based on whether or not clang needs them; add a CC=cc make arg to use the default system compiler), and, optionally libffi for •FFI, and C++ (C++11; defaults to c++, override with CXX=your-c++) for replxx.
While there aren't hard expectations of specific versions for any of those, nevertheless here are some configurations that CBQN is tested on by dzaima:
x86-64 (Linux):
gcc 9.5; gcc 11.3; clang 10.0.0; clang 14.0.0
libffi 3.4.2
cpu microarchitecture: Haswell
replxx: g++ 11.3.0
x86 (Linux):
clang 14.0.0; known to break on gcc - https://gcc.gnu.org/bugzilla/show_bug.cgi?id=58416
running on the above x86-64 system, compiled with CCFLAGS=-m32
AArch64 ARMv8-A (within Termux on Android 8):
using a `lf=-landroid-spawn` make arg after `pkg install libandroid-spawn` to get •SH to work
clang 15.0.4
libffi 3.4.4 (structs were broken as of 3.4.3)
replxx: clang++ 15.0.4
Additionally, CBQN is known to compile as-is on macOS (with some extra options for FFI), but Windows requires WinBQN to properly set up Cygwin/Msys2.
Most files here are copyright (c) 2021 dzaima & others, GNU GPLv3 only. Exceptions are:
- timsort implementation -
src/builtins/sortTemplate.h: MIT; original repo - Ryu -
src/utils/ryu.c& files insrc/utils/ryu/: Apache 2.0 or Boost 1.0; original repo