Commit Graph

  • 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? Nathan Braswell 2021-08-05 01:11:14 -04:00
  • 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. Nathan Braswell 2021-08-05 00:39:56 -04:00
  • c8c876e1bc Gonna checkpoint here - got basic fungll working, did a mod to allow strings as terminals, working on getting recursion working. Nathan Braswell 2021-08-05 00:07:44 -04:00
  • 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! Nathan Braswell 2021-08-04 00:56:04 -04:00
  • d38cd3e61e Put in title of paper / authors / url Nathan Braswell 2021-08-03 01:10:10 -04:00
  • 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 []. Nathan Braswell 2021-08-03 00:56:07 -04:00
  • dc712060cd generalize RB-Tree and make wrapper functions to use as a set or map Nathan Braswell 2021-08-02 20:34:01 -04:00
  • 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 Nathan Braswell 2021-08-01 23:48:41 -04:00
  • 93fd0d1943 Initial insert-only RB tree implementing a set Nathan Braswell 2021-08-01 22:15:58 -04:00
  • 537386d97b Extended foldl and foldr to be variadic, fixed foldr, and added pattern matching! Nathan Braswell 2021-08-01 20:21:14 -04:00
  • dfde35ee79 Add in basic element section Nathan Braswell 2021-08-01 00:23:41 -04:00
  • ee4a664660 Add global and table sections Nathan Braswell 2021-07-29 00:56:57 -04:00
  • 11684d9a35 Add start section Nathan Braswell 2021-07-27 22:21:03 -04:00
  • dbece88861 Added loop if/else br_if Nathan Braswell 2021-07-27 01:02:16 -04:00
  • 8eaf77876c Fixed up signed const encoding, can now execute my old wat test by copy pasting it into the kraken code! Nathan Braswell 2021-07-25 23:41:41 -04:00
  • 4e3e9a6147 Add memory, basic memory ins, data section Nathan Braswell 2021-07-25 22:20:25 -04:00
  • 6cacd32c00 Add import (only for functions for now) and call Nathan Braswell 2021-07-25 18:10:10 -04:00
  • 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 Nathan Braswell 2021-07-25 02:14:20 -04:00
  • ece3844c88 Quick commit adding br instruction Nathan Braswell 2021-07-24 00:39:45 -04:00
  • ca25f2ca2b Starting to add control instruction stuff, beginning with the block instruction. No nice labels or anything yet Nathan Braswell 2021-07-22 01:14:51 -04:00
  • f740dd07e2 Implement locals and foldl, which is the direction we should have been folding to not reverse the params/locals anyway Nathan Braswell 2021-07-20 23:36:03 -04:00
  • 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. Nathan Braswell 2021-07-20 00:37:27 -04:00
  • 835706c97d Add both bare WAT ins and nested WAT ins Nathan Braswell 2021-07-19 00:32:42 -04:00
  • 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 Nathan Braswell 2021-07-18 23:42:19 -04:00
  • d3dd37c60e Ooops, wasn't encoding numbers right at all, that's embarassing Nathan Braswell 2021-04-20 01:49:39 -04:00
  • f254f11f8d Generating first (in at least wasm3) runnable code! Added type, function, export, and code sections, with instructions and whatnot! Nathan Braswell 2021-04-20 01:36:38 -04:00
  • 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 Nathan Braswell 2021-04-19 01:39:04 -04:00
  • ed3b2ce743 Finished implementing real Damas-Hindley-Milner type system with let polymorphism! Nathan Braswell 2021-01-24 23:10:27 -05:00
  • 0a056ebef2 Limited monomorphic-only Damas-Hindley-Milner implemented in types Nathan Braswell 2021-01-24 02:53:55 -05:00
  • f0d3be32f6 Add lambda to stlc Nathan Braswell 2021-01-18 19:06:28 -05:00
  • 7850866068 Start working on STLC again, this one's coming along. Primitives, builtins, and calls, but no lambda yet Nathan Braswell 2021-01-18 02:04:35 -05:00
  • 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 Nathan Braswell 2021-01-17 19:57:33 -05:00
  • 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 Nathan Braswell 2021-01-14 23:43:50 -05:00
  • ddd5ce7032 Fix some longstanding string bugs and stop cheating with read-string in standard_grammer, implementing both unescape and string-to-int in k' Nathan Braswell 2021-01-04 00:11:15 -05:00
  • 6c0a46099a New kraken with import and #lang passed start symbol Nathan Braswell 2021-01-02 13:55:07 -05:00
  • 4ed9af307f Port method stuff over to new_kraken Nathan Braswell 2020-12-22 19:24:54 -05:00
  • 8d80f38f76 Fix a few parsing bugs at both levels, port some of the method demo over to new_kraken Nathan Braswell 2020-12-22 02:40:54 -05:00
  • 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. Nathan Braswell 2020-12-20 02:10:10 -05:00
  • 03b588f1f9 Insert standard_grammar into the standard scope via recursion, allowing it to be used in sub-languages Nathan Braswell 2020-12-19 23:05:46 -05:00
  • 85dbaae9de Add vector, quote, and quasiquote syntax to new_kraken, and refactor types to use meta & new syntax Nathan Braswell 2020-10-20 22:59:21 -04:00
  • 371f39c82b First impl of type-systems-as-vau-instead-of-macros in new-new-kraken Nathan Braswell 2020-10-20 22:11:57 -04:00
  • 168589c364 Finished generic concat, so let-rec properly works now Nathan Braswell 2020-10-18 20:18:38 -04:00
  • f9529b02aa Impl function let-rec with Y* Nathan Braswell 2020-10-18 19:11:23 -04:00
  • d689a59097 Experimenting with fungll optimization, implement the okmij.org poly-variadic fix-point combinator for mutual recursion Nathan Braswell 2020-10-17 11:59:54 -04:00
  • 45ecb25bb1 Lang with proper scoping Nathan Braswell 2020-10-11 23:24:17 -04:00
  • 844bb0f189 Working language mod, though it doesn't have access to anything defined in the outer Nathan Braswell 2020-10-11 22:31:36 -04:00
  • 42c2fcfb66 Cheating in the same way, strings! Nathan Braswell 2020-10-11 20:01:18 -04:00
  • 0820113c67 Fix error swallowing grammer errors for custom grammers on read-string, start constructing standard_grammar Nathan Braswell 2020-10-11 19:42:00 -04:00
  • e6319d18f7 Add all-k_prime grammar argument to read-string, enabling all-in-k_prime grammer changing Nathan Braswell 2020-09-20 13:52:56 -04:00
  • 23d2c166cd Basic provide & with_import, fix a rep bug where all but first execution was in root_env instead of standard env Nathan Braswell 2020-09-19 12:41:52 -04:00
  • e8899fc093 Better hermetic scoping Nathan Braswell 2020-09-19 00:04:09 -04:00
  • 1d97366933 Implement user-interatction part of k_prime in new_kraken.kp, moved from load_test.kp Nathan Braswell 2020-09-17 23:28:45 -04:00
  • 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 Nathan Braswell 2020-09-16 00:07:49 -04:00
  • 23910ba51e Update web version, add a sharable try.html Nathan Braswell 2020-09-13 19:03:44 -04:00
  • aa75269608 Working string interpolation! Nathan Braswell 2020-09-13 18:25:30 -04:00
  • 59c6bceb4d work in progress string interpolation Nathan Braswell 2020-09-13 18:05:54 -04:00
  • 33d28fe1fa Added {} bodies, C style function call, and Kraken-style fun Nathan Braswell 2020-09-12 21:34:23 -04:00
  • 54cffb4185 massage new constructor to be a function and add methods to both it and the new syntax Nathan Braswell 2020-09-08 23:30:56 -04:00
  • ba64276630 Begin object/struct syntax & semantics Nathan Braswell 2020-09-08 00:25:41 -04:00
  • 3cb5c8d827 Add TCO option to BuiltinCombinator and convert cond and eval to use this, then rewrite self-hosted do so that it too is TCO. This allows us to self-host cond (which we did) so without worring about stack space for large arrays Nathan Braswell 2020-09-07 15:41:27 -04:00
  • c0eca02e43 Update website Nathan Braswell 2020-09-06 22:10:59 -04:00
  • 0d07d22995 Move to wrap and unwrap Nathan Braswell 2020-09-06 12:19:19 -04:00
  • 8e47cb2ec2 Move to prelude and add enough to run bf (with modifications) Nathan Braswell 2020-08-29 00:33:04 -04:00
  • 241b4ca3f4 Implemented quasiquoting as a vau! Nathan Braswell 2020-08-28 00:38:16 -04:00
  • a5f15f70f8 Fixed the eval issue for builtins mentioned last time, and undid lambda fix. Fixed it by unevaling in appropriate spots by wrapping in a call to quote, or equilivant. Map at least should be rewritten a language feature, for sure. Nathan Braswell 2020-08-20 22:57:01 -04:00
  • 94a24cb30f Somehow forgot to commit rc all this time Nathan Braswell 2020-08-20 18:37:43 -04:00
  • d69e77ee33 Added vector syntatic sugar [], set-idx!, and neatend up some of the self-implementation with the ' and [] syntatic sugar. Realized that currently most builtins pass arguments evaluated such that functions that they are passed really have to be vau instead of lambda. This includes both add_grammer_rule and more common ones like map, etc. I think I might have to undo my lambda fix in recognition of this. Anyway, either I have to pass arguments unevaluated or I need to swap to wrap/unwrap instead of my current lambda impl. It would be more like Kernel, and might make optimization etc easier, but I'm a tad worried about unwrap being exposed to the user / not forcing the more general optimization based on partial evaluation on myself (maybe doing this even makes optimization harder or less elegant?) Nathan Braswell 2020-08-14 22:37:03 -04:00
  • 8ea030547a Finally commit earlier work now that I've fixed the bug where you couldn't use new syntax inside of functions because the inner closure struct was being corrupted and giving a null env. Now I use a nil env Nathan Braswell 2020-08-14 00:37:55 -04:00
  • b292180a86 File loading and gradual evaluation Nathan Braswell 2020-07-21 23:30:08 -04:00
  • 9caf220aa1 Added print / string stuff, meta and with-meta, and the old add_grammer_rule Nathan Braswell 2020-07-21 22:56:29 -04:00
  • 45af192cee Added in basic math, comparison, and boolean operations Nathan Braswell 2020-07-17 00:00:22 -04:00
  • 41c02d43ff implement cond vector len idx concat - =, all as builtins, as an excercise implemented quote let1 apply rest map lambda fun, all in k_prime itself, proving you don't absolutly need wrap or apply as builtins (eval and vector manipulation functions suffice) Nathan Braswell 2020-07-13 00:48:01 -04:00
  • 38bf5edc35 implement set! Nathan Braswell 2020-06-30 21:59:11 -04:00
  • a5f1355b63 Added eval, which I think completes the key vau parts - will have to see if I can construct lambda soon Nathan Braswell 2020-06-30 21:17:02 -04:00
  • 9f4dd92834 Add vau Nathan Braswell 2020-06-28 23:28:15 -04:00
  • 0a1cf4fb4d Swap core vau/kernel style interpreter Nathan Braswell 2020-06-28 19:17:09 -04:00
  • 2efd3b5474 More object syntax Nathan Braswell 2020-05-13 20:58:20 -04:00
  • 722a72579a Spelling Nathan Braswell 2020-05-12 21:30:37 -04:00
  • bf53d3701f spelling Nathan Braswell 2020-05-12 16:45:52 -04:00
  • 622aee0c75 Add fib example to web page Nathan Braswell 2020-05-12 16:36:07 -04:00
  • c799cf485b Massive updates to the website Nathan Braswell 2020-05-12 16:22:41 -04:00
  • dac3e41101 Pass inputs to grammer callbacks as individual parameters Nathan Braswell 2020-05-12 09:33:33 -04:00
  • 8e296d57c8 Add atom syntax Nathan Braswell 2020-05-12 09:19:01 -04:00
  • 45ea718bc8 Add in atoms as length-1 vectors to bf.kp, next need to add in reader macros for them. Also the params from earlier Nathan Braswell 2020-05-12 00:40:36 -04:00
  • 29230404a3 Remove just a tad more of bf Nathan Braswell 2020-05-12 00:33:29 -04:00
  • 25801b3d3a Add + and * to add_grammer_rule. Realized that rules should actually be passed to functions as params, with option for variadac, that will be up next Nathan Braswell 2020-05-12 00:32:12 -04:00
  • 77ce4095c0 Fix compiling varadic params, demo method syntax Nathan Braswell 2020-05-11 23:20:54 -04:00
  • a7c0c3d78c Lisp object system prototyped! Added necessary C functions and variadic support Nathan Braswell 2020-05-11 01:08:13 -04:00
  • 9aeadfc224 Add names to BuiltinFunctions so they can be compiled when used by reference, much less hacky and allows our new BF version to be compiled Nathan Braswell 2020-05-10 21:33:47 -04:00
  • f10630c66c First working object tests! Nathan Braswell 2020-05-10 19:29:28 -04:00
  • 3f501a5c2f Added correct compiling of top level vector values, including with meta Nathan Braswell 2020-05-10 00:50:46 -04:00
  • 4cd7b22c86 Added set-meta! to interp and compile Nathan Braswell 2020-05-10 00:17:30 -04:00
  • 9ce70badab added reference counted vectors in interp Nathan Braswell 2020-05-09 23:59:46 -04:00
  • 991a353805 Add compiling with-meta/meta for vectors only to C Nathan Braswell 2020-05-09 13:30:38 -04:00
  • 5d473d698d Somewhat in the middle - removed list, added meta for interpreter, not yet implemented in compiler Nathan Braswell 2020-05-09 11:52:32 -04:00
  • c5153c2977 add explanations of idea, links to paper, current status, and a tiny amount of CSS from https://bestmotherfucking.website/ Nathan Braswell 2020-05-03 00:48:51 -04:00
  • e6e053eaff create rudimentary try-kraken-online Nathan Braswell 2020-05-03 00:10:09 -04:00
  • c61b9d3c22 fixed closeing with strings Nathan Braswell 2020-04-25 13:05:56 -04:00
  • e74c883132 throw and catch implemented Nathan Braswell 2020-04-23 13:04:27 -04:00
  • ae150b17fa Added atoms! atom, deref, swap!, literal support Nathan Braswell 2020-04-23 00:15:39 -04:00