aboutsummaryrefslogtreecommitdiff
path: root/source/lux.lux (follow)
Commit message (Collapse)AuthorAgeFilesLines
...
* - Added ;;self-prefixes.Eduardo Julian2015-05-031-48/+103
| | | | - Added a version of ` that prefixes unprefixed idents with the current module's name. - The special forms no longer require unprefixed symbols and work with anything (in order to work properly with the new `).
* - Fixed escaping in charsEduardo Julian2015-05-031-17/+189
| | | | - Added 2 custom pattern-matchers (\ & \or) & gensym - Added signatures & structures ^_^
* - The type syntax is finally complete ^_^Eduardo Julian2015-05-031-110/+182
| | | | | | | | | - Finally, the "case" macro has been implemented ^_^ - The macro-expand function is also alive! - Corrected the field-access special forms so they take their field as a symbol instead of text. - Macros are no longer stored inside the CompilerState as (Maybe Macro), but as Macro. - Void is implemented as - Fixed an error when parsing escaped characters in text. - Fixed an error in the reader in which parsing regex2 gave back a 2-vector instead of a 2-tuple.
* - Implemented some new macros & functions in lux.lux.Eduardo Julian2015-05-021-113/+212
| | | - WORKING ON DEBUGGING A COMPILER ERROR: java.lang.IncompatibleClassChangeError
* - Finally got find-macro & macro-expand to work... (Note: type-vars bug is ↵Eduardo Julian2015-05-021-68/+32
| | | | | still there. Must find & squash). -
* - Added existential types via #ExT.Eduardo Julian2015-05-011-1/+2
| | | - Removed the (now useless) lux.type/is-Type? function.
* Optimized the compiler with 2 tweaks:Eduardo Julian2015-05-011-26/+0
| | | | - Compilation units are not longer wrapped inside Expression/Statement variants. - analyse-apply* no longer returns lists.
* - Added the lux;seed slot to the compiler state.Eduardo Julian2015-05-011-6/+35
| | | | - Macro declarations are now handled at the compiler-phase instead of the analyser phase to avoid the posibility of trying to declare a yet-uncompiled macro (due to the macro-expansion of defmacro). - Added a makeshift implementation of existential types on top of BoundT (must migrate to a more permanent implementation).
* - declare-macro has returned.Eduardo Julian2015-05-011-694/+464
| | | | | | - Method-invocation special forms now take the wanted method as an unprefixed symbol, instead of as text. - Some fixes in lux.analyser.host. - Lambda analysis now just returns the origin exo-type instead of the endo-type. - Made some changes to the type of the CompilerState.
* - Implemented pattern-matching for records.Eduardo Julian2015-04-301-61/+23
| | | | - Added some code to allow variant creation with existential types. (NOTE: Check if it's actually valid) - Modify var cleanup to leave the var as-is if it has been deleted. (NOTE: Need to find out why a variable is left prior to being deleted)
* - Made a slight correction to the Syntax type when it comes to records ↵Eduardo Julian2015-04-291-208/+192
| | | | | | | (slot-names are no longer Text, but Syntax). - lux/type;bound? no longer does further derefs to check for bound-ness? - Improved the way 2 type-vars are type-checked. - When cleaning type-vars, the dereffed typed is no longer cleaned again.
* - Fixed some errors in lux.lux.Eduardo Julian2015-04-281-1102/+1294
| | | | | | | | | | | | - Added the ability to export from def. - Added an optimized lambda macro. - Finished record analysis & compilation. - Fixed a bug in tuple, function & record analysis wherein AppT wasn't being performed prior to analysing the expression under analysis. - Fixed several bugs wherein "fail*" was needed but "fail" was used. - Added a case for records in base;show-ast. - Made an improvement for AllT in type;show-type. - Corrected an error in pattern-matching compilation wherein casts weren't being performed to make sure the source datum was of the necessary type for PM. - Removed the (now unnecessary) lux/macro.
* - lux/analyser/def has been renamed to lux/analyser/module.Eduardo Julian2015-04-261-214/+213
| | | | | - Renamed a few defs in lux.lux. - No more type-test shortcut inside lux/analyser/lux. - Defs are now being classified as either (#ValueD <type>) or (#MacroD <macro>).
* Made a correction to lux.lux and the analyser regarding how to handle type-vars.Eduardo Julian2015-04-261-3/+4
|
* - Macros are no longer declared. Instead, they are automatically detected.Eduardo Julian2015-04-261-257/+270
|
* - No more Any (Top) and Nothing (Bottom) types.Eduardo Julian2015-04-251-32/+25
|
* - More accurate AllT environment management by using (Maybe TypeEnv) instead ↵Eduardo Julian2015-04-251-28/+30
| | | | of TypeEnv. The performance of the type-checker also improved thanks to that.
* - Fused lux;local-envs & lux;global-envs as lux;envs.Eduardo Julian2015-04-231-18/+22
|
* - Added a dummy implementation of "export'".Eduardo Julian2015-04-231-208/+395
| | | | | - Fixed a bug wherein bool pattern-matching was only considered total if there was a wildcard, despite true & false cases where provided. - Changed the syntax of the jvm-interface special form. - Refactored the lux;writer, lux;eval-ctor & lux;loader fields of the CompilerState into a single data-structure which is now stored under the lux;host field
* - Removed analyse-2, as it was redundant.Eduardo Julian2015-04-231-444/+412
| | | | | - Fixed several bugs within lux.lux. - Renamed "check'" to ":'" and "coerce" to ":!".
* - Fixed several bugs in lux.luxEduardo Julian2015-04-191-1088/+1258
| | | | | | | - Fixed an error in lux.base/analyse-2 - Modified the analyser so the symbols that identify all of the special forms must mandatorily have "" as their prefix. - Fixed a bug in the binary operations at lux.analyser.host wherein the types where being omitted. - Fixed a bug when closing-over variables inside lambda bodies wherein the names of bindings where being stores as (incomparable) arrays, instead of as (comparable) strings.
* - Solved the bug wherein type-inferencing was causing computational ↵Eduardo Julian2015-04-171-208/+188
| | | | | | | complexity to explode and cause the compiler to become very slow (solved it by removing type-inference from tuples). - Also removed type-inference from functions/lambdas. - Added a small optimization to improve the efficiency of type-checking by not doing a thorough type-check when a global or local binding has a type variant with the same cases as Type, and it's exo-type is also like this (hopefully, it will never happen that someone will exploit this to make the compiler do something weird...)
* - |do bindings are now based on pattern matching (that way, tuple ↵Eduardo Julian2015-04-161-1219/+1239
| | | | | | | | destructuring can be done at do). - Patterns are no longer put inside a MatchAC structure, but are instead just moved around as lists. - Code outside of &type can no longer create/delete type-vars directly, but must now rely on with-var & with-vars to manage the life-cycle of type-vars. - Simplified pattern-matching analysis at lux/analyser/case. - The LEFT_APP optimization in check* has been replicated on the other side as RIGHT_APP, to attempt to improve performance of pattern-matching.
* - Type-vars can now be deleted and be scoped (through with-var).Eduardo Julian2015-04-161-163/+160
| | | | | - Fixed a few bugs with types and pattern-matching. - Fixed a bug wherein primitive-analysis did now unify the primitive type with the exotype. - Modified lambda-analysis so functions subject to universal quantification can manage better the universally-quantified variables.
* - Fixed a few type-related bugs.Eduardo Julian2015-04-151-174/+184
| | | | - Variants now need types to be specified both when constructing them as when deconstructing them (in pattern-matching). - Simplified DataT types by no-longer requiring a list of params, so only the tame name is necessary.
* - Function names & parameters now take prefixes into account.Eduardo Julian2015-04-091-39/+39
| | | | | - Added more cases for totality checking in pattern-matching. - Fixed a bug when type-checking function application that used the exo-type for both the function being applied as to the application itself. - Fixed a few minor bugs scattered around that had to do with wrong number of arguments being passed to functions.
* - Renamed exec to |do.Eduardo Julian2015-04-081-126/+126
| | | | | - :let within |do now uses |let instead of let. - The analyser now does totality analysis and structures the pattern matching, with the compiler only compiling the generated structures. - Local bindings with case' can now be prefixed arbitrarily. (Note: must do the same with functions).
* - Identifiers with just a semi-colon in front now have "lux" as their ↵Eduardo Julian2015-04-021-920/+1079
| | | | | | | | | module, instead of the local module. (e.g. ;map, #;Cons, ;All) - The type-checker now takes into account 2 types: an exo-type (imposed by outside forces) and an endo-type (generated through inference) - Fixed a few bugs in the analyser and the type-system. - &type/solve* is now the actual type-checker and &type/solve invokes solve* with an empty fixpoint environment. - The exo-type of Statements is Nothing. - variants, tuples and def' are being analyzed properly now.
* - Beginning to add type-system + type-inferencer.Eduardo Julian2015-03-301-920/+1100
| | | - Removed exec, get@' & set@' special forms, as they are not primitive enough as to be part of the language.
* - Fixed the bug that caused the infinite look while compiling the file.Eduardo Julian2015-03-221-1/+1
|
* - Added code-cursors (file-name, line-number, column-number) as metadata on ↵Eduardo Julian2015-03-221-207/+218
| | | | lexer nodes & parser nodes.
* - Added the reading-phase and it's associated structure as the mediator ↵Eduardo Julian2015-03-211-4/+25
| | | | between raw source-code and the lexing-phase.
* - Added module-name aliasing.Eduardo Julian2015-03-211-102/+112
|
* [2nd Super Refactoring That Breaks The System: Part 7]Eduardo Julian2015-03-211-416/+420
| | | - System works correctly once more.
* [2nd Super Refactoring That Breaks The System: Part 6]Eduardo Julian2015-03-201-226/+229
| | | - Corrected more bugs in the system.
* [2nd Super Refactoring That Breaks The System: Part 5]Eduardo Julian2015-03-191-817/+817
| | | | - Changed indents to symbols. - Corrected some of the bugs in the system. Many more still awaiting fixes.
* [2nd Super Refactoring That Breaks The System: Part 2]Eduardo Julian2015-03-171-49/+67
| | | | | - Compiler-state is now using Lux record-format. - Went from Error+Ok to Left+Right.
* [2nd Super Refactoring That Breaks The System: Part 1]Eduardo Julian2015-03-151-119/+191
| | | | - Finishing implementing the type-system. - Migrating more of the data-structures used in the compiler to the ones used by Lux itself.
* - Added null values as jvm-null.Eduardo Julian2015-03-101-0/+2
|
* - Modified the compiler so parser syntax tokens are stored in the same ↵Eduardo Julian2015-03-101-6/+4
| | | | format as lux data-structures, to ease communication between the compiler & macros.
* - Implemented record compilation, alongside get@' and set@'.Eduardo Julian2015-03-091-128/+184
| | | - Made a small change in float & double comparisons to make sure NaN < n.
* - Implemented comparisons and equalities for int, long, float & double.Eduardo Julian2015-03-081-418/+464
| | | - The lexer now allows "-" in front of numbers to get negative numbers.
* - The implementation of monadic macros is finally finished.Eduardo Julian2015-03-081-64/+70
|
* - In lux.lux, fixed a bug in the "list" macro that rendered it unusable.Eduardo Julian2015-03-081-387/+383
| | | | - Fixed a bug when compiling lambda instantiation (the bug had to do with compiling the env variables passed to the closure). - Fixed a bug in the lexer wherein the backquote (`) wasn't being recognized.
* - Changed once more the syntax of the prefix for host special forms. It's ↵Eduardo Julian2015-03-081-730/+569
| | | | | | | | | | now "jvm-" instead of "jvm;" - Fixed the bug where the same local vars/registers were getting registered more than once and the class-verifier complained. - Fixed a bug where the "end label" for pattern-matching bodies was never inserted. - Simplified the analyser by removing "self" calls and having self be just a local for the "this" object (register 0). - Removed the lambda-folding optimization. - The compiler state now holds and environment for naming globally-scoped lambdas.
* Simplified the compiler by using arrays to encode tuples & variants instead ↵Eduardo Julian2015-03-011-34/+15
| | | | of using custom classes for that.
* Code compiles again! (although, I had to employ a hack for "fold", as ↵Eduardo Julian2015-03-011-121/+92
| | | | | | function self-calls are broken). Also fixed several small bugs, including the one that caused ".apply" to never make progress (always returned a function with count 0). Also fixed an issue with scopes that caused class-names to be generated improperly.
* [TODO]Eduardo Julian2015-03-011-44/+18
| | | | | - For some reason, when I fail at compilation due to mistaken use of tags/variants, I don't get the right error reported. [Fixes] - Solved a problem where stack values weren't being properly cleaned-up when pattern-matching on variants and branch bodies.
* - Fixed some bugs with pattern matching and macros.Eduardo Julian2015-03-011-21/+63
| | | | | - Simplified the code for handling definitions and macros. - Slightly changed the names of the fields of tuple classes. - Added a (currently empty) optimization phase.
* Almost done with the super refactoring.Eduardo Julian2015-03-011-223/+246
| | | | Codebase still needs to be simplified further, though. Also, an explicit optimization phase, between analysis and compilation, must be established.