Commit graph

470 commits

Author SHA1 Message Date
Leonardo de Moura
d2f169a211 chore(library/init/lean/parser/parser): remove unnecessary unsafe code 2019-08-02 14:32:47 -07:00
Leonardo de Moura
46f361daab feat(library/init/lean/elaborator): add open command elaborator 2019-07-31 15:58:04 -07:00
Leonardo de Moura
cf8daf4b24 feat(library/init/lean/elaborator): process header
TODO:
- improve/fix `setSearchPath`
- add `IO.getEnv`
- add support for relative imports at `absolutizeModuleName`
2019-07-24 07:37:33 -07:00
Leonardo de Moura
c40cba66fb fix(library/init/lean/parser/parser): use eraseDups when registering builting parsers 2019-07-22 18:19:47 -07:00
Leonardo de Moura
eb47746647 feat(library/init/lean/elaborator): namespace, section and end commands 2019-07-21 16:55:23 -07:00
Leonardo de Moura
fdbbdf68fc refactor(library/init/lean/elaborator/basic): make sure ElabState does not depend on parser state
cc @kha
2019-07-19 17:07:39 -07:00
Leonardo de Moura
f9459f6e93 feat(library/init/lean/syntax): add Syntax.other
We will use this feature to implement the new elaborator.
An elaborator produces `Syntax Expr` instead of `Syntax`.
2019-07-19 10:45:01 -07:00
Leonardo de Moura
bf64310603 chore(library/init/lean): minor 2019-07-19 07:21:24 -07:00
Leonardo de Moura
eb7b2b77fa chore(library/init/lean): minor changes 2019-07-18 17:16:44 -07:00
Leonardo de Moura
b1d5a4284d feat(library/init/lean): address issue raised in the previous commit
We also changed the type of `addImportedFn` to `Array (Array α) → IO σ`.
This modification avoids the `unsafeIO` hack at `parser.lean`.
2019-07-18 13:20:46 -07:00
Leonardo de Moura
261d316990 chore(library/init/lean/parser/module): document potential issue 2019-07-18 12:45:26 -07:00
Leonardo de Moura
73824790a3 feat(library/init/lean/parser/parser): store SyntaxNodeKinds 2019-07-17 19:09:16 -07:00
Leonardo de Moura
267225eca6 feat(library/init/io): unsafeIO returns Except IO.Error a instead of Option a 2019-07-17 19:09:16 -07:00
Leonardo de Moura
f0899b381d feat(library/init/lean/parser/module): add displayStx param 2019-07-17 19:09:15 -07:00
Leonardo de Moura
611635281b chore(library/init/lean/parser/command): simple open command syntax 2019-07-17 19:09:15 -07:00
Leonardo de Moura
5489e23758 fix(library/init/lean/parser/parser): apply workaround for performance issue created by equation compiler 2019-07-16 16:13:58 -07:00
Leonardo de Moura
63f03a0303 chore(library/init/lean/parser/parser): remove unnecessary variable 2019-07-16 14:39:46 -07:00
Leonardo de Moura
912b7551d2 chore(library/init/lean/parser/module): interrupt test parser at #exit 2019-07-16 14:15:40 -07:00
Leonardo de Moura
69ab85de14 feat(library/init/lean/parser/command): add #exit command 2019-07-16 14:15:27 -07:00
Leonardo de Moura
3169a5f0d1 chore(library/init/lean/parser/module): display parsing time in test parser 2019-07-16 13:49:10 -07:00
Leonardo de Moura
310faa18c1 chore(tests/compiler/termparsertest1): fix test 2019-07-16 13:40:02 -07:00
Leonardo de Moura
ab27e1c7be feat(library/init/lean/parser/parser): change many p behavior
We should not ingore an error in `p` if error position > initial position
2019-07-16 13:32:42 -07:00
Leonardo de Moura
e59edb27cd feat(library/init/lean/parser/term): allow type annotation after pattern 2019-07-16 13:21:02 -07:00
Leonardo de Moura
a52f67cea8 chore(library/init/lean/parser/parser): missing space 2019-07-16 13:10:07 -07:00
Leonardo de Moura
8a11c8509e fix(library/init/lean/parser/command): open <id>+ 2019-07-16 13:09:45 -07:00
Leonardo de Moura
5d077ad592 feat(library/init/lean/parser/term): add andM and orM notation 2019-07-16 10:56:44 -07:00
Leonardo de Moura
6f31f6a38f fix(library/init/lean/parser/parser): typo at quotedCharFn 2019-07-16 10:48:28 -07:00
Leonardo de Moura
0dcdc2c198 feat(library/init/lean/parser/term): add support for "named" patterns n@(x :: s)
@kha, the implementation is a little bit hackish. It is whitespace
sensitive to avoid `f @g`, an application with argument `@g` to be
parsed as a named pattern.
Here are other approaches I have considered:

1- In the `namedPattern`, we add a guard that ensures the pattern
is *not* an identifier. Thus, `f @g` would not be considered a valid
`namedPattern`. Drawback: we would always try to parse it as a
namedPattern first, fail, and then try as an application.

2- Enforce whitespace before application arguments. Drawback: `f(a+b)`
would not be a valid application anymore.
2019-07-16 10:09:01 -07:00
Leonardo de Moura
260ea04add fix(library/init/lean/parser/parser): typo startPart ==> startPos 2019-07-16 09:36:44 -07:00
Leonardo de Moura
b157b2c9e9 feat(library/init/lean/parser): improve error messages 2019-07-16 08:16:03 -07:00
Leonardo de Moura
f206b30fd7 feat(library/init/lean/parser): add charLit 2019-07-16 07:22:09 -07:00
Leonardo de Moura
ee5ffb8ee2 fix(library/init/lean/parser/command): add partial modifier 2019-07-15 16:35:14 -07:00
Leonardo de Moura
07e52fb36c feat(library/init/lean/parser/term): quoted names 2019-07-15 16:06:51 -07:00
Leonardo de Moura
9f828f015f fix(library/init/lean/parser/term): allow empty anonymousCtor 2019-07-15 15:32:25 -07:00
Leonardo de Moura
262e83bbc8 fix(library/init/lean/parser/command): add class inductive 2019-07-15 15:24:26 -07:00
Leonardo de Moura
65edaa12a3 fix(library/init/lean/parser/command): missing trys 2019-07-15 14:18:21 -07:00
Leonardo de Moura
7af9de41ca feat(library/init/lean/parser/term): add borrowed syntax 2019-07-15 14:12:13 -07:00
Leonardo de Moura
299c3a0791 fix(library/init/lean/parser/term): typo 2019-07-15 14:09:31 -07:00
Leonardo de Moura
1636083cae fix(library/init/lean/parser/parser): typo 2019-07-15 14:07:27 -07:00
Leonardo de Moura
367f28e90b chore(library/init/lean/parser/module): export test function 2019-07-15 13:39:56 -07:00
Leonardo de Moura
a8c36d4c29 feat(library/init/lean/syntax): remove MacroScopes
We are going to use a simpler approach to help users writing hygienic
macros. Suppose we have a syntax quotation such as
```
`(let x := %%a;
  ite x x %%b)
```
We will parse this quotation, and during elaboration, we must create
code (i.e., an `Expr`) such that given `a` and `b`, it constructs
a (new) syntax object, and we want to guarantee that there is no accidental name capture.
So, given the syntax object `S` representing the quotation above, we
first pre-resolve the identifiers in `S`. In this step, we annotate the
identifier `ite` with the global declaration `_root_.ite`.
Then, we create a fresh identifier for each identifier, but we would
preserve the pre-resolved information.
Assume the monadic action `mkFresh <id>` creates a fresh identifier with
prefix `<id>`, and `mkFreshWithPreresolved <id> <pre-list>` creates a
fresh identifier with prefix <id> and pre-resolved list `<pre-list>`.
Then, the quotation above would be transformed into:
```
let x := mkFresh `x;
let ite := mkFreshWith `ite [`_root_.ite];
`(let %%x := %%a;
 %%ite %%x %%x %%b)
```
Here, the new quotation is just syntax sugar for a sequence of `Syntax`
constructor applications. Now, whenever we want to create a syntax
object using the quotation above, we guarantee there is no accidental
name capture because we are creating a fresh identifier for all
identifiers in the quotation. Global references are preserved using the
field preresolved that we already have.
It is straightforward to implement the transformation above using a
mapping. Note that if we use the same mapping to elaborate two different
quotations, we are essentially saying they share the same scope.
For example, suppose we have
```
let c := `(ite x x %%b);
`(let x := %%a; %%c)
```
If we use the same mapping, we produce
```
let x := mkFresh `x;
let ite := mkFreshWith `ite [`_root_.ite];
let c := `(%%ite %%x %%x %%b);
`(let %%x := %%a; %%c)
```
If we create a new mapping when compiling each quotation, we get
```
let x := mkFresh `x;
let ite := mkFreshWith `ite [`_root_.ite];
let c := `(%%ite %%x %%x %%b);
let x1 := mkFresh `x;
`(let %%x1 := %%a; %%c)
```
which is probably not what the user wants.
We can provide a simple notation for users specifying which behavior
they want. The default may be super simple. Example: we have a new mapping (aka scope) per declaration.
The approach above is simple and efficient. It is also great for
users that want to create syntax objects during the elaboration phase
and want to avoid name capture.
2019-07-15 10:00:27 -07:00
Leonardo de Moura
146a796c5c feat(library/init/lean/module): add ModuleParser with error recovery 2019-07-15 09:32:13 -07:00
Leonardo de Moura
6a47055850 feat(library/init/lean/parser/parser): improve orelse error message 2019-07-15 09:31:37 -07:00
Leonardo de Moura
b9149dd428 fix(library/init/lean/parser/module): token table initialization 2019-07-14 08:31:12 -07:00
Leonardo de Moura
d588d39786 fix(library/init/lean/parser): use symbolOrIdent when parsing max and imax 2019-07-14 08:22:07 -07:00
Leonardo de Moura
f8fba6877b fix(library/init/lean/parser/parser): add ident as possible first token for symbolOrIdent 2019-07-14 08:19:42 -07:00
Leonardo de Moura
1dce4a8f70 feat(library/init/lean/parser/parser): add symbolOrIdent 2019-07-14 08:09:04 -07:00
Leonardo de Moura
a843c0be55 feat(library/init/lean/parser/parser): shared TokenTable 2019-07-14 07:53:24 -07:00
Leonardo de Moura
52157cebf7 feat(library/init/lean/parser): add ParserAttribute skeleton 2019-07-14 07:16:14 -07:00
Leonardo de Moura
e4c9326c00 feat(library/init/lean/parser): add module.lean 2019-07-12 16:42:25 -07:00