summaryrefslogtreecommitdiff
path: root/Source/Dafny/Scanner.cs
diff options
context:
space:
mode:
authorGravatar leino <unknown>2015-05-06 17:58:00 -0700
committerGravatar leino <unknown>2015-05-06 17:58:00 -0700
commitf98a30f1ad7c441d8ef9e6e5740752723a43413a (patch)
treed3be16d38a2de15865b4b25c38b8c07e41ec1173 /Source/Dafny/Scanner.cs
parent20f97304dda7dca7259514ca472c3c1b76262013 (diff)
Added inductive predicates
Diffstat (limited to 'Source/Dafny/Scanner.cs')
-rw-r--r--Source/Dafny/Scanner.cs132
1 files changed, 61 insertions, 71 deletions
diff --git a/Source/Dafny/Scanner.cs b/Source/Dafny/Scanner.cs
index cbe8e6e5..9495d309 100644
--- a/Source/Dafny/Scanner.cs
+++ b/Source/Dafny/Scanner.cs
@@ -211,13 +211,13 @@ public class UTF8Buffer: Buffer {
public class Scanner {
const char EOL = '\n';
const int eofSym = 0; /* pdt */
- const int maxT = 135;
- const int noSym = 135;
+ const int maxT = 136;
+ const int noSym = 136;
[ContractInvariantMethod]
void objectInvariant(){
- Contract.Invariant(this._buffer != null);
+ Contract.Invariant(buffer!=null);
Contract.Invariant(t != null);
Contract.Invariant(start != null);
Contract.Invariant(tokens != null);
@@ -227,18 +227,7 @@ public class Scanner {
Contract.Invariant(errorHandler != null);
}
- private Buffer/*!*/ _buffer; // scanner buffer
-
- public Buffer/*!*/ buffer {
- get {
- Contract.Ensures(Contract.Result<Buffer>() != null);
- return this._buffer;
- }
- set {
- Contract.Requires(value != null);
- this._buffer = value;
- }
- }
+ public Buffer/*!*/ buffer; // scanner buffer
Token/*!*/ t; // current token
int ch; // current input character
@@ -318,7 +307,7 @@ public class Scanner {
t = new Token(); // dummy because t is a non-null field
try {
Stream stream = new FileStream(fileName, FileMode.Open, FileAccess.Read, FileShare.Read);
- this._buffer = new Buffer(stream, false);
+ buffer = new Buffer(stream, false);
Filename = useBaseName? GetBaseName(fileName): fileName;
Init();
} catch (IOException) {
@@ -333,7 +322,7 @@ public class Scanner {
Contract.Requires(fileName != null);
pt = tokens = new Token(); // first token is a dummy
t = new Token(); // dummy because t is a non-null field
- this._buffer = new Buffer(s, true);
+ buffer = new Buffer(s, true);
this.errorHandler = errorHandler;
this.Filename = useBaseName? GetBaseName(fileName) : fileName;
Init();
@@ -560,28 +549,29 @@ public class Scanner {
case "yield": t.kind = 83; break;
case "function": t.kind = 84; break;
case "predicate": t.kind = 85; break;
- case "copredicate": t.kind = 86; break;
- case "label": t.kind = 88; break;
- case "break": t.kind = 89; break;
- case "where": t.kind = 90; break;
- case "return": t.kind = 92; break;
- case "new": t.kind = 94; break;
- case "if": t.kind = 95; break;
- case "while": t.kind = 96; break;
- case "match": t.kind = 97; break;
- case "assert": t.kind = 98; break;
- case "print": t.kind = 99; break;
- case "forall": t.kind = 100; break;
- case "parallel": t.kind = 101; break;
- case "modify": t.kind = 102; break;
- case "exists": t.kind = 121; break;
- case "in": t.kind = 123; break;
- case "false": t.kind = 128; break;
- case "true": t.kind = 129; break;
- case "null": t.kind = 130; break;
- case "this": t.kind = 131; break;
- case "fresh": t.kind = 132; break;
- case "old": t.kind = 133; break;
+ case "inductive": t.kind = 86; break;
+ case "copredicate": t.kind = 87; break;
+ case "label": t.kind = 89; break;
+ case "break": t.kind = 90; break;
+ case "where": t.kind = 91; break;
+ case "return": t.kind = 93; break;
+ case "new": t.kind = 95; break;
+ case "if": t.kind = 96; break;
+ case "while": t.kind = 97; break;
+ case "match": t.kind = 98; break;
+ case "assert": t.kind = 99; break;
+ case "print": t.kind = 100; break;
+ case "forall": t.kind = 101; break;
+ case "parallel": t.kind = 102; break;
+ case "modify": t.kind = 103; break;
+ case "exists": t.kind = 122; break;
+ case "in": t.kind = 124; break;
+ case "false": t.kind = 129; break;
+ case "true": t.kind = 130; break;
+ case "null": t.kind = 131; break;
+ case "this": t.kind = 132; break;
+ case "fresh": t.kind = 133; break;
+ case "old": t.kind = 134; break;
default: break;
}
}
@@ -842,52 +832,52 @@ public class Scanner {
else if (ch >= '0' && ch <= '9') {AddCh(); goto case 65;}
else {t.kind = 5; break;}
case 66:
- {t.kind = 87; break;}
+ {t.kind = 88; break;}
case 67:
- {t.kind = 91; break;}
+ {t.kind = 92; break;}
case 68:
- {t.kind = 93; break;}
+ {t.kind = 94; break;}
case 69:
- {t.kind = 103; break;}
+ {t.kind = 104; break;}
case 70:
- {t.kind = 105; break;}
- case 71:
{t.kind = 106; break;}
- case 72:
+ case 71:
{t.kind = 107; break;}
- case 73:
+ case 72:
{t.kind = 108; break;}
- case 74:
+ case 73:
{t.kind = 109; break;}
- case 75:
+ case 74:
{t.kind = 110; break;}
- case 76:
+ case 75:
{t.kind = 111; break;}
+ case 76:
+ {t.kind = 112; break;}
case 77:
- {t.kind = 113; break;}
+ {t.kind = 114; break;}
case 78:
if (ch == '&') {AddCh(); goto case 79;}
else {goto case 0;}
case 79:
- {t.kind = 114; break;}
- case 80:
{t.kind = 115; break;}
- case 81:
+ case 80:
{t.kind = 116; break;}
- case 82:
+ case 81:
{t.kind = 117; break;}
+ case 82:
+ {t.kind = 118; break;}
case 83:
- {t.kind = 119; break;}
- case 84:
{t.kind = 120; break;}
+ case 84:
+ {t.kind = 121; break;}
case 85:
- {t.kind = 122; break;}
+ {t.kind = 123; break;}
case 86:
- {t.kind = 124; break;}
+ {t.kind = 125; break;}
case 87:
- {t.kind = 126; break;}
- case 88:
{t.kind = 127; break;}
+ case 88:
+ {t.kind = 128; break;}
case 89:
recEnd = pos; recKind = 20;
if (ch == ':') {AddCh(); goto case 30;}
@@ -908,9 +898,9 @@ public class Scanner {
else if (ch == '=') {AddCh(); goto case 98;}
else {t.kind = 59; break;}
case 93:
- recEnd = pos; recKind = 125;
+ recEnd = pos; recKind = 126;
if (ch == '>') {AddCh(); goto case 34;}
- else {t.kind = 125; break;}
+ else {t.kind = 126; break;}
case 94:
recEnd = pos; recKind = 45;
if (ch == '=') {AddCh(); goto case 99;}
@@ -920,26 +910,26 @@ public class Scanner {
if (ch == '=') {AddCh(); goto case 70;}
else {t.kind = 46; break;}
case 96:
- recEnd = pos; recKind = 118;
+ recEnd = pos; recKind = 119;
if (ch == '=') {AddCh(); goto case 41;}
else if (ch == 'i') {AddCh(); goto case 44;}
- else {t.kind = 118; break;}
+ else {t.kind = 119; break;}
case 97:
- recEnd = pos; recKind = 134;
+ recEnd = pos; recKind = 135;
if (ch == '.') {AddCh(); goto case 47;}
- else {t.kind = 134; break;}
+ else {t.kind = 135; break;}
case 98:
recEnd = pos; recKind = 47;
if (ch == '>') {AddCh(); goto case 75;}
else {t.kind = 47; break;}
case 99:
- recEnd = pos; recKind = 104;
+ recEnd = pos; recKind = 105;
if (ch == '=') {AddCh(); goto case 100;}
- else {t.kind = 104; break;}
+ else {t.kind = 105; break;}
case 100:
- recEnd = pos; recKind = 112;
+ recEnd = pos; recKind = 113;
if (ch == '>') {AddCh(); goto case 73;}
- else {t.kind = 112; break;}
+ else {t.kind = 113; break;}
}
t.val = new String(tval, 0, tlen);