mirror of
https://github.com/odin-lang/Odin.git
synced 2026-04-19 21:10:30 +00:00
package odin_parser
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
package token
|
||||
package odin_token
|
||||
|
||||
import "core:strings"
|
||||
|
||||
@@ -161,7 +161,6 @@ using Kind :: enum i32 {
|
||||
B_Keyword_End,
|
||||
};
|
||||
|
||||
|
||||
tokens := [len(Kind)]string {
|
||||
"Invalid",
|
||||
"EOF",
|
||||
@@ -295,6 +294,24 @@ tokens := [len(Kind)]string {
|
||||
"",
|
||||
};
|
||||
|
||||
is_literal :: proc(kind: Kind) -> bool do return B_Literal_Begin < kind && kind < B_Literal_End;
|
||||
is_operator :: proc(kind: Kind) -> bool do return B_Operator_Begin < kind && kind < B_Operator_End;
|
||||
is_keyword :: proc(kind: Kind) -> bool do return B_Keyword_Begin < kind && kind < B_Keyword_End;
|
||||
to_string :: proc(kind: Kind) -> string {
|
||||
if min(Kind) <= kind && kind <= max(Kind) {
|
||||
return tokens[kind];
|
||||
}
|
||||
return "Invalid";
|
||||
}
|
||||
|
||||
is_literal :: proc(kind: Kind) -> bool { return B_Literal_Begin < kind && kind < B_Literal_End; }
|
||||
is_operator :: proc(kind: Kind) -> bool {
|
||||
switch kind {
|
||||
case B_Operator_Begin..B_Operator_End:
|
||||
return true;
|
||||
case In, Notin:
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
is_assignment_operator :: proc(kind: Kind) -> bool {
|
||||
return B_Assign_Op_Begin < kind && kind < B_Assign_Op_End || kind == Eq;
|
||||
}
|
||||
is_keyword :: proc(kind: Kind) -> bool { return B_Keyword_Begin < kind && kind < B_Keyword_End; }
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
package tokenizer
|
||||
package odin_tokenizer
|
||||
|
||||
import "core:fmt"
|
||||
import "core:odin/token"
|
||||
@@ -137,7 +137,7 @@ scan_comment :: proc(t: ^Tokenizer) -> string {
|
||||
offset := t.offset-1;
|
||||
next := -1;
|
||||
general: {
|
||||
if t.ch == '/' {
|
||||
if t.ch == '/' || t.ch == '!' { // // #! comments
|
||||
advance_rune(t);
|
||||
for t.ch != '\n' && t.ch >= 0 {
|
||||
advance_rune(t);
|
||||
@@ -519,8 +519,14 @@ scan :: proc(t: ^Tokenizer) -> token.Token {
|
||||
} else {
|
||||
kind = switch2(t, token.Eq, token.Cmp_Eq);
|
||||
}
|
||||
case '!': kind = switch2(t, token.Eq, token.Not_Eq);
|
||||
case '#': kind = token.Hash;
|
||||
case '!': kind = switch2(t, token.Not, token.Not_Eq);
|
||||
case '#':
|
||||
kind = token.Hash;
|
||||
if t.ch == '!' {
|
||||
kind = token.Comment;
|
||||
lit = scan_comment(t);
|
||||
}
|
||||
case '?': kind = token.Question;
|
||||
case '@': kind = token.At;
|
||||
case '$': kind = token.Dollar;
|
||||
case '^': kind = token.Pointer;
|
||||
@@ -559,9 +565,9 @@ scan :: proc(t: ^Tokenizer) -> token.Token {
|
||||
advance_rune(t);
|
||||
kind = token.Arrow_Left;
|
||||
} else {
|
||||
kind = token.Lt;
|
||||
kind = switch4(t, token.Lt, token.Lt_Eq, '<', token.Shl, token.Shl_Eq);
|
||||
}
|
||||
case '>': kind = token.Gt;
|
||||
case '>': kind = switch4(t, token.Gt, token.Gt_Eq, '>', token.Shr,token.Shr_Eq);
|
||||
|
||||
case '≠': kind = token.Not_Eq;
|
||||
case '≤': kind = token.Lt_Eq;
|
||||
@@ -588,7 +594,7 @@ scan :: proc(t: ^Tokenizer) -> token.Token {
|
||||
case '}': kind = token.Close_Brace;
|
||||
case:
|
||||
if ch != utf8.RUNE_BOM {
|
||||
error(t, t.offset, "illegal character %d", ch);
|
||||
error(t, t.offset, "illegal character '%r': %d", ch, ch);
|
||||
}
|
||||
kind = token.Invalid;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user