aboutsummaryrefslogtreecommitdiff
path: root/src (unfollow)
Commit message (Collapse)AuthorFilesLines
2015-04-26Made a small change in regards to how global defs are resolved.Eduardo Julian3-6/+14
2015-04-26- Macros are no longer declared. Instead, they are automatically detected.Eduardo Julian3-16/+95
2015-04-25- No more Any (Top) and Nothing (Bottom) types.Eduardo Julian6-294/+282
2015-04-25- More accurate AllT environment management by using (Maybe TypeEnv) instead ↵Eduardo Julian1-29/+56
of TypeEnv. The performance of the type-checker also improved thanks to that.
2015-04-23- Migrated all the record data-structures to the new tuple-like format.Eduardo Julian8-95/+122
2015-04-23- Fused lux;local-envs & lux;global-envs as lux;envs.Eduardo Julian5-70/+58
2015-04-23- Added a dummy implementation of "export'".Eduardo Julian6-68/+58
- 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
2015-04-23- Removed analyse-2, as it was redundant.Eduardo Julian8-62/+87
- Fixed several bugs within lux.lux. - Renamed "check'" to ":'" and "coerce" to ":!".
2015-04-19- Fixed several bugs in lux.luxEduardo Julian10-273/+307
- 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.
2015-04-17- Solved the bug wherein type-inferencing was causing computational ↵Eduardo Julian3-114/+110
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...)
2015-04-16- |do bindings are now based on pattern matching (that way, tuple ↵Eduardo Julian10-374/+366
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.
2015-04-16- Type-vars can now be deleted and be scoped (through with-var).Eduardo Julian8-332/+474
- 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.
2015-04-15- Fixed a few type-related bugs.Eduardo Julian9-325/+284
- 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.
2015-04-09- Function names & parameters now take prefixes into account.Eduardo Julian7-63/+155
- 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.
2015-04-08- Renamed exec to |do.Eduardo Julian21-504/+665
- :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).
2015-04-02- Identifiers with just a semi-colon in front now have "lux" as their ↵Eduardo Julian6-177/+189
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.
2015-03-30- Beginning to add type-system + type-inferencer.Eduardo Julian11-400/+482
- Removed exec, get@' & set@' special forms, as they are not primitive enough as to be part of the language.
2015-03-22- Fixed the bug that caused the infinite look while compiling the file.Eduardo Julian6-24/+61
2015-03-22- Added code-cursors (file-name, line-number, column-number) as metadata on ↵Eduardo Julian10-297/+359
lexer nodes & parser nodes.
2015-03-21- Added the reading-phase and it's associated structure as the mediator ↵Eduardo Julian4-306/+394
between raw source-code and the lexing-phase.
2015-03-21- Added module-name aliasing.Eduardo Julian20-693/+773
2015-03-21[2nd Super Refactoring That Breaks The System: Part 7]Eduardo Julian12-82/+93
- System works correctly once more.
2015-03-20[2nd Super Refactoring That Breaks The System: Part 6]Eduardo Julian16-180/+242
- Corrected more bugs in the system.
2015-03-19[2nd Super Refactoring That Breaks The System: Part 5]Eduardo Julian19-774/+964
- Changed indents to symbols. - Corrected some of the bugs in the system. Many more still awaiting fixes.
2015-03-18[2nd Super Refactoring That Breaks The System: Part 4]Eduardo Julian19-387/+417
- Finished moving the codebase to use the functions from lux.base with the "&" prefix.
2015-03-18[2nd Super Refactoring That Breaks The System: Part 3]Eduardo Julian12-355/+362
- Migrated more of the compiler's data-structures to using Lux's format.
2015-03-17[2nd Super Refactoring That Breaks The System: Part 2]Eduardo Julian12-458/+563
- Compiler-state is now using Lux record-format. - Went from Error+Ok to Left+Right.
2015-03-15[2nd Super Refactoring That Breaks The System: Part 1]Eduardo Julian14-580/+651
- Finishing implementing the type-system. - Migrating more of the data-structures used in the compiler to the ones used by Lux itself.
2015-03-12- Added program creation (generates the "main" method).Eduardo Julian5-59/+181
- Added invokespecial & invokeinterface. - Added putstatic & putfield. - Corrected primitive conversions & bitwise operators to take into account (un)boxing.
2015-03-12- Added a special form for testing if references are null.Eduardo Julian5-10/+399
- Added bitwise operators. - Added synchronization primitives (monitor enter & exit). - Added exception-handling. - Added conversions between primitive values.
2015-03-10- Added null values as jvm-null.Eduardo Julian5-4/+20
2015-03-10- Modified the compiler so parser syntax tokens are stored in the same ↵Eduardo Julian10-204/+242
format as lux data-structures, to ease communication between the compiler & macros.
2015-03-09- Implemented record compilation, alongside get@' and set@'.Eduardo Julian6-7/+162
- Made a small change in float & double comparisons to make sure NaN < n.
2015-03-08- Implemented comparisons and equalities for int, long, float & double.Eduardo Julian6-48/+220
- The lexer now allows "-" in front of numbers to get negative numbers.
2015-03-08- The implementation of monadic macros is finally finished.Eduardo Julian4-17/+15
2015-03-08- In lux.lux, fixed a bug in the "list" macro that rendered it unusable.Eduardo Julian3-3/+7
- 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.
2015-03-08- Changed once more the syntax of the prefix for host special forms. It's ↵Eduardo Julian13-571/+260
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.
2015-03-02- Removed the (currently broken) static-call optimization.Eduardo Julian4-38/+11
- Added a list of optimizations to do in the future (after the language is functionally complete).
2015-03-01Simplified the compiler by using arrays to encode tuples & variants instead ↵Eduardo Julian11-103/+85
of using custom classes for that.
2015-03-01Code compiles again! (although, I had to employ a hack for "fold", as ↵Eduardo Julian11-110/+272
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.
2015-03-01[TODO]Eduardo Julian3-11/+15
- 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.
2015-03-01- Fixed some bugs with pattern matching and macros.Eduardo Julian14-94/+121
- Simplified the code for handling definitions and macros. - Slightly changed the names of the fields of tuple classes. - Added a (currently empty) optimization phase.
2015-03-01Almost done with the super refactoring.Eduardo Julian5-570/+180
Codebase still needs to be simplified further, though. Also, an explicit optimization phase, between analysis and compilation, must be established.
2015-02-18[Refactor]Eduardo Julian19-218/+227
- Split lux/analyser/env into "env" & "def" modules. - Renamed lux/analyser/util to "base".
2015-02-18Corrections to the super-refactoring: part 4Eduardo Julian17-434/+467
2015-02-17Corrections to the super-refactoring: part 3Eduardo Julian8-657/+757
## "compiler" subsystem now (almost) compiles.
2015-02-17Corrections to the super-refactoring: part 2Eduardo Julian10-599/+667
## Reorganized a lot of analyser code and got the analyser to compile.
2015-02-15Corrections to the super-refactoring: part 1Eduardo Julian5-45/+48
2015-02-15Super refactoring that breaks the system: Part 4Eduardo Julian9-1209/+1179
2015-02-10Super refactoring that breaks the system: Part 3Eduardo Julian2-34/+2
## Good-bye let-expressions...