From 823515cc4dd4bc984818c9881144366873a1f7c5 Mon Sep 17 00:00:00 2001 From: OpticFusion1 <37254722+OpticFusion1@users.noreply.github.com> Date: Mon, 26 Sep 2022 19:44:11 -0400 Subject: [PATCH] Version 1.8 Added more Dim support StatementFactory#buildVariableInitStatements Added more TODO comments in StatementFactory Updated DataType enum VBSAnalyzer now logs VariableInit classes VariableInit now has getName & setName methods --- pom.xml | 2 +- .../kitsune/parser/vbs/StatementFactory.java | 17 ++++++++++++++--- .../kitsune/parser/vbs/domain/DataType.java | 6 ++++-- .../kitsune/parser/vbs/domain/VariableInit.java | 9 +++++++++ .../impl/analyze/analyzer/vbs/VBSAnalyzer.java | 7 +++++++ 5 files changed, 35 insertions(+), 6 deletions(-) diff --git a/pom.xml b/pom.xml index c3f12fa..c0cf2fe 100644 --- a/pom.xml +++ b/pom.xml @@ -4,7 +4,7 @@ optic_fusion1 Kitsune - 1.7.1 + 1.8 diff --git a/src/main/java/optic_fusion1/kitsune/parser/vbs/StatementFactory.java b/src/main/java/optic_fusion1/kitsune/parser/vbs/StatementFactory.java index 8e8b05b..ed892d3 100644 --- a/src/main/java/optic_fusion1/kitsune/parser/vbs/StatementFactory.java +++ b/src/main/java/optic_fusion1/kitsune/parser/vbs/StatementFactory.java @@ -25,6 +25,8 @@ Sub SubName( param1, param2 ) || Sub SubName(param1,param2) // Or other variants */ // TODO: Implement support for storing the values that variables get set to // TODO: Implement support for parsing operators (=, +, -, /, *, %) +// TODO: Implement support for parsing things like Array(1,2) Array () +// TODO: Implement support for parsing function calls like reader.ReadFromFile WScript.Arguments(0) or WScript.Echo "Found barcode with type '" & reader.GetFoundBarcodeType(i) & "' and value '" & reader.GetFoundBarcodeValue(i) & "'" public class StatementFactory { /* @@ -72,9 +74,18 @@ public static VariableInit buildVariableInitStatements(int index, String lineTri VariableInit vinit = new VariableInit(); vinit.setText(lineTrimmed); vinit.setLineNumber(index); - // TODO: Make private static final Pattern for this Pattern pattern; - Matcher matcher = null; + Matcher matcher; + if (lineTrimmed.contains(":") && lineTrimmed.contains("=")) { + // TODO: Check to see if this REGEX Pattern can be improved + pattern = Pattern.compile("Dim (.*) : (.*) = (.*)", Pattern.CASE_INSENSITIVE); + matcher = pattern.matcher(lineTrimmed); + matcher.find(); + vinit.setName(matcher.group(1)); + vinit.getVariables().add(matcher.group(3)); + return vinit; + } + // TODO: Make private static final Pattern for this if (lineTrimmed.contains("As")) { pattern = Pattern.compile("Dim(.+?)As", Pattern.CASE_INSENSITIVE); matcher = pattern.matcher(lineTrimmed); @@ -180,7 +191,7 @@ public static ConstStatement buildConstStatements(int index, String lineTrimmed) return statement; } - private static final Pattern COMMENT_PATTERN = Pattern.compile("' ? (.*)"); + private static final Pattern COMMENT_PATTERN = Pattern.compile("'(.*)"); public static Comment buildComments(int index, String lineTrimmed) { Matcher matcher = COMMENT_PATTERN.matcher(lineTrimmed); diff --git a/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/DataType.java b/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/DataType.java index c801596..67447d5 100644 --- a/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/DataType.java +++ b/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/DataType.java @@ -2,11 +2,13 @@ public enum DataType { + // TODO: Look to see if there's any other DataTypes that should be added to this STRING("String"), INT("Int"), VAR("var"), - ByVal("ByVal"), - ByRef("ByRef"), + BY_VAL("ByVal"), + BY_REF("ByRef"), + SINGLE("Single"), EMPTY(""); private final String name; diff --git a/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/VariableInit.java b/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/VariableInit.java index f41599a..a0d3013 100644 --- a/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/VariableInit.java +++ b/src/main/java/optic_fusion1/kitsune/parser/vbs/domain/VariableInit.java @@ -5,6 +5,7 @@ public class VariableInit extends Statement { + private String name; private DataType variableType; private List variables = new ArrayList<>(); @@ -25,4 +26,12 @@ public void setVariableType(DataType variableType) { this.variableType = variableType; } + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + } diff --git a/src/main/java/optic_fusion1/kitsune/tool/impl/analyze/analyzer/vbs/VBSAnalyzer.java b/src/main/java/optic_fusion1/kitsune/tool/impl/analyze/analyzer/vbs/VBSAnalyzer.java index 0b35bd9..099b317 100644 --- a/src/main/java/optic_fusion1/kitsune/tool/impl/analyze/analyzer/vbs/VBSAnalyzer.java +++ b/src/main/java/optic_fusion1/kitsune/tool/impl/analyze/analyzer/vbs/VBSAnalyzer.java @@ -8,6 +8,7 @@ import optic_fusion1.kitsune.parser.vbs.domain.MsgBoxStatement; import optic_fusion1.kitsune.parser.vbs.domain.SetStatement; import optic_fusion1.kitsune.parser.vbs.domain.Statement; +import optic_fusion1.kitsune.parser.vbs.domain.VariableInit; import optic_fusion1.kitsune.tool.impl.analyze.analyzer.Analyzer; public class VBSAnalyzer extends Analyzer { @@ -32,6 +33,12 @@ public void analyze(File input) { if (statement instanceof Comment comment) { LOGGER.info("Comment: " + comment.getText()); } + if (statement instanceof VariableInit stmnt) { + LOGGER.info("Name: " + stmnt.getName() + " Variable Type: " + stmnt.getVariableType()); + for (String variable : stmnt.getVariables()) { + LOGGER.info("Variable: " + variable); + } + } } }