From 99f7b7c2e30cc1466e197cd2a07f647b429c2ee2 Mon Sep 17 00:00:00 2001 From: rusefillc Date: Sat, 1 Jan 2022 23:36:25 -0500 Subject: [PATCH] handling another kind of statement --- .../main/java/com/rusefi/CodeWalkthrough.java | 11 +++++- .../livedata/LiveDataParserSandbox.java | 2 +- .../ui/livedata/LiveDataParserTest.java | 39 ++++++++++++++----- .../ui/livedata/PrintCPP14ParserListener.java | 16 +++----- 4 files changed, 46 insertions(+), 22 deletions(-) diff --git a/java_console/ui/src/main/java/com/rusefi/CodeWalkthrough.java b/java_console/ui/src/main/java/com/rusefi/CodeWalkthrough.java index e2cd115aa6..ac857dc8de 100644 --- a/java_console/ui/src/main/java/com/rusefi/CodeWalkthrough.java +++ b/java_console/ui/src/main/java/com/rusefi/CodeWalkthrough.java @@ -52,6 +52,12 @@ public class CodeWalkthrough { colorStatement(ctx, painter); } + @Override + public void enterExpressionStatement(CPP14Parser.ExpressionStatementContext ctx) { + super.enterExpressionStatement(ctx); + colorStatement(ctx, painter); + } + @Override public void enterJumpStatement(CPP14Parser.JumpStatementContext ctx) { super.enterJumpStatement(ctx); @@ -126,7 +132,10 @@ public class CodeWalkthrough { boolean isAlive = getOverallState(currentState); color = isAlive ? ACTIVE_STATEMENT : INACTIVE_BRANCH; } - painter.paintBackground(color, new Range(ctx)); + Range range = new Range(ctx); + if (log.debugEnabled()) + log.info(color + " for " + sourceCode.substring(range.getStart(), range.getStop())); + painter.paintBackground(color, range); } }, tree); diff --git a/java_console/ui/src/test/java/com/rusefi/livedata/LiveDataParserSandbox.java b/java_console/ui/src/test/java/com/rusefi/livedata/LiveDataParserSandbox.java index a92e31b843..de06b093f6 100644 --- a/java_console/ui/src/test/java/com/rusefi/livedata/LiveDataParserSandbox.java +++ b/java_console/ui/src/test/java/com/rusefi/livedata/LiveDataParserSandbox.java @@ -17,7 +17,7 @@ public class LiveDataParserSandbox { values.put("engineTooSlow", Boolean.TRUE); values.put("engineTooFast", Boolean.FALSE); - VariableValueSource valueSource = name -> values.get(name); + VariableValueSource valueSource = values::get; new FrameHelper(JDialog.EXIT_ON_CLOSE).showFrame(new LiveDataParserPanel(new UIContext(), valueSource, "ac_control.cpp").getContent()); } diff --git a/java_console/ui/src/test/java/com/rusefi/ui/livedata/LiveDataParserTest.java b/java_console/ui/src/test/java/com/rusefi/ui/livedata/LiveDataParserTest.java index 793108410e..c74d9a31bd 100644 --- a/java_console/ui/src/test/java/com/rusefi/ui/livedata/LiveDataParserTest.java +++ b/java_console/ui/src/test/java/com/rusefi/ui/livedata/LiveDataParserTest.java @@ -21,6 +21,24 @@ import static org.mockito.Matchers.eq; import static org.mockito.Mockito.*; public class LiveDataParserTest { + @Test + public void testGreenCode() { + String sourceCode = "void AcController::onSlowCallback() {\n" + + "\tbool isEnabled = getAcState();\n" + + "\n" + + "\tm_acEnabled = isEnabled;\n" + + "\n" + + "\tenginePins.acRelay.setValue(isEnabled);\n" + + "\n" + + "#if EFI_TUNER_STUDIO\n" + + "\tengine->outputChannels.acState = isEnabled;\n" + + "#endif // EFI_TUNER_STUDIO\n" + + "}\n"; + + SourceCodePainter painter = run(name -> null, sourceCode); + verify(painter, times(4)).paintBackground(eq(CodeWalkthrough.ACTIVE_STATEMENT), any()); + } + @Test public void testParsing() { Map values = new TreeMap<>(String.CASE_INSENSITIVE_ORDER); @@ -48,16 +66,8 @@ public class LiveDataParserTest { "return ff;\n" + "}\n"; - SourceCodePainter painter = mock(SourceCodePainter.class); - ParseTree tree = LiveDataParserPanel.getParseTree(sourceCode); + SourceCodePainter painter = run(valueSource, sourceCode); - System.out.println("******************************************* Just print everything for educational purposes"); - new ParseTreeWalker().walk(new PrintCPP14ParserListener(), tree); - - System.out.println("******************************************* Now running FOR REAL"); - - - CodeWalkthrough.applyVariables(valueSource, sourceCode, painter, tree); verify(painter, times(2)).paintForeground(eq(Color.blue), any()); verify(painter).paintBackground(eq(Color.red), any()); @@ -69,6 +79,17 @@ public class LiveDataParserTest { verify(painter, times(3)).paintBackground(eq(CodeWalkthrough.PASSIVE_CODE), any()); } + private SourceCodePainter run(VariableValueSource valueSource, String sourceCode) { + SourceCodePainter painter = mock(SourceCodePainter.class); + ParseTree tree = LiveDataParserPanel.getParseTree(sourceCode); + + System.out.println("******************************************* Just print everything for educational purposes"); + new ParseTreeWalker().walk(new PrintCPP14ParserListener(), tree); + System.out.println("******************************************* Now running FOR REAL"); + CodeWalkthrough.applyVariables(valueSource, sourceCode, painter, tree); + return painter; + } + @Test public void testConfigurationInRealSourceCode() throws IOException, URISyntaxException { String sourceCode = LiveDataParserPanel.getContent(LiveDataParserPanel.class, LiveDataView.BOOST_CONTROL.getFileName()); diff --git a/java_console/ui/src/test/java/com/rusefi/ui/livedata/PrintCPP14ParserListener.java b/java_console/ui/src/test/java/com/rusefi/ui/livedata/PrintCPP14ParserListener.java index e9933bca64..dc7e69c68e 100644 --- a/java_console/ui/src/test/java/com/rusefi/ui/livedata/PrintCPP14ParserListener.java +++ b/java_console/ui/src/test/java/com/rusefi/ui/livedata/PrintCPP14ParserListener.java @@ -601,7 +601,7 @@ public class PrintCPP14ParserListener implements CPP14ParserListener { @Override public void enterLabeledStatement(CPP14Parser.LabeledStatementContext ctx) { - printWithCounter("enterLabeledStatement"); + printWithCounter("enterLabeledStatement " + ctx.getText()); } @@ -613,8 +613,7 @@ public class PrintCPP14ParserListener implements CPP14ParserListener { @Override public void enterExpressionStatement(CPP14Parser.ExpressionStatementContext ctx) { - printWithCounter("enterExpressionStatement"); - + printWithCounter("enterExpressionStatement " + ctx.getText()); } @Override @@ -650,7 +649,6 @@ public class PrintCPP14ParserListener implements CPP14ParserListener { @Override public void enterSelectionStatement(CPP14Parser.SelectionStatementContext ctx) { printWithCounter("CONDITIONAL enterSelectionStatement " + ctx.getText() + " statements" + ctx.statement()); - } @Override @@ -672,26 +670,22 @@ public class PrintCPP14ParserListener implements CPP14ParserListener { @Override public void enterIterationStatement(CPP14Parser.IterationStatementContext ctx) { - printWithCounter("enterIterationStatement"); - + printWithCounter("enterIterationStatement " + ctx.getText()); } @Override public void exitIterationStatement(CPP14Parser.IterationStatementContext ctx) { printWithCounter("exitIterationStatement"); - } @Override public void enterForInitStatement(CPP14Parser.ForInitStatementContext ctx) { printWithCounter("enterForInitStatement"); - } @Override public void exitForInitStatement(CPP14Parser.ForInitStatementContext ctx) { printWithCounter("exitForInitStatement"); - } @Override @@ -732,7 +726,7 @@ public class PrintCPP14ParserListener implements CPP14ParserListener { @Override public void enterDeclarationStatement(CPP14Parser.DeclarationStatementContext ctx) { - printWithCounter("enterDeclarationStatement"); + printWithCounter("enterDeclarationStatement " + ctx.getText()); } @@ -756,7 +750,7 @@ public class PrintCPP14ParserListener implements CPP14ParserListener { @Override public void enterDeclaration(CPP14Parser.DeclarationContext ctx) { - printWithCounter("enterDeclaration"); + printWithCounter("enterDeclaration " + ctx); }