diff options
-rw-r--r-- | src/ChangeLog | 9 | ||||
-rw-r--r-- | src/interp/c-doc.boot | 10 | ||||
-rw-r--r-- | src/interp/compiler.boot | 25 | ||||
-rw-r--r-- | src/interp/postpar.boot | 4 |
4 files changed, 43 insertions, 5 deletions
diff --git a/src/ChangeLog b/src/ChangeLog index 9d1ee773..4c95fcf2 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,12 @@ +2013-06-02 Gabriel Dos Reis <gdr@integrable-solutions.net> + + Make parser non-dependent on constructor databases. + * interp/compiler.boot (instantiateNiladics!): New. + (compileParseTree): Use it to expand niladict constructors. + (instantiateNiladicsInList!): New. + * interp/c-doc.boot (instantiateNiladicsInDoc!): New. + (finalizeDocumentation): Use it. + 2013-06-01 Gabriel Dos Reis <gdr@integrable-solutions.net> * interp/define.boot (addInfo): Remove. diff --git a/src/interp/c-doc.boot b/src/interp/c-doc.boot index 5c87a1ed..ba640875 100644 --- a/src/interp/c-doc.boot +++ b/src/interp/c-doc.boot @@ -1,6 +1,6 @@ -- Copyright (c) 1991-2002, The Numerical Algorithms Group Ltd. -- All rights reserved. --- Copyright (C) 2007-2011, Gabriel Dos Reis. +-- Copyright (C) 2007-2013, Gabriel Dos Reis. -- All rights reserved. -- -- Redistribution and use in source and binary forms, with or without @@ -136,10 +136,16 @@ collectAndDeleteAssoc x == y.rest := s res +instantiateNiladicsInDoc! docList == + for [x,:.] in docList | x is [.,:.] repeat + x.opSig := instantiateNiladicsInList! x.opSig + docList + finalizeDocumentation db == ctor := dbConstructor db unusedCommentLineNumbers := [x for (x := [n,:r]) in $COMBLOCKLIST | r] - docList := substitute("$","%",transDocList($op,$docList)) + docList := instantiateNiladicsInDoc! + substitute!("$","%",transDocList($op,$docList)) if u := [sig for [sig,:doc] in docList | null doc] then for y in u repeat y is 'constructor => noHeading := true diff --git a/src/interp/compiler.boot b/src/interp/compiler.boot index 3bcb0399..e6b9f2c8 100644 --- a/src/interp/compiler.boot +++ b/src/interp/compiler.boot @@ -2797,6 +2797,30 @@ preprocessParseTree pt == displayPreCompilationErrors() nil +++ Mutate parse form `pf' so that references to niladic constructors +++ appear in instantiation form. +instantiateNiladics! pf == + ident? pf and niladicConstructor? pf => [pf] + do + pf isnt [.,:.] or pf.op is 'QUOTE => nil + pf.op in '(DEF MDEF) => + -- Note: Normally, we wouldn't want to touch the definiendum; + -- except that some operators such as 'case' take flags, + -- so we want to solve them if they are types. + if second(pf) is [.,:.] then + second(pf).args := instantiateNiladicsInList! second(pf).args + third(pf) := instantiateNiladicsInList! third pf + fourth(pf) := instantiateNiladics! fourth pf + pf.op is 'SIGNATURE => third(pf) := instantiateNiladicsInList! third pf + pf.op isnt [.,:.] => pf.args := instantiateNiladicsInList! pf.args + instantiateNiladicsInList! pf + pf + +instantiateNiladicsInList! l == + for xs in tails l repeat + xs.first := instantiateNiladics! first xs + l + ++ Takes a parse tree `pt', typecheck it and compile it down ++ to VM instructions. compileParseTree pt == @@ -2815,6 +2839,7 @@ compileParseTree pt == $returnMode: local := $EmptyMode $exitModeStack: local := [] -- Used by the compiler proper $leaveLevelStack: local := [] + pf := instantiateNiladics! pf if T := compTopLevel(pf,$EmptyMode,$InteractiveFrame) then $InteractiveFrame := T.env finishLine $OutputStream diff --git a/src/interp/postpar.boot b/src/interp/postpar.boot index eeebbfe0..7cdf7674 100644 --- a/src/interp/postpar.boot +++ b/src/interp/postpar.boot @@ -167,9 +167,7 @@ postAtom x == x is 0 => $Zero x is 1 => $One x is "," => "%Comma" - ident? x => - niladicConstructor? x => [x] - normalizeName x + ident? x => normalizeName x x postBlock: %ParseTree -> %ParseForm |