From 4196096ff5eeaefff2133d6ac0afc17f017cdb15 Mon Sep 17 00:00:00 2001 From: Felix Auringer Date: Fri, 31 Jul 2020 17:28:04 +0200 Subject: [PATCH 1/6] Ignore nodes with invalid intervals while building sourceMap --- .../Ohm-Core.package/OhmNode.class/instance/isEmpty.st | 6 ++++++ .../Ohm-Core.package/OhmNode.class/instance/isNotEmpty.st | 4 ++++ .../Ohm-Core.package/OhmNode.class/methodProperties.json | 2 ++ .../OhmSourceMapping.class/instance/defaultExpression..st | 8 ++++---- .../instance/terminalExpression..st | 5 +++-- .../OhmSourceMapping.class/methodProperties.json | 4 ++-- 6 files changed, 21 insertions(+), 8 deletions(-) create mode 100644 packages/Ohm-Core.package/OhmNode.class/instance/isEmpty.st create mode 100644 packages/Ohm-Core.package/OhmNode.class/instance/isNotEmpty.st diff --git a/packages/Ohm-Core.package/OhmNode.class/instance/isEmpty.st b/packages/Ohm-Core.package/OhmNode.class/instance/isEmpty.st new file mode 100644 index 0000000..a48d011 --- /dev/null +++ b/packages/Ohm-Core.package/OhmNode.class/instance/isEmpty.st @@ -0,0 +1,6 @@ +testing +isEmpty + + ^ (self interval length == 0 + or: [ self interval end < 1 ] + or: [ self interval start > self interval stream contents size ]) \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmNode.class/instance/isNotEmpty.st b/packages/Ohm-Core.package/OhmNode.class/instance/isNotEmpty.st new file mode 100644 index 0000000..3af20c8 --- /dev/null +++ b/packages/Ohm-Core.package/OhmNode.class/instance/isNotEmpty.st @@ -0,0 +1,4 @@ +testing +isNotEmpty + + ^ self isEmpty not \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmNode.class/methodProperties.json b/packages/Ohm-Core.package/OhmNode.class/methodProperties.json index e1f4eb8..d7feb19 100644 --- a/packages/Ohm-Core.package/OhmNode.class/methodProperties.json +++ b/packages/Ohm-Core.package/OhmNode.class/methodProperties.json @@ -12,7 +12,9 @@ "initialize" : "pre 11/21/2017 15:29", "interval" : "pre 1/5/2015 15:38", "interval:" : "pre 1/5/2015 15:38", + "isEmpty" : "fau 7/31/2020 16:31", "isListNode" : "pre 3/2/2018 16:08", + "isNotEmpty" : "fau 7/31/2020 16:32", "isRootNode" : "pre 7/13/2020 10:31", "isTerminalNode" : "pre 3/2/2018 16:17", "parent" : "pre 1/21/2015 15:03", diff --git a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st index 715af15..311c73d 100644 --- a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st +++ b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st @@ -1,7 +1,7 @@ standard attributes defaultExpression: aNode - (aNode interval start to: (aNode interval end min: self sourceMap size)) - do: [:index | (self sourceMap at: index) add: aNode]. - - aNode children do: [:c | self value: c]. \ No newline at end of file + aNode isNotEmpty ifTrue:[ aNode interval start + to: aNode interval end + do: [ :index | (self sourceMap at: index) add: aNode ]. + aNode children do: [ :c | self value: c ] ] \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st index b5f178c..30a0b10 100644 --- a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st +++ b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st @@ -1,5 +1,6 @@ standard attributes terminalExpression: aNode - aNode interval start to: aNode interval end do: [:i | - (self sourceMap at: i) add: aNode] \ No newline at end of file + aNode isNotEmpty ifTrue: [ aNode interval start + to: aNode interval end + do: [ :i | (self sourceMap at: i) add: aNode ] ] \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json b/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json index c13f692..9f60554 100644 --- a/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json +++ b/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json @@ -3,7 +3,7 @@ }, "instance" : { "createSourceMapFor:" : "pre 7/31/2020 15:20", - "defaultExpression:" : "pre 7/13/2020 11:02", + "defaultExpression:" : "fau 7/31/2020 16:34", "sourceMap" : "pre 4/29/2020 10:20", "sourceMap:" : "pre 4/29/2020 10:20", - "terminalExpression:" : "pre 7/13/2020 11:01" } } + "terminalExpression:" : "fau 7/31/2020 16:33" } } From 763e9359da2a685022f5f0ed57b0ea9312807f28 Mon Sep 17 00:00:00 2001 From: Felix Auringer Date: Fri, 31 Jul 2020 17:37:06 +0200 Subject: [PATCH 2/6] Fix linting issues --- .../OhmSourceMapping.class/instance/defaultExpression..st | 7 ++++--- .../OhmSourceMapping.class/instance/terminalExpression..st | 7 ++++--- .../OhmSourceMapping.class/methodProperties.json | 4 ++-- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st index 311c73d..cc815ee 100644 --- a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st +++ b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/defaultExpression..st @@ -1,7 +1,8 @@ standard attributes defaultExpression: aNode - aNode isNotEmpty ifTrue:[ aNode interval start - to: aNode interval end - do: [ :index | (self sourceMap at: index) add: aNode ]. + aNode isNotEmpty ifTrue: [ + aNode interval start + to: aNode interval end + do: [ :index | (self sourceMap at: index) add: aNode ]. aNode children do: [ :c | self value: c ] ] \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st index 30a0b10..3a15c1e 100644 --- a/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st +++ b/packages/Ohm-Core.package/OhmSourceMapping.class/instance/terminalExpression..st @@ -1,6 +1,7 @@ standard attributes terminalExpression: aNode - aNode isNotEmpty ifTrue: [ aNode interval start - to: aNode interval end - do: [ :i | (self sourceMap at: i) add: aNode ] ] \ No newline at end of file + aNode isNotEmpty ifTrue: [ + aNode interval start + to: aNode interval end + do: [ :index | (self sourceMap at: index) add: aNode ] ] \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json b/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json index 9f60554..70b8f0c 100644 --- a/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json +++ b/packages/Ohm-Core.package/OhmSourceMapping.class/methodProperties.json @@ -3,7 +3,7 @@ }, "instance" : { "createSourceMapFor:" : "pre 7/31/2020 15:20", - "defaultExpression:" : "fau 7/31/2020 16:34", + "defaultExpression:" : "fau 7/31/2020 17:35", "sourceMap" : "pre 4/29/2020 10:20", "sourceMap:" : "pre 4/29/2020 10:20", - "terminalExpression:" : "fau 7/31/2020 16:33" } } + "terminalExpression:" : "fau 7/31/2020 17:38" } } From 498cb2125a0442c14423cfd21980d90aa03e4ab0 Mon Sep 17 00:00:00 2001 From: Felix Auringer Date: Wed, 29 Jul 2020 16:44:17 +0200 Subject: [PATCH 3/6] Add case labels to OhmExplicitSendsSmalltalk --- .../class/serializedGrammar.st | 5 +++-- .../OhmExplicitSendsSmalltalk.class/methodProperties.json | 2 +- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/class/serializedGrammar.st b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/class/serializedGrammar.st index 2aa66f4..71d22b4 100644 --- a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/class/serializedGrammar.st +++ b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/class/serializedGrammar.st @@ -36,7 +36,7 @@ Expression = Operand CascadedMessages -- operandCascade | UnaryMessageReceiver CascadedMessages -- unaryCascade | BinaryMessageReceiver CascadedMessages -- binaryCascade - | KeywordMessageSend + | KeywordMessageSend --base BinaryMessageSend = BinaryMessageReceiver BinaryMessage? @@ -143,7 +143,8 @@ Pragma = "<" PragmaValues ">" PragmaValues = - KeywordPragma+ | unaryPragma + KeywordPragma+ --keyword + | unaryPragma --unary Pragmas = Pragma* diff --git a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/methodProperties.json b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/methodProperties.json index 38df315..80ab114 100644 --- a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/methodProperties.json +++ b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalk.class/methodProperties.json @@ -1,5 +1,5 @@ { "class" : { - "serializedGrammar" : "pre 7/7/2020 16:08" }, + "serializedGrammar" : "fau 7/29/2020 16:41" }, "instance" : { } } From 461d66f51104da8225b52553fc5ef1b162177068 Mon Sep 17 00:00:00 2001 From: Felix Auringer Date: Thu, 30 Jul 2020 14:52:00 +0200 Subject: [PATCH 4/6] Adapt tests to new case labels of grammar --- ...arParsesConstantReferencesInExpressions.st | 13 +++---- ...UnaryMessageSendsWithProblematicOperand.st | 36 ++++++++++--------- .../methodProperties.json | 4 +-- 3 files changed, 28 insertions(+), 25 deletions(-) diff --git a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesConstantReferencesInExpressions.st b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesConstantReferencesInExpressions.st index d21dced..195f3a3 100644 --- a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesConstantReferencesInExpressions.st +++ b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesConstantReferencesInExpressions.st @@ -3,9 +3,10 @@ testGrammarParsesConstantReferencesInExpressions startRule := #Expression. self shouldParse: 'nil+3' to: #(Expression - (KeywordMessageSend - (KeywordMessageReceiver - (BinaryMessageSend - (BinaryMessageReceiver (UnaryMessageSend (UnaryMessageSend_base (Operand (Literal 'nil'))))) - (BinaryMessage '+3'))) - (_list))) \ No newline at end of file + (Expression_base + (KeywordMessageSend + (KeywordMessageReceiver + (BinaryMessageSend + (BinaryMessageReceiver (UnaryMessageSend (UnaryMessageSend_base (Operand (Literal 'nil'))))) + (BinaryMessage '+3'))) + (_list)))) \ No newline at end of file diff --git a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesUnaryMessageSendsWithProblematicOperand.st b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesUnaryMessageSendsWithProblematicOperand.st index 8b1bcf6..03d881d 100644 --- a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesUnaryMessageSendsWithProblematicOperand.st +++ b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/instance/testGrammarParsesUnaryMessageSendsWithProblematicOperand.st @@ -4,23 +4,25 @@ testGrammarParsesUnaryMessageSendsWithProblematicOperand startRule := #Expression. self shouldParse: '2negated' to: #(Expression - #(KeywordMessageSend - #(KeywordMessageReceiver - #(BinaryMessageSend - #(BinaryMessageReceiver - #(UnaryMessageSend - #(UnaryMessageSend_message - #(UnaryMessageReceiver #(Operand '2')) - #(UnaryMessage 'negated')))))) - #(_list))); + #(Expression_base + #(KeywordMessageSend + #(KeywordMessageReceiver + #(BinaryMessageSend + #(BinaryMessageReceiver + #(UnaryMessageSend + #(UnaryMessageSend_message + #(UnaryMessageReceiver #(Operand '2')) + #(UnaryMessage 'negated')))))) + #(_list)))); shouldParse: 'falseNegated' to: #(Expression - #(KeywordMessageSend - #(KeywordMessageReceiver - #(BinaryMessageSend - #(BinaryMessageReceiver - #(UnaryMessageSend - #(UnaryMessageSend_base - #(Operand 'falseNegated')))))) - #(_list))) + #(Expression_base + #(KeywordMessageSend + #(KeywordMessageReceiver + #(BinaryMessageSend + #(BinaryMessageReceiver + #(UnaryMessageSend + #(UnaryMessageSend_base + #(Operand 'falseNegated')))))) + #(_list)))) \ No newline at end of file diff --git a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/methodProperties.json b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/methodProperties.json index 0e40d4a..c7999c8 100644 --- a/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/methodProperties.json +++ b/packages/Ohm-Grammars.package/OhmExplicitSendsSmalltalkGrammarTest.class/methodProperties.json @@ -7,6 +7,6 @@ "testGrammarDistinguishesOperandAndUnaryCascades" : "pre 7/28/2020 16:13", "testGrammarParsesBinaryMessageChains" : "pre 7/6/2020 12:28", "testGrammarParsesCascadedMessages" : "pre 7/10/2020 13:53", - "testGrammarParsesConstantReferencesInExpressions" : "pre 7/6/2020 15:23", + "testGrammarParsesConstantReferencesInExpressions" : "fau 7/30/2020 14:51", "testGrammarParsesUnaryMessageChains" : "pre 7/6/2020 12:28", - "testGrammarParsesUnaryMessageSendsWithProblematicOperand" : "pre 6/10/2020 18:14" } } + "testGrammarParsesUnaryMessageSendsWithProblematicOperand" : "fau 7/30/2020 14:50" } } From 774c995b07ecd2d254e29e9acf60d6d450fdb519 Mon Sep 17 00:00:00 2001 From: "Patricia.Sowa" Date: Sat, 1 Aug 2020 09:36:41 +0200 Subject: [PATCH 5/6] Add method firstCild --- .../Ohm-Core.package/OhmNode.class/instance/firstChild.st | 4 ++++ packages/Ohm-Core.package/OhmNode.class/methodProperties.json | 1 + 2 files changed, 5 insertions(+) create mode 100644 packages/Ohm-Core.package/OhmNode.class/instance/firstChild.st diff --git a/packages/Ohm-Core.package/OhmNode.class/instance/firstChild.st b/packages/Ohm-Core.package/OhmNode.class/instance/firstChild.st new file mode 100644 index 0000000..2d4f65a --- /dev/null +++ b/packages/Ohm-Core.package/OhmNode.class/instance/firstChild.st @@ -0,0 +1,4 @@ +accessing +firstChild + + ^ self children first \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmNode.class/methodProperties.json b/packages/Ohm-Core.package/OhmNode.class/methodProperties.json index d7feb19..85fb8df 100644 --- a/packages/Ohm-Core.package/OhmNode.class/methodProperties.json +++ b/packages/Ohm-Core.package/OhmNode.class/methodProperties.json @@ -7,6 +7,7 @@ "children" : "pre 1/5/2015 16:06", "children:" : "pre 1/5/2015 16:06", "enclosingRule" : "pre 7/31/2020 15:43", + "firstChild" : "PS 8/1/2020 09:25", "grammar" : "pre 1/5/2015 15:38", "grammar:" : "pre 1/5/2015 15:38", "initialize" : "pre 11/21/2017 15:29", From 617559591d1d52263f0f5bc29eb9c99f9c9ff7d7 Mon Sep 17 00:00:00 2001 From: "Patricia.Sowa" Date: Tue, 4 Aug 2020 05:26:24 +0200 Subject: [PATCH 6/6] Add methods for accessing children size and contents of interval stream --- .../OhmNode.class/instance/numberOfChildren.st | 4 ++++ .../OhmNode.class/instance/unformattedSourceCode.st | 4 ++++ packages/Ohm-Core.package/OhmNode.class/methodProperties.json | 4 +++- 3 files changed, 11 insertions(+), 1 deletion(-) create mode 100644 packages/Ohm-Core.package/OhmNode.class/instance/numberOfChildren.st create mode 100644 packages/Ohm-Core.package/OhmNode.class/instance/unformattedSourceCode.st diff --git a/packages/Ohm-Core.package/OhmNode.class/instance/numberOfChildren.st b/packages/Ohm-Core.package/OhmNode.class/instance/numberOfChildren.st new file mode 100644 index 0000000..0136af1 --- /dev/null +++ b/packages/Ohm-Core.package/OhmNode.class/instance/numberOfChildren.st @@ -0,0 +1,4 @@ +accessing +numberOfChildren + + ^ self children size \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmNode.class/instance/unformattedSourceCode.st b/packages/Ohm-Core.package/OhmNode.class/instance/unformattedSourceCode.st new file mode 100644 index 0000000..0fa1c3e --- /dev/null +++ b/packages/Ohm-Core.package/OhmNode.class/instance/unformattedSourceCode.st @@ -0,0 +1,4 @@ +accessing +unformattedSourceCode + + ^ self interval stream contents \ No newline at end of file diff --git a/packages/Ohm-Core.package/OhmNode.class/methodProperties.json b/packages/Ohm-Core.package/OhmNode.class/methodProperties.json index 85fb8df..09e679f 100644 --- a/packages/Ohm-Core.package/OhmNode.class/methodProperties.json +++ b/packages/Ohm-Core.package/OhmNode.class/methodProperties.json @@ -18,6 +18,7 @@ "isNotEmpty" : "fau 7/31/2020 16:32", "isRootNode" : "pre 7/13/2020 10:31", "isTerminalNode" : "pre 3/2/2018 16:17", + "numberOfChildren" : "fau 8/4/2020 09:03", "parent" : "pre 1/21/2015 15:03", "parent:" : "pre 1/21/2015 15:03", "printStringLimitedTo:" : "pre 6/9/2015 13:39", @@ -26,4 +27,5 @@ "ruleName:" : "pre 1/6/2015 17:15", "skippedSpacesNodes" : "pre 7/10/2020 11:17", "skippedSpacesString" : "pre 7/31/2020 15:47", - "sourceMap" : "pre 7/13/2020 10:32" } } + "sourceMap" : "pre 7/13/2020 10:32", + "unformattedSourceCode" : "PS 8/4/2020 06:24" } }