Nathan Braswell
|
64c793d9f4
|
Flesh out the closes over test. Still doesnt' partial eval like we want, need to investigate why - have idea for specalizing function but do have to be careful with actual_function
|
2021-09-14 02:01:31 -04:00 |
|
Nathan Braswell
|
ec9083a958
|
Fixed bug with y, but still not partially evaluating the lets with later :/
|
2021-09-12 01:37:07 -04:00 |
|
Nathan Braswell
|
f89b21420a
|
Ok, figured out why let5 is failing and wrote down a plan of attack
|
2021-09-07 00:06:19 -04:00 |
|
Nathan Braswell
|
12271ff27c
|
Bug fixed and back to state before refactor/rewrite. Need to get that darn let5 working now! That's why we did this
|
2021-09-06 23:00:04 -04:00 |
|
Nathan Braswell
|
873e7c4244
|
Working through the bugs, got the first few working
|
2021-09-06 12:29:05 -04:00 |
|
Nathan Braswell
|
6a47375d28
|
Ok, refactored the whole thing! It's now always operating on marked values with a mark step at the beginning, which should solve our stripping problems. It parses, but crashes, but it's 3am, so I'm saving and going to bed
|
2021-09-06 03:00:33 -04:00 |
|
Nathan Braswell
|
49d5a196aa
|
2 steps forward, 1 step back - I have arrays (and I think varargs) working, but let5_test is now not partial evaling as far as it should because of my fix. Detailed explanation in the comments, but it looks like we are going to have to insert that eval_strip hack, or somesuch
|
2021-09-05 00:25:33 -04:00 |
|
Nathan Braswell
|
b44ff104fb
|
Implement variadic paremters, found additional bug for array, still need to handle recursion too
|
2021-08-26 01:03:36 -04:00 |
|
Nathan Braswell
|
26e9c5a41f
|
Fix a bug in eval strip not actually stripping in the proper eval way - f there's a later anywhere in there, it has to desist, which is now implemented. Added do tests - we have to add support for & params, which I had forgotten, and I belive it now loops infinately because it tries to partially evaluate a recursive function!
|
2021-08-25 01:32:24 -04:00 |
|
Nathan Braswell
|
649e0107d4
|
And lambda is working nicely too, once I added support for val to the function call evaluaator (just looking it up in comb_to_mark_map)
|
2021-08-24 00:33:29 -04:00 |
|
Nathan Braswell
|
634812cea4
|
Got it working!
|
2021-08-23 23:43:47 -04:00 |
|
Nathan Braswell
|
2cd85a552d
|
Some more tests and cleanup, looks like we're going to have to do either a try-eval thing or CPS-style partial evaluator, which I'm reading up on
|
2021-08-22 20:27:48 -04:00 |
|
Nathan Braswell
|
7700f0b709
|
FIXED THE BUG!
|
2021-08-22 13:03:33 -04:00 |
|
Nathan Braswell
|
c9e2e4659b
|
Completely untested, but added partial eval for all array methods and and/or - this is pretty much everything! We don't bother with meta or error/recover right now though
|
2021-08-17 23:09:42 -04:00 |
|
Nathan Braswell
|
04f1c76bd7
|
Factored out parameter eval for some combinators and then added combiner? and env?
|
2021-08-17 20:31:07 -04:00 |
|
Nathan Braswell
|
47d5149400
|
Implement smart cond partial-eval
|
2021-08-17 18:17:42 -04:00 |
|
Nathan Braswell
|
772b984de0
|
Ok, more bugfixes & comments, and got eval working!
|
2021-08-17 01:19:38 -04:00 |
|
Nathan Braswell
|
e8747ef899
|
Bugfix and improvment, eval one works even though eval isn't implemented yet!
|
2021-08-16 11:54:05 -04:00 |
|
Nathan Braswell
|
62a238e041
|
Added wrap/unwrap and a vau test that uses wrap!
|
2021-08-16 01:20:10 -04:00 |
|
Nathan Braswell
|
550565a235
|
More vau usage working
|
2021-08-16 00:37:56 -04:00 |
|
Nathan Braswell
|
05092cba76
|
First vau-involved partial evals working!
|
2021-08-15 01:27:53 -04:00 |
|
Nathan Braswell
|
b3c02c82b3
|
Create and pass through comb_to_mark_map to allow us to re-mark stripped expressions so we can evaluate them mutliple times, etc, etc
|
2021-08-11 23:30:49 -04:00 |
|
Nathan Braswell
|
f09962ddc4
|
Add 2 parameter vau that discards dynamic env
|
2021-08-10 23:26:22 -04:00 |
|
Nathan Braswell
|
95b37da44e
|
Ok, I think this is a correct? skeleton, implemented as much as I did yesterday
|
2021-08-10 22:56:12 -04:00 |
|
Nathan Braswell
|
e1fa65deaf
|
Starting work on a partial evaluator - just sketching for now, needs a bunch of work and likely some foundational changes
|
2021-08-10 00:23:14 -04:00 |
|
Nathan Braswell
|
d2215c2831
|
Fix some of the massive speed drop from destructuring lambda by checking to see if it actually needs to destrucure first. Still slower than it was, but not 10x anymore. Maybe 1.5-2x?
|
2021-08-05 01:11:14 -04:00 |
|
Nathan Braswell
|
ae82af6636
|
Bugfix & added an extra lambda wrapping around term/nterm so that their value can be made recursive with let-rec, and with that the parser works! On the other hand, it takes 38 seconds to parse 'a,a,a' with the grammer A='a'|'a' ',' A .... so that could be a lot better.
|
2021-08-05 00:39:56 -04:00 |
|
Nathan Braswell
|
c8c876e1bc
|
Gonna checkpoint here - got basic fungll working, did a mod to allow strings as terminals, working on getting recursion working.
|
2021-08-05 00:07:44 -04:00 |
|
Nathan Braswell
|
5a61d5f90c
|
Added destructuring lambda/rec-lambda, changed let to use the same [] array destructuring syntax, added basic multiset & set-foldl. Fixed a bunch of bugs in fungll, hopefully close to working, but just realized that < is only defined for ints, while it's how the RB-Tree set/map sort their values/keys, so I'll need to extend it like = for all types. Tomorrow!
|
2021-08-04 00:56:04 -04:00 |
|
Nathan Braswell
|
d38cd3e61e
|
Put in title of paper / authors / url
|
2021-08-03 01:10:10 -04:00 |
|
Nathan Braswell
|
c96f20c80e
|
Add lcompose to prelude, size to rb, and sketch out fungll. Still haven't figured out the exact datatype for grammer_slots and have decided to implement [] destrucuring in lambda params, and change let destructuring to use [].
|
2021-08-03 00:56:07 -04:00 |
|
Nathan Braswell
|
dc712060cd
|
generalize RB-Tree and make wrapper functions to use as a set or map
|
2021-08-02 20:34:01 -04:00 |
|
Nathan Braswell
|
e0802baf5e
|
Extend match to support ~unquote for matching against the *value* of expressions or variables, and use that to implement deletion for the RB-tree set
|
2021-08-01 23:48:41 -04:00 |
|
Nathan Braswell
|
93fd0d1943
|
Initial insert-only RB tree implementing a set
|
2021-08-01 22:15:58 -04:00 |
|
Nathan Braswell
|
537386d97b
|
Extended foldl and foldr to be variadic, fixed foldr, and added pattern matching!
|
2021-08-01 20:21:14 -04:00 |
|
Nathan Braswell
|
dfde35ee79
|
Add in basic element section
|
2021-08-01 00:23:41 -04:00 |
|
Nathan Braswell
|
ee4a664660
|
Add global and table sections
|
2021-07-29 00:56:57 -04:00 |
|
Nathan Braswell
|
11684d9a35
|
Add start section
|
2021-07-27 22:21:03 -04:00 |
|
Nathan Braswell
|
dbece88861
|
Added loop if/else br_if
|
2021-07-27 01:02:16 -04:00 |
|
Nathan Braswell
|
8eaf77876c
|
Fixed up signed const encoding, can now execute my old wat test by copy pasting it into the kraken code!
|
2021-07-25 23:41:41 -04:00 |
|
Nathan Braswell
|
4e3e9a6147
|
Add memory, basic memory ins, data section
|
2021-07-25 22:20:25 -04:00 |
|
Nathan Braswell
|
6cacd32c00
|
Add import (only for functions for now) and call
|
2021-07-25 18:10:10 -04:00 |
|
Nathan Braswell
|
3ad51ce19d
|
Implement the env shuffling to enable blocks with labels and breaking to them (via 'hidden' depth constant added to each block env, from which the block depth is subtracted in the br vau
|
2021-07-25 02:14:20 -04:00 |
|
Nathan Braswell
|
ece3844c88
|
Quick commit adding br instruction
|
2021-07-24 00:39:45 -04:00 |
|
Nathan Braswell
|
ca25f2ca2b
|
Starting to add control instruction stuff, beginning with the block instruction. No nice labels or anything yet
|
2021-07-22 01:14:51 -04:00 |
|
Nathan Braswell
|
f740dd07e2
|
Implement locals and foldl, which is the direction we should have been folding to not reverse the params/locals anyway
|
2021-07-20 23:36:03 -04:00 |
|
Nathan Braswell
|
e271feed24
|
Implemented $ references for functions and parameters, which are also parsed for real now, along with the result. Setup for locals added, but not it's backend. Added pretty interesting add-dict-to-env function to collections.kp, which has also been added to put collections stuff in one place.
|
2021-07-20 00:37:27 -04:00 |
|
Nathan Braswell
|
835706c97d
|
Add both bare WAT ins and nested WAT ins
|
2021-07-19 00:32:42 -04:00 |
|
Nathan Braswell
|
d6d7af0bc1
|
Super basic and a tiny bit hardcoded WAT-like syntax for generating the array of arrays of arrays of arrays wasm implementation in wasm.kp, allowing us to write psudo-WAT in kraken and output binary wasm with 1 function call
|
2021-07-18 23:42:19 -04:00 |
|
Nathan Braswell
|
d3dd37c60e
|
Ooops, wasn't encoding numbers right at all, that's embarassing
|
2021-04-20 01:49:39 -04:00 |
|