mirror of
https://github.com/ParadiseSS13/Paradise.git
synced 2025-12-22 16:21:31 +00:00
More optimizing
This commit is contained in:
@@ -6,8 +6,7 @@
|
||||
An object responsible for breaking up source code into tokens for use by the parser.
|
||||
*/
|
||||
/datum/n_Scanner
|
||||
var/code
|
||||
var/list/charlist
|
||||
var/list/code
|
||||
/*
|
||||
Var: errors
|
||||
A list of fatal errors found by the scanner. If there are any items in this list, then it is not safe to parse the returned tokens.
|
||||
@@ -26,9 +25,8 @@
|
||||
Proc: LoadCode
|
||||
Loads source code.
|
||||
*/
|
||||
/datum/n_Scanner/proc/LoadCode(var/c)
|
||||
/datum/n_Scanner/proc/LoadCode(var/list/c)
|
||||
code=c
|
||||
charlist=string2charlist(code)
|
||||
|
||||
/*
|
||||
Proc: LoadCodeFromFile
|
||||
@@ -102,18 +100,18 @@
|
||||
code - The source code to tokenize.
|
||||
options - An <nS_Options> object used to configure the scanner.
|
||||
*/
|
||||
/datum/n_Scanner/nS_Scanner/New(var/code, var/datum/n_scriptOptions/nS_Options/options)
|
||||
/datum/n_Scanner/nS_Scanner/New(var/list/c, var/datum/n_scriptOptions/nS_Options/options)
|
||||
. = ..()
|
||||
ignore += ascii2text(13) //Carriage return
|
||||
delim += ignore + options.symbols + end_stmt + string_delim
|
||||
src.options = options
|
||||
LoadCode(code)
|
||||
LoadCode(c)
|
||||
|
||||
/datum/n_Scanner/nS_Scanner/Scan() //Creates a list of tokens from source code
|
||||
var/list/tokens = new
|
||||
for(, src.codepos <= charlist.len, src.codepos++)
|
||||
var/char = charlist[codepos]
|
||||
var/nextchar = TCOMMS_SAFE_INDEX(charlist, codepos + 1)
|
||||
for(, src.codepos <= code.len, src.codepos++)
|
||||
var/char = code[codepos]
|
||||
var/nextchar = TCOMMS_SAFE_INDEX(code, codepos + 1)
|
||||
if(char == "\n")
|
||||
line++
|
||||
linepos = codepos
|
||||
@@ -157,12 +155,12 @@
|
||||
*/
|
||||
/datum/n_Scanner/nS_Scanner/proc/ReadString(start)
|
||||
var/buf
|
||||
for(, codepos <= charlist.len, codepos++)//codepos to length(code))
|
||||
var/char = charlist[codepos]
|
||||
for(, codepos <= code.len, codepos++)//codepos to length(code))
|
||||
var/char = code[codepos]
|
||||
switch(char)
|
||||
if("\\") //Backslash (\) encountered in string
|
||||
codepos++ //Skip next character in string, since it was escaped by a backslash
|
||||
char = TCOMMS_SAFE_INDEX(charlist, codepos)
|
||||
char = TCOMMS_SAFE_INDEX(code, codepos)
|
||||
switch(char)
|
||||
if("\\") //Double backslash
|
||||
buf += "\\"
|
||||
@@ -192,13 +190,13 @@
|
||||
Reads characters separated by an item in <delim> into a token.
|
||||
*/
|
||||
/datum/n_Scanner/nS_Scanner/proc/ReadWord()
|
||||
var/char = charlist[codepos]
|
||||
var/char = code[codepos]
|
||||
var/buf
|
||||
|
||||
while(!delim.Find(char))
|
||||
buf += char
|
||||
if(++codepos > length(code)) break
|
||||
char = charlist[codepos]
|
||||
if(++codepos > code.len) break
|
||||
char = code[codepos]
|
||||
|
||||
codepos-- //allow main Scan() proc to read the delimiter
|
||||
if(options.keywords.Find(buf))
|
||||
@@ -211,13 +209,13 @@
|
||||
Reads a symbol into a token.
|
||||
*/
|
||||
/datum/n_Scanner/nS_Scanner/proc/ReadSymbol()
|
||||
var/char = charlist[codepos]
|
||||
var/char = code[codepos]
|
||||
var/buf
|
||||
|
||||
while(options.symbols.Find(buf + char))
|
||||
buf += char
|
||||
if(++codepos > length(code)) break
|
||||
char = charlist[codepos]
|
||||
if(++codepos > code.len) break
|
||||
char = code[codepos]
|
||||
|
||||
codepos-- //allow main Scan() proc to read the next character
|
||||
return new /datum/token/symbol(buf, line, COL)
|
||||
@@ -227,7 +225,7 @@
|
||||
Reads a number into a token.
|
||||
*/
|
||||
/datum/n_Scanner/nS_Scanner/proc/ReadNumber()
|
||||
var/char = charlist[codepos]
|
||||
var/char = code[codepos]
|
||||
var/buf
|
||||
var/dec = 0
|
||||
|
||||
@@ -237,7 +235,7 @@
|
||||
|
||||
buf += char
|
||||
codepos++
|
||||
char = TCOMMS_SAFE_INDEX(charlist, codepos)
|
||||
char = TCOMMS_SAFE_INDEX(code, codepos)
|
||||
|
||||
var/datum/token/number/T = new(buf, line, COL)
|
||||
if(isnull(text2num(buf)))
|
||||
@@ -253,8 +251,8 @@
|
||||
*/
|
||||
|
||||
/datum/n_Scanner/nS_Scanner/proc/ReadComment()
|
||||
var/char = charlist[codepos]
|
||||
var/nextchar = TCOMMS_SAFE_INDEX(charlist, codepos + 1)
|
||||
var/char = code[codepos]
|
||||
var/nextchar = TCOMMS_SAFE_INDEX(code, codepos + 1)
|
||||
var/charstring = char + nextchar
|
||||
var/comm = 1
|
||||
// 1: single-line comment
|
||||
@@ -266,23 +264,23 @@
|
||||
comm = 2 // starts a multi-line comment
|
||||
|
||||
while(comm)
|
||||
if(++codepos > charlist.len)
|
||||
if(++codepos > code.len)
|
||||
break
|
||||
|
||||
if(expectedend) // ending statement expected...
|
||||
char = charlist[codepos]
|
||||
char = code[codepos]
|
||||
if(char == "/") // ending statement found - beak the comment
|
||||
comm = 0
|
||||
break
|
||||
|
||||
if(comm == 2)
|
||||
// multi-line comments are broken by ending statements
|
||||
char = charlist[codepos]
|
||||
char = code[codepos]
|
||||
if(char == "*")
|
||||
expectedend = 1
|
||||
continue
|
||||
else
|
||||
char = charlist[codepos]
|
||||
char = code[codepos]
|
||||
if(char == "\n")
|
||||
comm = 0
|
||||
break
|
||||
|
||||
Reference in New Issue
Block a user