Commit Graph

413 Commits

Author SHA1 Message Date
Nathan Braswell
a9bb011bd9 Starting to make k_prime lisp grammer, doing testing to get all MAL test cases parsing 2020-03-28 00:23:01 -04:00
Nathan Braswell
2bc9ce497b FINALLY FIXED THE PROBLEM - was using set instead of set_single, so it set it's child as well, causing the type loop. Also, the binding replace child evaluated the parameters first, changing t's parent before t->parent->replace_child happened 2019-07-13 18:01:04 -04:00
Nathan Braswell
148d70e2d4 Man, I was just missing initting to null and it would have run 2019-01-06 22:04:56 -05:00
Nathan Braswell
c2495a04f8 binding epochs compile, but segfault. too late tonight to keep going 2019-01-06 01:06:15 -05:00
Nathan Braswell
06df819e72 Port (though ineffecently) defer_lower! 2018-12-29 20:58:34 -05:00
Nathan Braswell
ed57d2b2a9 Added sizeof and fixed inferencing from explicitly instantiated template functions so that new and delete work! (though not traits yet...) 2018-12-29 16:35:47 -05:00
Nathan Braswell
235775c077 Basic veriadic, ext, and declaration only support, allowing us to use printf! Unifying with veriadic might need work (does it need ref treatment?) 2018-12-29 14:50:58 -05:00
Nathan Braswell
eccc4c87a6 Finally, ref lowering! A little hacky, but not terrible... 2018-12-29 12:19:54 -05:00
Nathan Braswell
deda17e18b groundwork for refs, moved ref indicator into fun type 2018-12-27 15:14:28 -05:00
Nathan Braswell
66f82062ba Almost have scoped . working, in fact it is, but having objects with member names has problems (like o.o) if the member function is in scope. (it thinks maybe you're trying to call o on itself...) 2018-12-18 02:51:44 -05:00
Nathan Braswell
3f2d51ba75 Fixed type unification for templates! Next up is adding to the scope for . 2018-12-07 01:08:12 -05:00
Nathan Braswell
3e6dc2c5ee Merge branch 'master' of https://github.com/limvot/kraken 2018-12-05 23:43:28 -05:00
Nathan Braswell
0153054a4c work on k 2018-12-05 23:43:24 -05:00
Nathan Braswell
caafc6f4e4 Allow <= and >= as overloadable operators and add in a string <= function (though some refactoring to do <, >, and => would be good) and a sorted to vec 2018-12-06 04:39:40 +00:00
Nathan Braswell
8177bc7fd0 Add struct access! Uses new translation_unit_generative pass depended on by scope lookups to generate compiler_intrinsics that access members of structs' 2018-10-27 18:00:26 -04:00
Nathan Braswell
194842397f address of and dereference implemented as templated compiler intrinsics 2018-10-16 19:12:10 -04:00
Nathan Braswell
c0a6b614d0 Fix pointer/ref parsing 2018-10-10 01:13:47 -04:00
Nathan Braswell
02424543fb Explicit template function instantiation working 2018-10-10 00:39:04 -04:00
Nathan Braswell
379d9f612e Template functions (instantiated implicitly) work! 2018-10-09 23:00:57 -04:00
Nathan Braswell
39ecf24e69 Can't finish template inst tonight. 2018-10-08 00:28:42 -04:00
Nathan Braswell
0ae2fbaae6 Prep for templated functions 2018-10-02 23:51:26 -04:00
Nathan Braswell
3d8be84472 Break and continue weren't all the way implemented 2018-10-02 00:07:02 -04:00
Nathan Braswell
ae2f40bcc7 Treat assignment like other operators 2018-10-01 23:32:46 -04:00
Nathan Braswell
fb179cfcf7 Added primitive math ops, and realized when chaining them that overload resolution had to happen for different functions at different times (esp now that we don't just go outside in). Added a iterative resolver to solve the overloads, which iterates over each one and binds the one that only has one option and unifing types based on that, then running through them all again. If progress is not made for a whole iteration, it errors out and shows the first ambigious call. It could show all ambigious calls... 2018-10-01 01:19:51 -04:00
Nathan Braswell
dea34f0821 Add in all primitive comparators. Gonna add other primitive ops next - pointers are gonna be interesting and will probs have to wait till generic functions (to make them generic operators) 2018-09-30 16:21:24 -04:00
Nathan Braswell
4d5e65e962 Groundwork for primitive operations, including > for ints 2018-09-30 16:06:07 -04:00
Nathan Braswell
4dcf102cb0 Also regular overloading works now, by counting remaining unknowns as equal during overload filtering time (so that function calls as statements, which get an inferenced return type of _unknown can match a function with any return type 2018-09-24 00:21:39 -04:00
Nathan Braswell
2148577523 HM-style return type overloaded function infrencing works! 2018-09-24 00:09:30 -04:00
Nathan Braswell
9178c2a29d More unification for typechecking: 2018-09-22 20:10:56 -04:00
Nathan Braswell
6c7f313075 Very limited HM-style type inference works! (Just var v = value, but still. The machinery is mostly in place) 2018-09-22 16:41:36 -04:00
Nathan Braswell
0505a0e7d6 Move types into binding also 2018-09-22 14:54:52 -04:00
Nathan Braswell
38133b8bc3 Pull binding out into it's own templated object so we can use it for types for unification 2018-09-22 10:44:02 -04:00
Nathan Braswell
08b5e29b70 Fix poset to handle circular closed dependencies (they're propegated recursively to open dependencies) and some indentation fixes 2018-09-19 00:43:49 -04:00
Nathan Braswell
2d9f5dc6fe Add in support for top-level-declarations in k and erroring out if no progress is made in poset. A bug I encountered during devleopment of this reminds me of the need to deal with cycles in the poset in the future - probabally by not adding a close dependency if doing so would make a close dependency cycle? This might not actually be fully legitimate 2018-09-18 00:37:16 -04:00
Nathan Braswell
0e0ca8d7b4 Big changes to k - now all passes are top-level-item focused, does dead simple scope lookup. Added an error message when trying to match on not an ADT 2018-09-17 23:36:26 -04:00
Nathan Braswell
87bc88cde4 Transition to new pass/poset setup 2018-08-26 21:45:38 -04:00
Nathan Braswell
1cae1b1504 parse types into initial ast 2018-06-22 23:13:08 -04:00
Nathan Braswell
e851d0eac5 Add basis for types in k, and move to new poset setup (depend on individual imports, functions, types, and global variables) 2018-06-22 20:58:47 -04:00
Nathan Braswell
6ffe7aee46 Basic support for templates in ast, rest will come with types 2018-06-22 09:02:30 -04:00
Nathan Braswell
a8d4b4eb7f Parses everything but templates into new AST, including imports adding to dependency poset 2018-06-20 00:49:49 -04:00
Nathan Braswell
b5ce776726 Basic AST 2018-06-18 19:04:24 -04:00
Nathan Braswell
e898e7b285 Pass system works 2018-06-14 00:08:55 -04:00
Nathan Braswell
405ee70db8 Change ADTs to generate a copy_construct() that returns this, which should be our new default. Fix storing functions in vectors (lots of bugs here, with funciton types in templates, sizeof, returned by ref, etc. might have missed a few more, put in some warning comments 2018-06-12 23:29:39 -04:00
Nathan Braswell
d85f388792 Shorter AST names 2018-05-22 20:14:15 -04:00
Nathan Braswell
eefa752d55 shortening of str and vec 2018-05-22 19:43:54 -04:00
Nathan Braswell
804f98f9cf Finish up c extern functions for bytecode 2018-03-26 01:25:15 -04:00
Nathan Braswell
1c94cd2f03 Small, but added system call to bytecode 2018-03-23 01:27:44 -04:00
Nathan Braswell
b8213dfc9f Fix character value handling. String stuff appears to work correctly in bytecode now 2018-03-22 00:51:57 -04:00
Nathan Braswell
c056af6e56 accidentally broke subtraction 2018-03-21 01:50:24 -04:00
Nathan Braswell
f209fad91e Can generate bytecode for files that use a decent bit of the standard library now. Need to finish implementing the external functions, and check to see why we can't print integers. I think it might be that character values aren't being generated correctly 2018-03-21 01:20:28 -04:00