Skip to content

Commit

Permalink
Zap/Preserve now ignores variables/identifiers that are unrelated (#19)
Browse files Browse the repository at this point in the history
* Zap/Preserve now ignores idents working nearby

* Include registers with operators in checks
  • Loading branch information
DerelictDrone authored Nov 20, 2023
1 parent 95578a1 commit a00b47a
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 3 deletions.
13 changes: 10 additions & 3 deletions lua/wire/client/hlzasm/hc_syntax.lua
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ for i=0,15 do VectorSyntax.MATRIX[i+1] = {tostring(i)} end

--------------------------------------------------------------------------------
-- Compile an opcode (called after if self:MatchToken(TOKEN.OPCODE))
function HCOMP:Opcode() local TOKEN = self.TOKEN
function HCOMP:Opcode() local TOKEN,TOKENSET = self.TOKEN,self.TOKENSET
local opcodeName = self.TokenData
local opcodeNo = self.OpcodeNumber[self.TokenData]
local operandCount = self.OperandCount[opcodeNo]
Expand Down Expand Up @@ -456,7 +456,7 @@ end

--------------------------------------------------------------------------------
-- Compile a variable/function. Returns corresponding labels
function HCOMP:DefineVariable(isFunctionParam,isForwardDecl,isRegisterDecl,isStructMember) local TOKEN = self.TOKEN
function HCOMP:DefineVariable(isFunctionParam,isForwardDecl,isRegisterDecl,isStructMember) local TOKEN,TOKENSET = self.TOKEN,self.TOKENSET
local varType,varSize,isStruct
if self:MatchToken(TOKEN.IDENT) then -- Define structure
varType = self.TokenData
Expand Down Expand Up @@ -752,7 +752,7 @@ end

--------------------------------------------------------------------------------
-- Compile a single statement
function HCOMP:Statement() local TOKEN = self.TOKEN
function HCOMP:Statement() local TOKEN,TOKENSET = self.TOKEN,self.TOKENSET
-- Parse code for absolute labels and define (LABEL:)
if self.CurrentToken == 1 then
while not(self:MatchToken(TOKEN.EOF)) do
Expand Down Expand Up @@ -836,6 +836,13 @@ function HCOMP:Statement() local TOKEN = self.TOKEN
local tokenType = self.TokenType
if self.BlockDepth > 0 then
while self:MatchToken(TOKEN.REGISTER) or self:MatchToken(TOKEN.IDENT) do
-- Don't error on catching a variable being used near a zap/preserve
if self:MatchToken(TOKENSET.OPERATORS) then
-- move back 2 tokens and then re-parse this
self:PreviousToken()
self:PreviousToken()
return self:Statement()
end
if self.TokenType == TOKEN.IDENT then
if self.RegisterIdentities[self.TokenData] then
if tokenType == TOKEN.PRESERVE then
Expand Down
52 changes: 52 additions & 0 deletions lua/wire/client/hlzasm/hc_tokenizer.lua
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,7 @@ end
--------------------------------------------------------------------------------
-- Generate table of all possible tokens
HCOMP.TOKEN = {}
HCOMP.TOKENSET = {} -- Manuallly defined sets of tokens
HCOMP.TOKEN_NAME = {}
HCOMP.TOKEN_NAME2 = {}
local IDX = 1
Expand All @@ -128,6 +129,49 @@ for tokenName,tokenData in pairs(HCOMP.TOKEN_TEXT) do
IDX = IDX + 1
end

HCOMP.TOKENSET.OPERATORS = {
HCOMP.TOKEN.LPAREN,
HCOMP.TOKEN.RPAREN,
HCOMP.TOKEN.LSUBSCR,
HCOMP.TOKEN.RSUBSCR,
HCOMP.TOKEN.TIMES,
HCOMP.TOKEN.SLASH,
HCOMP.TOKEN.MODULUS,
HCOMP.TOKEN.PLUS,
HCOMP.TOKEN.MINUS,
HCOMP.TOKEN.AND,
HCOMP.TOKEN.OR,
HCOMP.TOKEN.XOR,
HCOMP.TOKEN.POWER,
HCOMP.TOKEN.INC,
HCOMP.TOKEN.DEC,
HCOMP.TOKEN.SHL,
HCOMP.TOKEN.SHR,
HCOMP.TOKEN.EQL,
HCOMP.TOKEN.NEQ,
HCOMP.TOKEN.LEQ,
HCOMP.TOKEN.LSS,
HCOMP.TOKEN.GEQ,
HCOMP.TOKEN.GTR,
HCOMP.TOKEN.NOT,
HCOMP.TOKEN.EQUAL,
HCOMP.TOKEN.LAND,
HCOMP.TOKEN.LOR,
HCOMP.TOKEN.EQLADD,
HCOMP.TOKEN.EQLSUB,
HCOMP.TOKEN.EQLMUL,
HCOMP.TOKEN.EQLDIV,
HCOMP.TOKEN.DOT
}

HCOMP.TOKENSET.ASSIGNMENT = {
HCOMP.TOKEN.EQUAL,
HCOMP.TOKEN.EQLADD,
HCOMP.TOKEN.EQLSUB,
HCOMP.TOKEN.EQLMUL,
HCOMP.TOKEN.EQLDIV
}

-- Create lookup tables for faster parsing
HCOMP.PARSER_LOOKUP = {}
for symID,symList in pairs(HCOMP.TOKEN_TEXT) do
Expand Down Expand Up @@ -495,6 +539,14 @@ end

-- Returns true and skips a token if it matches this one
function HCOMP:MatchToken(tok)
if istable(tok) then -- Match against a table of tokens
for _,token in pairs(tok) do
if self:MatchToken(token) then
return true
end
end
return false
end
if not self.Tokens[self.CurrentToken] then
return tok == self.TOKEN.EOF
end
Expand Down

0 comments on commit a00b47a

Please sign in to comment.