andreypopp / CBQN

a BQN implementation in C

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

A BQN implementation in C

CBQN-specific documentationsource code overview

Running

  1. make
    • make CC=gcc if you don't have clang installed
    • make PIE="" on ARM CPUs (incl. Android & M1)
    • gmake on BSDs
    • make clean if anything goes bad and you want a clean slate
    • make [...]; sudo make install to install into /usr/local/bin/bqn; sudo make uninstall to uninstall
  2. ./BQN somefile.bqn to execute a file, or rlwrap ./BQN for a REPL

Configuration options

  • some-other-bqn-implementation ./genRuntime path/to/mlochbaum/BQN can be used to avoid pulling precompiled bytecode with git from remotes/origin/bytecode.
    This creates the dummy file src/gen/customRuntime, which will disable automated bytecode retrieval, leading to the bytecode going out-of-sync whenever it needs updating.
    make clean-runtime (which is included in make clean) can be used to reset this to the default state.
  • Different build types:
    • make o3 - -O3, the default build
    • make o3n - -O3 -march=native
    • make o3g - -g -O3
    • make debug - unoptimized debug build
    • make debug1 - debug build without parallel compilation. Useful if everything errors, and you don't want error messages of multiple threads to be written at the same time.
    • make heapverify - verify that refcounting is done correctly
    • make o3n-singeli - a Singeli build, currently only for x86-64 CPUs supporting AVX2
    • make t=some_custom_type f='-O3 -DSOME_MACRO=whatever -some_other_cc_flag' c - custom build
      Macros that you may want to define are listed in src/h.h.
      The some_custom_type is used as the key for caching/incremental compilation, so make sure to make t=some_custom_type clean if you want to change the flags without changing the t= value!!
    • make single-(o3|o3g|debug|c) - compile everything as a single translation unit. Slower for optimized builds, but may allow some more optimizations
    • ... and more; see makefile
  • A specific build type can be cleaned with make t=some_type clean
  • Tests can be run with ./BQN path/to/mlochbaum/BQN/test/this.bqn (add -noerr if using make heapverify).
  • Test precompiled expression: some-other-bqn-impl ./precompiled.bqn path/to/mlochbaum/BQN "$PATH" '2+2'
  • Some implementation docs

License

Any file without an explicit copyright message is copyright (c) 2021 dzaima, GNU GPLv3 - see LICENSE

About

a BQN implementation in C

License:GNU General Public License v3.0


Languages

Language:C 98.6%Language:Makefile 0.9%Language:Shell 0.4%