From 35d260a2d6dc34b2b254af709913bb43a5e617e2 Mon Sep 17 00:00:00 2001 From: YellowAfterlife Date: Sat, 17 Oct 2020 14:42:42 +0300 Subject: [PATCH] Some fixes for GMCompFix (don't convert macros, preproc comments for parsing) --- src/VitGML.hx | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/src/VitGML.hx b/src/VitGML.hx index 5296a84..071a0fa 100644 --- a/src/VitGML.hx +++ b/src/VitGML.hx @@ -46,6 +46,7 @@ class VitGML { case "*".code: pos = src.skipComment(pos + 1); } }; + #if !gmv_nc case '#'.code: { // possibly macros or regions if (!src.fastCodeAt(pos).isIdent0()) { // not what we want @@ -94,6 +95,7 @@ class VitGML { } } }; + #end case '@'.code: pos = src.skipAtSignCommon(pos); case '"'.code: pos = src.skipString2(pos); default: @@ -255,8 +257,8 @@ class VitGML { } public static function proc(src:String, ctx:String, isInline:Bool = false):String { - #if !gmv_nc src = escapeComments(src); + #if !gmv_nc src = fixSpaces(src); src = fixVarDecl(src, ctx); if (src.indexOf("?") >= 0) src = replaceTernaryOperators(src, isInline); @@ -323,6 +325,8 @@ class VitGML { } // var flushTill = dotIndex >= 0 ? dotPrefixStart : at; + //trace(src.substring(0, flushTill)); + //trace(src.isStatementBacktrack(flushTill, isInline), remap.statOnly, remap.exprOnly); if (remap.statOnly) { if (!src.isStatementBacktrack(flushTill, isInline)) continue; } else if (remap.exprOnly) { @@ -639,6 +643,7 @@ class VitGML { var id = src.substring(at, pos); var remaps = Ruleset.remaps[id]; var foundRemap:Bool; + //trace(src.substring(pos) + "\n\n"); if (remaps != null) { foundRemap = procRemaps(id, at, remaps); } else do { @@ -651,7 +656,9 @@ class VitGML { var posAtIdentEnd = pos; pos = posAfterIdent + 2; foundRemap = procRemaps("", at, remaps); - if (!foundRemap) pos = posAtIdentEnd; + if (!foundRemap) { + pos = posAtIdentEnd; + } } while (false); if (!foundRemap) { var arr = Ruleset.importsByIdent[id];