Commit graph

16 commits

Author SHA1 Message Date
YetAnotherMinion
b6182376b6
feat: add map2, map3, andThen to Astrid.Query 2025-11-23 19:34:16 -08:00
YetAnotherMinion
3cf23637d5
feat: add sqlite support to starmelon interpreter 2025-11-23 19:34:16 -08:00
YetAnotherMinion
e90a0b62a6
exp: structure project for higher level tools
Factor out the content code from the supporting editor. The next step is
to derive the visual CMS editor from the content codebase. In theory the
system will work like this:

A user would edit the view functions in src/Components/* with a Figma style
editor and write the changes back to the source Elm file.

A second tool will inspect the source directories looking for modules
that expose (route: astrid-pages/core/Astrid.Pages.Route). It will allow
a user to visually define and edit routing rules that decide which
module should handle each request. This tool compiles the routing rules
and source files into a standalone binary.

A third tool will generate a visual CMS that modifies the view functions
of each route to insert clickable targets on components. These targets
will open database record editor modals for the rows that generated that
specific HTML. This is achieved by engineer cooperation via annotations
rather than static analysis. This visual CMS can hot reload itself when
the view functions are changed by the first tool.

A fourth tool will generate an AirTable style database editor from the
type definitions found in src/Database/* modules.

The automated operation of these tools allows a non technical user to
edit the appearance and data of a website in cooperation with software
engineers define the data structures. The simple nature of Elm prevents
the engineers from being so creative the tools cannot understand what is
going on. And Elm checks the work of non technical contributors for any
conflicts with the engineers' design.
2025-11-23 19:34:16 -08:00
YetAnotherMinion
2e78b33524
feat: figured out starmelon needs expr types
To generate partial application boxed closures I need to know the arity
of the expression to tell if more args will remain after the given args.
Right now I think I can recalculate the types if I have a symbol table
where I can look up every variable. I think this will be a lot of work
because I have to reimplement most of unification to deal with
collections, patterns, and type variables. And I currently don't know
how unification works.
2025-11-23 19:34:16 -08:00
YetAnotherMinion
2f335b02ae
feat: transpile hello world view function 2025-11-23 19:34:16 -08:00
YetAnotherMinion
8354d51ecb
feat: prove elm object cache is complete 2025-11-23 19:34:16 -08:00
YetAnotherMinion
0a5e25e4f0
feat: use tracing crate to measure cpu time 2025-11-23 19:34:16 -08:00
YetAnotherMinion
80fe2c6d83
refactor: some modernization while computer was in shop 2025-11-23 19:34:16 -08:00
YetAnotherMinion
5d770d0d0a
refactor: share checksum rebuild logic
Move some of the caching logic (source file checksum) out of Starmelon
into a shared infra crate.

I have 4 similar tooling use cases for working with elm projects in
Rust.
1. Starmelon needs to create a modified copy of an existing elm
   application with extra dependencies and source directories. The
   extension elm application points to the source directories of the
   parent
2. Elm reactor needs to compile an elm module into javascript with
   caching.
3. SQL reactor needs to generate an elm application for each database,
   generate elm source code and compile that elm code with caching. It
   uses Starmelon to run derive macros written in Elm.
4. AstridLabs needs to create a heavily modified copy of an existing elm
   application with tons of generated code. It uses Starmelon to run
   derive macros written in Elm.

For 3 and 4 I could speed up the code generation step by using
part of starmelon as library. A proc-macro could include the Elm derive
macro javascript at crate build time and reuse the same v8 isolate over
and over for every web request.

My plan for 1,2,3,4 has a lot of shared functionality. I am thinking
that I should consolidate all the components into one library crate.
2025-11-23 19:34:16 -08:00
YetAnotherMinion
0576ae168a
refactor: use starmelon for derive macros
infra/homer/examples was the start of my work on macros for Elm. I have
greatly refined these ideas in starmelon. Delete the multi step build
process and replace it with a single call to starmelon.
2025-11-23 19:34:16 -08:00
YetAnotherMinion
afb53518a5
feat: livetable derive generates working code
Database identifiers are parsed and merged with table definition.
Add support machinery for multi-stage derive macros.
2025-11-23 19:34:16 -08:00
YetAnotherMinion
c845bf95a3
feat: pack starmelon with upx 2025-11-23 19:34:16 -08:00
YetAnotherMinion
ee7ce47f48
feat: starmelon reads files or stdin 2025-11-23 19:34:16 -08:00
YetAnotherMinion
287e59c566
refactor: replace unwraps with errors 2025-11-23 19:34:16 -08:00
YetAnotherMinion
601137dd16
feat: start to report errors instead of panicing 2025-11-23 19:34:16 -08:00
YetAnotherMinion
f7aff7585d
feat: unix adaptor for elm called starmelon
Introduce starmelon, a program for executing elm functions with input
from files and writing the output back to files.

Support evaluating 4 types of values and 12 types of functions.
```elm
x : String
x : Bytes
x : VirtualDom.Node msg
x : Json.Encode.Value

f : String -> String
f : String -> Bytes
f : String -> VirtualDom.Node msg
f : String -> Json.Encode.Value
f : Bytes -> String
f : Bytes -> Bytes
f : Bytes -> VirtualDom.Node msg
f : Bytes -> Json.Encode.Value
f : Json.Encode.Value -> String
f : Json.Encode.Value -> Bytes
f : Json.Encode.Value -> VirtualDom.Node msg
f : Json.Encode.Value -> Json.Encode.Value
```

My target use case for starmelon is generating html files. It is nice
to be able to write parameterized framgents of markup in multiple
modules and then compose them into a final value. I also have in mind
attempting to replace helm (kubernetes pacakge manager) because I hate
how error prone its string based templating language is.
2025-11-23 19:34:16 -08:00