Fixes in chapter 2
This commit is contained in:
		
							parent
							
								
									e04d421f70
								
							
						
					
					
						commit
						24c26fd8b0
					
				| @ -68,7 +68,7 @@ I'll add 3 functions for iterating through characters of the text: | |||||||
| class Lexer { | class Lexer { | ||||||
|     // ... |     // ... | ||||||
|     private step() { /*...*/ } |     private step() { /*...*/ } | ||||||
|     private done(): bool { return this.index >= this.text.length; } |     private done(): boolean { return this.index >= this.text.length; } | ||||||
|     private current(): string { return this.text[this.index]; } |     private current(): string { return this.text[this.index]; } | ||||||
|     // ... |     // ... | ||||||
| } | } | ||||||
| @ -127,11 +127,8 @@ And a method for creating valueless tokens: | |||||||
| class Lexer { | class Lexer { | ||||||
|     // ... |     // ... | ||||||
|     private token(type: string, pos: Pos): Token { |     private token(type: string, pos: Pos): Token { | ||||||
|         return { |         const length = this.index - pos.index; | ||||||
|             index: this.index, |         return { type, pos, length }; | ||||||
|             line: this.line, |  | ||||||
|             col: this.col, |  | ||||||
|         }; |  | ||||||
|     } |     } | ||||||
|     // ... |     // ... | ||||||
| } | } | ||||||
| @ -142,11 +139,11 @@ And a method for testing/matching the `.current()` against a regex pattern or st | |||||||
| ```ts | ```ts | ||||||
| class Lexer { | class Lexer { | ||||||
|     // ... |     // ... | ||||||
|     private test(pattern: RegExp | string): Token { |     private test(pattern: RegExp | string): boolean { | ||||||
|         if (typeof pattern === "string") |         if (typeof pattern === "string") | ||||||
|             return this.current === pattern; |             return this.current() === pattern; | ||||||
|         else |         else | ||||||
|             return pattern.test(this.current); |             return pattern.test(this.current()); | ||||||
|     } |     } | ||||||
|     // ... |     // ... | ||||||
| } | } | ||||||
| @ -164,7 +161,7 @@ class Lexer { | |||||||
|         // ... |         // ... | ||||||
|         console.error(`Lexer: illegal character '${this.current()}' at ${pos.line}:${pos.col}`); |         console.error(`Lexer: illegal character '${this.current()}' at ${pos.line}:${pos.col}`); | ||||||
|         this.step(); |         this.step(); | ||||||
|         return next(); |         return this.next(); | ||||||
|     } |     } | ||||||
|     // ... |     // ... | ||||||
| } | } | ||||||
| @ -182,21 +179,13 @@ We don't need to know anything about whitespace, so we'll skip over it without m | |||||||
| class Lexer { | class Lexer { | ||||||
|     // ... |     // ... | ||||||
|     public next(): Token | null { |     public next(): Token | null { | ||||||
|         if (this.done()) |         // ... | ||||||
|             return null; |  | ||||||
|         const pos = this.pos(); |  | ||||||
|         if (this.test(/[ \t\n]/)) { |         if (this.test(/[ \t\n]/)) { | ||||||
|             while (!this.done() && this.test(/[ \t\n]/)) |             while (!this.done() && this.test(/[ \t\n]/)) | ||||||
|                 this.step(); |                 this.step(); | ||||||
|             return next(); |             return this.next(); | ||||||
|         } |         } | ||||||
|         // ... |         // ... | ||||||
|         console.error( |  | ||||||
|             `Lexer: illegal character '${this.current()}'` |  | ||||||
|                 + ` at ${pos.line}:${pos.col}`, |  | ||||||
|         ); |  | ||||||
|         this.step(); |  | ||||||
|         return next(); |  | ||||||
|     } |     } | ||||||
|     // ... |     // ... | ||||||
| } | } | ||||||
| @ -216,7 +205,7 @@ class Lexer { | |||||||
|         if (this.test("#")) { |         if (this.test("#")) { | ||||||
|             while (!this.done() && !this.test("\n")) |             while (!this.done() && !this.test("\n")) | ||||||
|                 this.step(); |                 this.step(); | ||||||
|             return next(); |             return this.next(); | ||||||
|         } |         } | ||||||
|         // ... |         // ... | ||||||
|     } |     } | ||||||
| @ -408,7 +397,8 @@ const text = ` | |||||||
| const lexer = new Lexer(text); | const lexer = new Lexer(text); | ||||||
| let token = lexer.next(); | let token = lexer.next(); | ||||||
| while (token !== null) { | while (token !== null) { | ||||||
|     console.log(`Lexed ${token}`); |     const value = token.identValue ?? token.intValue ?? token.stringValue ?? ""; | ||||||
|  |     console.log(`Lexed ${token}(${value})`); | ||||||
|     token = lexer.next(); |     token = lexer.next(); | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user