fructure VS vernacular

Compare fructure vs vernacular and see what are their differences.

fructure

a structured interaction engine 🗜️ ⚗️ (by disconcision)

vernacular

Module system for languages that compile to Common Lisp (by ruricolist)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
fructure vernacular
8 2
442 58
- -
3.7 3.6
3 months ago 5 months ago
Racket Common Lisp
Apache License 2.0 MIT 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.

fructure

Posts with mentions or reviews of fructure. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-29.
  • Racket: The Lisp for the Modern Day
    6 projects | news.ycombinator.com | 29 Jun 2023
    Even the racket teachpack libraries designed for education are very capable; I was able to make this structured editor with only using teachpack content without external deps: https://github.com/disconcision/fructure
  • Common Lisp vs Racket
    14 projects | news.ycombinator.com | 5 Sep 2022
    Right, it's fine, and is a pretty basic macro. Doubly linked lists are pretty basic data structures too, even the Rust versions once you figure it out. I like your sibling comment making it look like the CL version. I still want to know in more detail though why you think that doing things this way instead of the CL way is less likely to be "fragile and break down" for the complicated stuff, it would help to have a specific complicated example to showcase. Perhaps the linked https://github.com/disconcision/fructure in another comment would be a good study? The author there claimed they might not have been able to manage with defmacro, maybe someone familiar with both could articulate the challenges in detail. Is it just an issue of some things benefit a lot from pattern matching, and if so, does using CL's Trivia system mitigate that at all (in the same way that using gensym+packages+Lisp-2ness can mitigate hygiene issues)?
  • Fructure: A structured interaction engine in Racket
    2 projects | news.ycombinator.com | 12 May 2022
  • graph-based UI for Lisp/Scheme
    2 projects | /r/lisp | 12 Apr 2022
    see also: fructure
  • Why text only.
    2 projects | /r/ProgrammingLanguages | 29 Nov 2021
  • An Intuition for Lisp Syntax
    4 projects | news.ycombinator.com | 27 May 2021

vernacular

Posts with mentions or reviews of vernacular. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-10-10.
  • Common Lisp: An Interactive Approach (1992) [pdf]
    7 projects | news.ycombinator.com | 10 Oct 2023
    there is also https://github.com/lisp-maintainers/defstar for providing more ergonomic type declarations inline in definitions

    And this is another thing I'm not sure how to explain, I thought CL is surely more verbose and ugly than python for small scripts, but maybe it's macros will make it cleaner for building large systems. But then when I started writing actual programs, even small programs without any of my own macros, I generally use about 30% less LoC than in python... I've thought about making sly/slime like support for python (built on ipython with autoreload extension) or ruby (with it's fairly new low-overhead debug gem). But at the end of the day support for these things will always be incomplete and a hack compared to CL where it was designed from the start to support it, they run 20-100x slower than CL, and imo their runtime metaprogramming is harder to reason about than CL which is mostly compile time metaprogramming. When I've had to dig into some CL library, which is a lot more often than in those languages because it has 10000x fewer users so of course I will be first to run into some issue, it has generally been easy to understand what is going on and fix it, compared to large codebases in other languages.

    Regarding "modern type-safe language", languages with expressive type systems, rust, ocaml, haskell, typescript, etc, can give really confusing type errors, when you get into generics and traits and more expressive stuff. I'm not convinced it's a better development experience than a dynamically typed languages where values have simple types, and when you get a type error you see the actual contents of the variable that is the wrong type and state of the program, at least in the case of CL where the stack isn't unwound on error and runtime is kind of compile-time as you're running all code as you write it. But mostly this sort of interactive development is very hard to implement in static languages, I'm not aware of any that does it. For example even in static langs like ocaml that have a repl through a bytecode interpreter, simple things don't work like say you pass some function as an event handler, and then update the function. As you passed efectively a function pointer to the old definition, rather than a symbol name like lisp, it will be calling the original function not the new version. But the main issue is that efficient staticly typed languages the type system is all at compile time, type information doesn't exist at runtime, which is great for performance, but means you don't get the ability to introspect on your running program like you do in CL and elixir, which personally I value more than full compile-time type checking.

    Would I like some new language or heavy modification of existing language runtime that provides the best of everything? of course, but I also realize that it's a huge amount of work and won't happen with 10 years, while I can have a nice experience hacking away in CL and emacs right now. And ultimately CL is an extremely flexible language and I think it'll be less work to build on CL than to provide a CL like runtime for some other language. For example projects really pushing the edge there is Coalton described above. While personally I prefer dynamicly typed for general application programming I think Coalton could be great for compilers, parsing some protocol, or writing some subparts of your program in. And vernacular (https://github.com/ruricolist/vernacular) which explores bringing racket's lang and macro system to CL. For more standard CL code, using extremely common and widely used libraries like alexandria, serapeum, trivia, etc, already makes CL into a fairly modern and ergonomic language to write.

  • Common Lisp vs Racket
    14 projects | news.ycombinator.com | 5 Sep 2022
    I have a project to do that, https://github.com/ruricolist/vernacular, although I'm not working on it right now.

What are some alternatives?

When comparing fructure and vernacular you can also consider the following projects:

LIBUCL - Universal configuration library parser

lparallel - Parallelism for Common Lisp

slimv - Official mirror of Slimv versions released on vim.org

with-c-syntax - C language syntax in Common Lisp

vlime - A Common Lisp dev environment for Vim (and Neovim)

ltk

cmu-infix - Updated infix.cl of the CMU AI repository, originally written by Mark Kantrowitz

awesome-cl - A curated list of awesome Common Lisp frameworks, libraries and other shiny stuff.

coherence - Oracle Coherence Community Edition

defstar - Type declarations for defun et all. Just a mirror. Ask for push acess!

slime - The Superior Lisp Interaction Mode for Emacs

racket-binfmt - A binary format parser generator DSL with support for limited context-sensitivity.