Commit Graph

918 Commits

Author SHA1 Message Date
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
Nathan Braswell
23d2c166cd Basic provide & with_import, fix a rep bug where all but first execution was in root_env instead of standard env 2020-09-19 12:41:52 -04:00
Nathan Braswell
e8899fc093 Better hermetic scoping 2020-09-19 00:04:09 -04:00
Nathan Braswell
1d97366933 Implement user-interatction part of k_prime in new_kraken.kp, moved from load_test.kp 2020-09-17 23:28:45 -04:00
Nathan Braswell
62e991d0dd Y combinator works, as well as vY (the vau version, which is different b/c applicative order), and prototype for new load style removing set works 2020-09-16 00:07:49 -04:00