A dependently typed programming language, a successor to Idris
Go to file
Edwin Brady 1fe78c7f06 Complete basic partial evaluation mechanism
This more or less follows the rules from ICFP '10 "Scrapping your
inefficient engine" in that it generates new partially evaluated
definitions by evaluating with the statically known arguments, and
caches the results so that they can be reused if the evaluator
encounters them again. Some polish is still needed:
- proper tests
- nice display of residual programs (which will help with proper tests!)
- sensible handling of partial functions (probably a small limit on how
much to evaluate, and fail on encountering it?)
- checking whether evaluation has made progress, and failing if not

Once the above works, we're in a position to start specialising
interfaces, which is the main point of this.
2020-05-08 00:13:44 +01:00
.ci-dockerfiles [ new ] interactive test runner 2020-04-06 11:06:19 +01:00
.github/ISSUE_TEMPLATE Update issue templates 2019-07-23 09:43:18 +01:00
dist Merge pull request #310 from Kaiepi/bsd-builds 2020-04-27 15:21:37 +01:00
docs Add compatibility with the original record update syntax. 2020-04-27 18:02:25 +02:00
icons Add icons/logos 2019-07-21 14:47:11 +01:00
libs readFile needs a newline 2020-05-04 21:05:51 +01:00
Notes Use HTTPS instead of HTTP 2019-12-18 21:37:50 +01:00
samples Some FFI documentation 2020-03-03 23:23:49 +00:00
src Complete basic partial evaluation mechanism 2020-05-08 00:13:44 +01:00
support Check for EOF when reading from an input port 2020-04-24 12:32:58 +06:00
tests Change argument unification order 2020-04-28 11:31:18 +01:00
.gitignore Removed docs directory for adding new docs. 2020-04-13 17:41:59 +05:30
.travis.yml Add Travis CI config 2019-07-23 21:49:24 +02:00
CHANGELOG.md Merge branch 'master' into records 2020-04-27 13:36:18 +01:00
CONTRIBUTING.md Delay should always delay, not just under Inf 2019-08-06 14:54:27 +01:00
CONTRIBUTORS Add --dumpcases option 2020-04-02 16:11:10 +01:00
idris2.ipkg Add some more IRs for back ends to use 2020-04-30 22:15:04 +01:00
idris2api.ipkg Add an ipkg for Idris2 as a library 2020-04-06 22:27:31 +01:00
INSTALL.md Merge pull request #311 from Kaiepi/racket 2020-04-27 15:28:17 +01:00
LICENSE Remember to add the LICENSE 2019-07-09 00:00:25 +02:00
Makefile Fix builds on *BSD 2020-04-22 11:09:05 -03:00
mkdist.sh Add --dumpcases option 2020-04-02 16:11:10 +01:00
README.md Added a travis badge because it's good to have badges... 2020-04-07 13:26:27 +01:00
srcfiles Move network test to chez test suite 2020-03-05 18:03:12 +00:00
tests.ipkg Remove uneeded dependency on tests.ipkg 2020-04-25 15:30:24 -05:00

Idris 2

Build Status

This is a pre-alpha implementation of Idris 2, the successor to Idris.

*** Please note: To build, this requires Idris version 1.3.2 ***

Idris 2 is mostly backwards compatible with Idris 1, with some minor exceptions. The most notable user visible differences, which might cause Idris 1 programs to fail to type check, are:

  • Unbound implicit arguments are always erased, so it is a type error to attempt to pattern match on one.

  • Simplified resolution of ambiguous names, which might mean you need to explicitly disambiguate more often. As a general rule, Idris 2 will be able to disambiguate between names which have different concrete return types (such as data constructors), or which have different concrete argument types (such as record projections). It may struggle to resolve ambiguities if one name requires an interface to be resolved.

  • Minor differences in the meaning of export modifiers private, export, and public export, which now refer to visibility of names from other namespaces rather than visibility from other files.

  • Module names must match the filename in which they are defined (unless the module's name is "Main").

  • Anything which uses a %language pragma in Idris 1 is likely to be different. Notably, elaborator reflection will exist, but most likely in a slightly different form because the internal details of the elaborator are different.

  • The Prelude is much smaller (and easier to replace with an alternative).

  • let x = val in e no longer computes with x in e, instead being essentially equivalent to (\x => e) val. This is to make the behaviour of let consistent in the presence of case and with (where it is hard to push the computation inside the case/with efficiently). Instead, you can define functions locally with let, which do have computational force, as follows:

    let x : ?
        x = val in
        e
    

Watch this space for more details and the rationale for the changes, as I get around to writing it...

Summary of new features:

  • A core language based on "Quantitative Type Theory" which allows explicit annotation of erased types, and linear types.
  • let bindings are now more expressive, and can be used to define pattern matching functions locally.
  • Names which are in scope in a type are also always in scope in the body of the corresponding definition.
  • Better inference. Holes are global to a source file, rather than local to a definition, meaning that some holes can be left in function types to be inferred by the type checker. This also gives better inference for the types of case expressions, and means fewer annotations are needed in interface declarations.
  • Better type checker implementation which minimises the need for compile time evaluation.
  • New Chez Scheme based back end which both compiles and runs faster than the default Idris 1 back end. (Also, optionally, Chicken Scheme and Racket can be used as targets).
  • Everything works faster :).

A significant change in the implementation is that there is an intermediate language TTImp, which is essentially a desugared Idris, and is cleanly separated from the high level language which means it is potentially usable as a core language for other high level syntaxes.

Installation

To build and install what exists of it so far:

  • Optionally, set the PREFIX in Makefile
  • make idris2
  • make install

You'll need to set your PATH to $PREFIX/bin You may also want to set IDRIS_CC to clang, since this seems to build the generated C significantly faster.

Note: If you edit idris2.ipkg to use the opts with optimisation set (--cg-opt -O2) you'll find it runs about twice as fast, at the cost of taking a couple of minutes to generate the idris2 executable.

You can check that building succeeded by running

  • make test

I make no promises how well this works yet, but you are welcome to have a play. Good luck :).

Information about external dependencies are presented in INSTALL.md.

Things still missing

  • Disambiguation via 'with'
  • Cumulativity (so we currently have Type : Type! Bear that in mind when you think you've proved something :))
  • 'rewrite' doesn't yet work on dependent types
  • Parts of the ide-mode, particularly syntax highlighting
  • Documentation strings and HTML documentation generation
  • ':search' and ':apropos' at the REPL
  • Metaprogramming (reflection, partial evaluation)

Talks

Idris 2 - Type-driven Development of Idris (Curry On - London 2019)