aboutsummaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
4 daysWIP: rewrite C++ backend to be CHEADmasterKimplul
+ C allows for a bit more control, and we can manually handle closure contexts. For example `examples/fib.fwd` now works for effectively any `n`, pretty cool. + Fairly slow Fibonacci, I must admit. Initial profiling indicates it's mainly due to branch mispredictions, but I'll have to look into this a bit deeper. + The code is a bit hacked together, for now I'm more interested in getting things working, I'll worry about making things pretty later. + For testing, there's also initial support for modules, just so I can print stuff to the terminal + This commit is way too big, lol
11 daysstart sketching out type systemKimplul
13 daysuse maps in scopeKimplul
13 daysimprove printingKimplul
13 daysbump conts and remove c23 requirementKimplul
2025-03-18use generic contsKimplul
2025-03-18add move queuesKimplul
+ Returning blocks don't want to show moves for subsequent statements, but do want to show them for possible closure callers above.
2025-03-17fix some total movesKimplul
2025-03-17improve codegenKimplul
+ Probably kind of silly since I'll probably not use the C++ backend in the future but at least it's a bit easier to read what's going on + Total move checking doesn't seem to work in if statements, will have to fix at some point
2025-03-17detect leaksKimplul
2025-01-09initial ptr stuffKimplul
2025-01-09initial reference checkingKimplul
2025-01-06fix some analyzer warningsKimplul
2025-01-06implement move checking furthermvcheckKimplul
+ Enough that examples still compile, but missing references etc.
2025-01-04initial move checkingKimplul
+ Missing implementations for most things, but it already highlights an oversight in my initial plan, namely that currently, a function might call multiple of its closures, meaning that a closure wouldn't be allowed to move a value. I'm debating whether to check that only one closure from a parameter list is called at a time or if I should do what Hylo does and add in some kind of 'subscript' that's like a function but has slightly different rules?
2025-01-01run formatterKimplul
2024-12-28enough type checking for all examples to passKimplul
2024-12-20add enough type checking to compile uniq.fwdKimplul
2024-12-20fix generated files in .gitignoreKimplul
2024-12-11add note about closure callsKimplul
2024-12-08add some thought about error handlingKimplul
2024-12-07add a motivating caseKimplul
+ Hopefully it generalizes well, but at least it does use both lifetime and ownership intermixed
2024-12-06add trailing closuresKimplul
+ Useful for guard statements, not entirely sure about the final syntax but at least they're possible
2024-12-06formattingKimplul
2024-12-06show usage for examplesKimplul
2024-12-06fix some comments in the examplesKimplul
2024-12-06add types to parserKimplul
+ No actual type checking is implemented as of yet, but with references and pointers I should be able to start playing around with checking move semantics and so on + Might at some point also look into type propagation for let, annoying to have to specify the same thing twice.
2024-12-05add note about functions as expressionsKimplul
2024-12-05add extra requirement for returns that I forgotKimplul
2024-12-04remove mention that there's only a `uniq` exampleKimplul
2024-12-04implement expression handling furtherKimplul
+ Add some notes about returning functions that I started thinking about as a result of the fib example
2024-12-03initial commitKimplul
+ Lots of code copied from ek, so didn't have to start from scratch, but might mean there are some quirks here and there that made sense in ek but not necessarily here.