aboutsummaryrefslogtreecommitdiff
path: root/source (follow)
Commit message (Collapse)AuthorAgeFilesLines
* - Added type-inference when constructing tuples.Eduardo Julian2015-09-065-104/+107
|
* - Removed the (unnecessary) lux/meta/macro module.Eduardo Julian2015-09-0613-98/+90
|
* - Expanded the standard library.Eduardo Julian2015-09-0612-42/+332
| | | | - Fixed some minor bugs. - Added the updated code for the parser (forgot to add it to a previous commit).
* - Added a new (albeit small) I/O library with host-dependent functions.Eduardo Julian2015-09-025-46/+76
|
* - Added the lux/meta/type module (still missing equality due to an issue ↵Eduardo Julian2015-09-011-0/+157
| | | | with type-inference & Type/Show needs some pending corrections).
* - Fixed the implementation of the Rec macro, which forgot to do application ↵Eduardo Julian2015-09-011-60/+111
| | | | | on Void to achieve "recursion". - Introduced ExQ types into the type-system (still pending work on inference).
* - Added a macro to write recursive types.Eduardo Julian2015-09-014-118/+136
| | | | - Corrected some code that still involved the old names for the list macros. - Corrected some code in the pattern-matcher analyser to it fails properly when encountering invalid pattern-syntax.
* - Found a compromise with the issue of certain definitions clashing with ↵Eduardo Julian2015-08-319-373/+373
| | | | each other when saving the class files in case-insensitive file-systems (https://github.com/LuxLang/lux/issues/8). The names of certain definitions were changed slightly to avoid clashes and the compiler throws an error if the names end up clashing prior to saving the .class file.
* - Added call/cc to lux/codata/lazy.Eduardo Julian2015-08-302-2/+8
| | | - Added some minor compiler optimizations.
* - Removed the (now obsolete) `' macro.Eduardo Julian2015-08-307-459/+496
| | | - Implemented hygienic macros by adding global symbol resolution inside the ` macro.
* - Remove the (unnec) "All'" and "->'" macros.Eduardo Julian2015-08-2919-259/+260
| | | | - Improved the "struct" macro so that (once again) it doesn't ask for the prefixes of the members. - Added tests for the lux.reader namespace.
* - Added some compiler optimizations.Eduardo Julian2015-08-2913-307/+215
| | | | - Removed the (unnecessary) lux/control/dict & lux/control/stack modules. - The "Meta" type is now a record instead of a variant.
* - Removed the (unnecessary) lux/data/cont module.Eduardo Julian2015-08-295-87/+93
| | | | | | - Removed the (unnecessary) lux/data/error module and moved it's structures to lux/data/either. - Implemented the \slots destructurer for records. - Implemented quicksort for lists as the "sort" function in lux/data/list. - Added tags for the Cursor type.
* - Changed the name of AllT (for-all type) to UnivQ (universal quantification).Eduardo Julian2015-08-282-430/+460
| | | | - UnivQ no longer stores the environment as key-val pairs with Text names, but instead stores it as type-lists with variables accessed via an index through a (updated) BoundT. - UnivQ no longer stores the name of the type-fun, not the name of the type-arg.
* The environments of AllT types are no longer stored inside a Maybe.Eduardo Julian2015-08-281-29/+24
|
* Changed the license from EPL to MPL.Eduardo Julian2015-08-2839-273/+156
|
* Due to several performance issues and my inability to optimize them away due ↵Eduardo Julian2015-08-287-497/+494
| | | | to too many corner cases, I decided the abandon the path towards a more mathematical implementation of tuples & variants.
* - Restructuring how sums & products work [part 3]Eduardo Julian2015-08-237-172/+186
|
* - Restructuring how sums & products work [part 2]Eduardo Julian2015-08-231-72/+82
|
* - Restructuring how sums & products work [part 1]Eduardo Julian2015-08-231-255/+234
|
* - Finished turning tags into indices.Eduardo Julian2015-08-1719-467/+547
| | | | | | | - As an unexpected bonus, the compiler has become 2.5x faster. - Fixed some minor bugs. - Tag declarations now include associated types. - Tag declarations info is now stored twice (one from the perspective of tags, the other from the perspective of types). - Changed the named of the "types" member of the Compiler type, to "type-vars" to avoid collision with the "types" member of the Module type.
* Introduced named types (#NamedT Ident Type).Eduardo Julian2015-08-161-194/+235
|
* Unified tuples & records.Eduardo Julian2015-08-161-179/+152
|
* - Some clean-up of needless code.Eduardo Julian2015-08-161-171/+105
| | | - some adjustments to the new format for types.
* - Changing tags so they're actually indices (part 4). Eduardo Julian2015-08-121-23/+4
| | | - Bug fixes and adjustments.
* - Changing tags so they're actually indices (part 3). Eduardo Julian2015-08-121-50/+58
| | | | | | | | - Added several bug fixes - Changed "Reader" to "Source" and "HostState" to "Host" in lux.lux - Set up indexing of records via tags. - Added lux.analyser.record namespace. - Removed some (now) unnecessary code for working with records. - Added the license (can't believe I missed it for so long.)
* - Changing tags so they're actually indices (part 2).Eduardo Julian2015-08-101-4/+4
| | | | - Fixed some bugs. - Now pattern-matching on variants works with indices, rather than text tags.
* - Changing tags so they're actually indices (part 1).Eduardo Julian2015-08-101-118/+190
| | | | - Fixed a bug regarding type coercion (type-checking was ocurring unnecessarily). - Fixed another bug regarding Local/Global variables.
* - Local vars can now longer have prefixed symbols.Eduardo Julian2015-08-057-139/+152
|
* - The compiler now stores the cursor of the last analysed AST in order to ↵Eduardo Julian2015-08-052-15/+30
| | | | avoid the problem of error ocurring "nowhere" (at ["" -1 -1]).
* - Struct definition no longer required prefixed members (now, it actually ↵Eduardo Julian2015-08-0419-356/+371
| | | | prohibits them).
* - Renamed the Syntax type to AST.Eduardo Julian2015-08-0415-241/+271
| | | - Created the lux/meta/ast module.
* - Added a macro for exporting definitions (to not depend on the #export tag ↵Eduardo Julian2015-08-046-32/+47
| | | | | on definitions). - The "open" and "using" macros now work recursively on records.
* - Type definitions inside the compiler data now hold the type itself.Eduardo Julian2015-08-034-22/+48
| | | | - Value definitions inside the compiler data now hold the value itself. - Fixed a few bugs.
* Implemented text-interpolation through a macro ("<>") in lux/data/textEduardo Julian2015-08-036-24/+89
|
* - Added a module for hashing.Eduardo Julian2015-08-028-281/+431
| | | | | | | | - Refactored the standard library a bit. - Implemented the "loop" macro. - Added the expected type of expressions as a field in the compiler state. - Added syntactic sugar for using tuples with variants, in order to minimize the usage of brackets to delimit the contents of data-structures. - Fixed a bug wherein "macro-expand" was behaving like "macro-expand-all", and added a separate implementation for "macro-expand-all". - Fixed a few bugs.
* - Did some refactoring of the standard library.Eduardo Julian2015-07-3127-711/+1080
| | | | | | | | - Introduced 2 new modules: lux/data/tuple & lux/codata/function - Now doing safe reading of files. - Took the "let", "lambda" & "def" macros to their ultimate form. - Added some macros for doing better JVM interop. - Fixed a bug when compiling comparisons for doubles. - Changed the order in which arguments are compiled for all arithmetic operations, as the order is reversed (from the conventional order) in the JVM bytecode.
* - lux;using no longer prefixes variables.Eduardo Julian2015-07-2911-96/+67
| | | | - Fixed several bugs with host (JVM) interop. - Now packaging everything in a .jar file ("program.jar").
* - Changed the name of lux/host/java to lux/host/jvmEduardo Julian2015-07-269-195/+145
| | | | | - Completed lux/host/jvm - Modified (slightly) the syntax used in several host (JVM) special forms. - The "defsyntax" macro now binds all of the arguments it receives inside a variable named "tokens".
* - Fixed a pattern-matching error where generalizations of types ↵Eduardo Julian2015-07-268-93/+133
| | | | | | (universal-quantification / AllT) was not being taken into account properly when destructuring. - Fixed a compiler error wherein the types of definitions didn't generate (correctly) the structures necessary for storage inside the class _meta(data) field. - Improved both the "open" and "import" macros with extra features.
* - The output directory is now being used as the cache.Eduardo Julian2015-07-2531-0/+5222
| | | - "input" has been renamed as "source" and "output" has been renamed as "target".
* - The directory for source-code is now named "input".Eduardo Julian2015-06-202-2184/+0
| | | - Implemented module-caching to avoid the waiting too much during program compilation.
* - Added imports.Eduardo Julian2015-06-121-18/+24
| | | - Now storing information about definitions & imports inside the .class files.
* - Reimplemented module-aliasing.Eduardo Julian2015-06-101-26/+35
|
* - Put definition metadata into the generated .class files.Eduardo Julian2015-06-091-23/+6
|
* - Finished _jvm-interface_ & _jvm-class_.Eduardo Julian2015-05-311-93/+114
| | | - The version of the compiler is now stored as a field in the compiled definitions.
* - _jvm_program now relies on the (IO (,)) type.Eduardo Julian2015-05-272-10/+8
| | | - The command-line params argument in jvm_program is now transformed from a String array into (List Text).
* - Now using an in-memory class-loader.Eduardo Julian2015-05-261-2/+4
|
* - Cleaned-up a few things in lux.luxEduardo Julian2015-05-241-110/+100
| | | | - Replace most instances of "=" with ".equals". - Added an optimization to lux.type/type= that drastically speeds-up type comparisons.
* - Added a simple optimization based on the idea of avoiding to compare 2 ↵Eduardo Julian2015-05-221-35/+35
| | | | | type-functions which are most-likely the same, due to their name (remembering that when you define types using deftype, the type-function's name will correspond to the def's). - Gave empty environments to top-level type-functions, instead of leaving them with unset environments.