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 |
|
Nathan Braswell
|
f254f11f8d
|
Generating first (in at least wasm3) runnable code! Added type, function, export, and code sections, with instructions and whatnot!
|
2021-04-20 01:36:38 -04:00 |
|
Nathan Braswell
|
e1fd8abd4f
|
Started working on basic wasm encoding/serialization. Added binary_file_writing, generalized arity comparison operators, bitwise operators, parsing of hex numbers, and wasm w/ memory section deserialization
|
2021-04-19 01:39:04 -04:00 |
|
Nathan Braswell
|
ed3b2ce743
|
Finished implementing real Damas-Hindley-Milner type system with let polymorphism!
|
2021-01-24 23:10:27 -05:00 |
|
Nathan Braswell
|
0a056ebef2
|
Limited monomorphic-only Damas-Hindley-Milner implemented in types
|
2021-01-24 02:53:55 -05:00 |
|
Nathan Braswell
|
f0d3be32f6
|
Add lambda to stlc
|
2021-01-18 19:06:28 -05:00 |
|
Nathan Braswell
|
7850866068
|
Start working on STLC again, this one's coming along. Primitives, builtins, and calls, but no lambda yet
|
2021-01-18 02:04:35 -05:00 |
|
Nathan Braswell
|
1f8fb59220
|
Fully functional now, removing set!, set-idx!, array-with-len, and making concat a builtin. Also, added 2 fun rules to new_kraken that allow nesting of new_kraken and k_prime languages
|
2021-01-17 19:57:56 -05:00 |
|
Nathan Braswell
|
7d7b2bd6d5
|
Add error/recover, rep->repl with error catching, and add it to scope so you can do it recursively and debug and whatnot. Also make it take in the grammer to repl with, and fix and commit the new_kraken work from earlier
|
2021-01-14 23:43:50 -05:00 |
|
Nathan Braswell
|
ddd5ce7032
|
Fix some longstanding string bugs and stop cheating with read-string in standard_grammer, implementing both unescape and string-to-int in k'
|
2021-01-04 00:11:15 -05:00 |
|
Nathan Braswell
|
6c0a46099a
|
New kraken with import and #lang passed start symbol
|
2021-01-02 13:55:07 -05:00 |
|
Nathan Braswell
|
4ed9af307f
|
Port method stuff over to new_kraken
|
2020-12-22 19:24:54 -05:00 |
|
Nathan Braswell
|
8d80f38f76
|
Fix a few parsing bugs at both levels, port some of the method demo over to new_kraken
|
2020-12-22 02:40:54 -05:00 |
|
Nathan Braswell
|
5152e1d109
|
Now actually have standard_grammar and with_import in scope let and all other ways in, having implemented let-vrec for mutually recursive vaus and fixing bugs. Tiny placeholder new_kraken definition and test.
|
2020-12-20 02:10:10 -05:00 |
|
Nathan Braswell
|
03b588f1f9
|
Insert standard_grammar into the standard scope via recursion, allowing it to be used in sub-languages
|
2020-12-19 23:05:46 -05:00 |
|
Nathan Braswell
|
85dbaae9de
|
Add vector, quote, and quasiquote syntax to new_kraken, and refactor types to use meta & new syntax
|
2020-10-20 22:59:21 -04:00 |
|
Nathan Braswell
|
371f39c82b
|
First impl of type-systems-as-vau-instead-of-macros in new-new-kraken
|
2020-10-20 22:11:57 -04:00 |
|
Nathan Braswell
|
168589c364
|
Finished generic concat, so let-rec properly works now
|
2020-10-18 20:18:38 -04:00 |
|
Nathan Braswell
|
f9529b02aa
|
Impl function let-rec with Y*
|
2020-10-18 19:11:23 -04:00 |
|
Nathan Braswell
|
d689a59097
|
Experimenting with fungll optimization, implement the okmij.org poly-variadic fix-point combinator for mutual recursion
|
2020-10-17 11:59:54 -04:00 |
|
Nathan Braswell
|
45ecb25bb1
|
Lang with proper scoping
|
2020-10-11 23:24:17 -04:00 |
|
Nathan Braswell
|
844bb0f189
|
Working language mod, though it doesn't have access to anything defined in the outer
|
2020-10-11 22:31:36 -04:00 |
|
Nathan Braswell
|
42c2fcfb66
|
Cheating in the same way, strings!
|
2020-10-11 20:01:18 -04:00 |
|
Nathan Braswell
|
0820113c67
|
Fix error swallowing grammer errors for custom grammers on read-string, start constructing standard_grammar
|
2020-10-11 19:42:00 -04:00 |
|
Nathan Braswell
|
e6319d18f7
|
Add all-k_prime grammar argument to read-string, enabling all-in-k_prime grammer changing
|
2020-09-20 13:52:56 -04:00 |
|