Vacietis VS sectorlisp

Compare Vacietis vs sectorlisp and see what are their differences.

sectorlisp

Bootstrapping LISP in a Boot Sector (by jart)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
Vacietis sectorlisp
7 25
294 1,173
- -
0.0 4.3
almost 2 years ago 5 months ago
Common Lisp C
GNU General Public License v3.0 or later ISC License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

Vacietis

Posts with mentions or reviews of Vacietis. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-04-11.
  • List of (open source) C compilers
    3 projects | news.ycombinator.com | 11 Apr 2023
  • Rust's Poor Composability
    9 projects | news.ycombinator.com | 6 Apr 2023
    Yes. Not because of the developer, but because of how extremely flexible and dynamic the Lisp-family languages are. The power and joy of Lisp is in how it's almost a meta-language, so every project can become its own EDSL. The most famous (infamous?) example of this is Vacietis[2], which is a Common Lisp library that allows C code to be imported directly(!!).

    [0] IIRC the Yesod framework's Warp does well on benchmarks, and when you look at code like https://github.com/yesodweb/wai/blob/master/warp/Network/Wai... you can see the lengths they had to go through to work around the choice of implementation language.

    [1] Go has a garbage collector, but exposes the stack/heap distinction more directly than Haskell, so it's easier to write allocation-free code in hot paths.

    [2] https://github.com/vsedach/Vacietis

  • Any attempts at a "distro"/"package manager" for building a programming language?
    2 projects | /r/ProgrammingLanguages | 12 Apr 2022
    racket and common lisp both offer reader interfaces which allow parsing non-s-expression languages. see https://github.com/vsedach/Vacietis , a c compiler implemented in common lisp which uses the common lisp reader.
  • C to php converter online
    1 project | /r/programming | 21 Mar 2022
    Very funny. One might be interested in e.g. Vacietis which does manage to compile enough of C correctly to a higher level language (in this case, Common Lisp) to be interesting.
  • CLOG Needs You :)
    2 projects | /r/lisp | 24 Feb 2022
    https://github.com/vsedach/Vacietis - C in CL
  • Compiler in Lisp
    8 projects | /r/lisp | 26 Jan 2021
    C
  • Wisp: A light Lisp written in C++
    10 projects | news.ycombinator.com | 28 Dec 2020
    How about C?

    https://news.ycombinator.com/item?id=25531871

    https://github.com/vsedach/Vacietis

    ================

    Vacietis is a C compiler for Common Lisp systems.

    Vacietis works by loading C code into a Common Lisp runtime as though

sectorlisp

Posts with mentions or reviews of sectorlisp. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-02-26.
  • are there any benchmarks on sector lisp
    2 projects | /r/lisp | 26 Feb 2023
    I'm assuming you are referring to https://github.com/jart/sectorlisp which I gather is an attempt to make a Lisp that fits in a disk boot sector?
  • Sectorlisp
    1 project | /r/hypeurls | 13 Jan 2023
    1 project | news.ycombinator.com | 13 Jan 2023
  • Kilo Lisp: A Kilo Byte-Sized Lisp System
    11 projects | news.ycombinator.com | 16 Dec 2022
  • For the LISP 1.5 mainframe fans here...
    4 projects | /r/mainframe | 15 Dec 2022
  • Ask HN: Best book to learn C in 2022?
    8 projects | news.ycombinator.com | 8 Oct 2022
  • Take More Screenshots
    24 projects | news.ycombinator.com | 24 Jul 2022
    I think SIMD was a distraction to our conversation, most code doesn't use it and in the future the length agnostic, flexible vectors; https://github.com/WebAssembly/flexible-vectors/blob/master/... are a better solution. They are a lot like RVV; https://github.com/riscv/riscv-v-spec, research around vector processing is why RISC-V exists in the first place!

    I was trying to find the smallest Rust Wasm interpreters I could find, I should have read the source first, I only really use wasmtime, but this one looks very interesting, zero deps, zero unsafe.

    16.5kloc of Rust https://github.com/rhysd/wain

    The most complete wasm env for small devices is wasm3

    20kloc of C https://github.com/wasm3/wasm3

    I get what you are saying as to be so small that there isn't a place of bugs to hide.

    > “There are two ways of constructing a software design: One way is to make it so simple that there are obviously no deficiencies, and the other way is to make it so complicated that there are no obvious deficiencies. The first method is far more difficult.” CAR Hoare

    Even a 100 line program can't be guaranteed to be free of bugs. These programs need embedded tests to ensure that the layer below them is functioning as intended. They cannot and should not run open loop. Speaking of 300+ reimplementations, I am sure that RISC-V has already exceeded that. The smallest readable implementation is like 200 lines of code; https://github.com/BrunoLevy/learn-fpga/blob/master/FemtoRV/...

    I don't think Wasm suffers from the base extension issue you bring up. It will get larger, but 1.0 has the right algebraic properties to be useful forever. Wasm does require an environment, for archival purposes that environment should be written in Wasm, with api for instantiating more envs passed into the first env. There are two solutions to the Wasm generating and calling Wasm problem. First would be a trampoline, where one returns Wasm from the first Wasm program which is then re-instantiated by the outer env. The other would be to pass in the api to create new Wasm envs over existing memory buffers.

    See, https://copy.sh/v86/

    MS-DOS, NES or C64 are useful for archival purposes because they are dead, frozen in time along with a large corpus of software. But there is a ton of complexity in implementing those systems with enough fidelity to run software.

    Lua, Typed Assembly; https://en.wikipedia.org/wiki/Typed_assembly_language and Sector Lisp; https://github.com/jart/sectorlisp seem to have the right minimalism and compactness for archival purposes. Maybe it is sectorlisp+rv32+wasm.

    If there are directions you would like Wasm to go, I really recommend attending the Wasm CG meetings.

    https://github.com/WebAssembly/meetings

    When it comes to an archival system, I'd like it to be able to run anything from an era, not just specially crafted binaries. I think Wasm meets that goal.

    https://gist.github.com/dabeaz/7d8838b54dba5006c58a40fc28da9...

  • *Laughs in autocmd*
    4 projects | /r/neovim | 30 Jun 2022
    Based on this, the next thing you wrote, and your reference to running a minimal Gentoo: I think you might be a Scheme fan in the making. Scheme is the minimal Lisp. (Okay, that might be sectorlisp which fits in 512 bytes.) It’s hands down my favorite language. While it’s evolved on its own to be more of a superset of Scheme, Racket is my Scheme of choice.
  • Bootstrapping Lisp in a Boot Sector
    1 project | news.ycombinator.com | 25 Jun 2022
  • That's pretty much it!
    7 projects | /r/ProgrammerHumor | 26 Feb 2022
    sectorlisp

What are some alternatives?

When comparing Vacietis and sectorlisp you can also consider the following projects:

foth - Tutorial-style FORTH implementation written in golang

sectorforth - sectorforth is a 16-bit x86 Forth that fits in a 512-byte boot sector.

yale-haskell - HASKELL: Yale Haskell system written in Lisp

small-lisp - A very small lisp interpreter, that I may one day get working on my 8-bit AVR microcontroller.

quilc - The optimizing Quil compiler.

Carp - A statically typed lisp, without a GC, for real-time applications.

clog - CLOG - The Common Lisp Omnificent GUI

mal - mal - Make a Lisp

wisp - A lisp👽 written in C++

femtolisp - a lightweight, robust, scheme-like lisp implementation

sb-jonesforth - 64-bit jonesforth using the SBCL assembler

kernel-zig - :floppy_disk: hobby x86 kernel zig