c3e02d21adsample-code: Add some sample Conlang programs :DJohn2023-10-30 00:23:43 -05:00
c1c834701aparser: Mockup type-expression syntax - Allow name: Type notation for parameters - Allow fn x() -> RetVal notation for return values - TODO: Create syntax for type-expressions/pathsJohn2023-10-30 00:07:27 -05:00
374017d5e3examples/interpret: Call main if loading from fileJohn2023-10-29 23:48:38 -05:00
ee5dabb4f3Conlang: Implement functions 1.0 (Resolves#12) - [x] Call syntax - [x] Function declaration syntax TODO: - [ ] Any form of type checking - [ ] Static variable resolution - [ ] Closures, etc.John2023-10-29 23:47:00 -05:00
f3306e7ba4examples/format: Rename from parse_inputJohn2023-10-29 21:10:09 -05:00
9a6eb6b0f1examples/interpret: Improve the repl's UX somewhatJohn2023-10-29 01:14:36 -05:00
8fe89e6297conlang: Variable binding and cleanup ast: Separate concerns, and remove Walk interpreter: implement variable bindingJohn2023-10-29 01:13:48 -05:00
35d214c9f6ast: Remove vestigial "ignore" in ExprJohn2023-10-27 00:19:19 -05:00
ac540ebd22parser: parse let statements - TODO: Type expressions token: Add mut keywordJohn2023-10-27 00:18:02 -05:00
a339dfd549dummy.cl: Use unicode escape 🦈John2023-10-23 21:02:45 -05:00
0e917837c0identify_tokens: Use Display on token DataJohn2023-10-23 21:02:09 -05:00
8b1a1534f3docs: Improve and update documentationJohn2023-10-23 21:01:32 -05:00
c43ecf00d1token::token_data::Data: Renamed from token::TokenData & Moved into its own module + Added token::preamble; common imports when working with TokenJohn2023-10-23 19:43:16 -05:00
ccfddcc09aConlang: Add range operators TODO: Limit range operators to at most 2 operandsJohn2023-10-22 18:30:00 -05:00
b5abd2bff1Lexer rewrite: - Scan the input string *linearly*, without backtracking - Peek at most one character (unicode code-point) ahead - Store data (unescaped string literals and chars, identifiers, integers, floats) inside Token - This unfortunately makes tokens non-Copy - Refactor Parser to accommodate these changes - On the bright side, Parser no longer needs a reference to the text! - Write a new set of lexer tests - TODO: write a new set of token tests using tokendataJohn2023-10-22 18:28:20 -05:00
feb5cc5dd0AST: Refactor binary operations, fix Walk trait - Unified math operations into a single self-referential enum - Walk now visits the children of a node, rather than the node itself - The old behavior was super confusing, and led to numerous stack overflows.John2023-10-21 12:24:52 -05:00
4ec91ff806constr: switch to Rust-style unicode parsingJohn2023-10-21 12:20:22 -05:00
1e5f7149d9Token: Add range operators, rename for consistencyJohn2023-10-20 17:09:14 -05:00
34525ec77alexer: Only allow lines up to 4GB in size. Saves 8 bytes per tokenJohn2023-10-20 15:34:54 -05:00
a26a01fc17constr: Misuse iterators to parse tokensJohn2023-10-20 15:33:02 -05:00
7f7393d2c6conlang: Grammatical cleanup; merge control flow expressionsJohn2023-10-19 14:40:03 -05:00
331141356atests: Move module into fileJohn2023-10-17 13:39:05 -05:00
73f7337fd5pretty_printer: Move module into fileJohn2023-10-17 13:38:30 -05:00
59617d805aparser: Move module into fileJohn2023-10-17 13:36:21 -05:00
3d0698ba60lexer: Move module into fileJohn2023-10-17 13:33:07 -05:00
b1d9e4fd03ast: Move module into fileJohn2023-10-17 13:30:16 -05:00
5d9c45c26atoken: Move module into fileJohn2023-10-17 13:23:34 -05:00
c15490847atoken & lexer: add line & col to tokensJohn2023-10-13 13:05:14 -05:00
545483dae6token: Add Display impl for TypeJohn2023-09-28 01:34:56 -05:00
48f5e5248cconlang: Add break, true, false keywords, and example fileJohn2023-09-28 01:31:46 -05:00
f25685560aconlang: Tokenize punctuation (resolves#9) Things left to consider: - token::Type enum is getting fairly large. breaking it up could invoke substantial code bloat - Compound operators might make more sense at the parser level - Compound-assign operators are ripe for syntactic desugaring, but there must be some reason it's done separately in other languages. - Operators like FatArrow may still make sense at the tokenizer level, regardless. - What is a lexer? A miserable pile of parsers! - Operator overloading, or user-defined operators? Hmm...John2023-09-28 00:11:31 -05:00
d3b1e65e35lexer: Add documentation blurbs to token-class functionsJohn2023-09-28 00:09:47 -05:00
b1621f2522tests: Add tests for token-class functionsJohn2023-09-28 00:08:51 -05:00
0661789d42Lexer: reduce code duplication in Rule mappingJohn2023-09-27 22:51:51 -05:00
d4245844celexer: Add Invalid token to aid in implementing featuresJohn2023-09-27 21:17:35 -05:00
335fea8d73conlang: add delimiter types, lexer rules, and testsJohn2023-09-27 18:26:38 -05:00
bed21941e8conlang: Add keyword types, rules, and testsJohn2023-09-27 18:21:19 -05:00
097e2c4f11conlang: Rename literals; split, compose, and document Rules - Renamed literal Types to reflect their literal nature - This allows for consistent naming across future non-literal Types - Complicated lexer Rules have been split into composable sub-rules, and moved into the Rule struct. - This improves modularity, and allows sharing of sub-rules across rules. - Documented each lexer rule with (at least) a one-line blurb describing its functionJohn2023-09-27 18:13:01 -05:00
46e72e4889conlang: add toy program to interact with the tokenizerJohn2023-09-25 18:06:03 -05:00
443cd11803lexer: Refactor rule and assoc. tests - Lexer now ignores leading whitespace - Rule now has shorter, clearer function names - Tests for comment lexing are now consolidated into a module - Tests using the assert_has_type_and_len wrapper can now specify an expected lengthJohn2023-09-25 14:13:28 -05:00
71053f1992lerox: Consolidate traits The auto-implementation scheme doesn't really fit the applicationJohn2023-09-25 13:52:21 -05:00
8bc32896c9lerox: Fix and_any setting the Combinable to alright even when it should not be alrightJohn2023-09-23 01:04:10 -05:00
a8f524d742lerox: and_maybe is actually and_either with g = identity functionJohn2023-09-23 00:57:33 -05:00
24f7c95ae2dummy.cl: Add the new comment types to the exampleJohn2023-09-22 23:57:30 -05:00