tp_plus 0.0.73 → 0.0.74
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +74 -65
- data/Rakefile +35 -21
- data/bin/tpp +73 -73
- data/lib/tp_plus/interpreter.rb +152 -129
- data/lib/tp_plus/namespace.rb +66 -66
- data/lib/tp_plus/nodes/abort_node.rb +9 -9
- data/lib/tp_plus/nodes/address_node.rb +22 -0
- data/lib/tp_plus/nodes/argument_node.rb +20 -19
- data/lib/tp_plus/nodes/assignment_node.rb +45 -45
- data/lib/tp_plus/nodes/call_node.rb +34 -34
- data/lib/tp_plus/nodes/case_condition_node.rb +26 -26
- data/lib/tp_plus/nodes/case_node.rb +33 -33
- data/lib/tp_plus/nodes/comment_node.rb +22 -22
- data/lib/tp_plus/nodes/conditional_node.rb +60 -54
- data/lib/tp_plus/nodes/definition_node.rb +22 -22
- data/lib/tp_plus/nodes/digit_node.rb +22 -21
- data/lib/tp_plus/nodes/empty_stmt_node.rb +9 -0
- data/lib/tp_plus/nodes/eval_node.rb +13 -13
- data/lib/tp_plus/nodes/expression_node.rb +68 -65
- data/lib/tp_plus/nodes/for_node.rb +20 -20
- data/lib/tp_plus/nodes/header_node.rb +27 -27
- data/lib/tp_plus/nodes/indirect_node.rb +51 -49
- data/lib/tp_plus/nodes/inline_conditional_node.rb +40 -40
- data/lib/tp_plus/nodes/io_method_node.rb +55 -55
- data/lib/tp_plus/nodes/io_node.rb +31 -30
- data/lib/tp_plus/nodes/jump_node.rb +23 -23
- data/lib/tp_plus/nodes/label_definition_node.rb +21 -21
- data/lib/tp_plus/nodes/motion_node.rb +62 -62
- data/lib/tp_plus/nodes/namespace_node.rb +16 -16
- data/lib/tp_plus/nodes/namespaced_var_node.rb +38 -38
- data/lib/tp_plus/nodes/numreg_node.rb +26 -25
- data/lib/tp_plus/nodes/offset_node.rb +27 -27
- data/lib/tp_plus/nodes/operator_node.rb +78 -72
- data/lib/tp_plus/nodes/paren_expression_node.rb +17 -0
- data/lib/tp_plus/nodes/pause_node.rb +9 -9
- data/lib/tp_plus/nodes/position_data_node.rb +64 -50
- data/lib/tp_plus/nodes/position_node.rb +26 -25
- data/lib/tp_plus/nodes/posreg_node.rb +64 -48
- data/lib/tp_plus/nodes/raise_node.rb +13 -13
- data/lib/tp_plus/nodes/real_node.rb +27 -27
- data/lib/tp_plus/nodes/set_skip_node.rb +14 -0
- data/lib/tp_plus/nodes/skip_node.rb +22 -22
- data/lib/tp_plus/nodes/speed_node.rb +29 -29
- data/lib/tp_plus/nodes/string_node.rb +13 -13
- data/lib/tp_plus/nodes/string_register_node.rb +26 -25
- data/lib/tp_plus/nodes/termination_node.rb +23 -18
- data/lib/tp_plus/nodes/terminator_node.rb +16 -16
- data/lib/tp_plus/nodes/time_node.rb +24 -24
- data/lib/tp_plus/nodes/timer_method_node.rb +37 -37
- data/lib/tp_plus/nodes/timer_node.rb +16 -21
- data/lib/tp_plus/nodes/units_node.rb +20 -20
- data/lib/tp_plus/nodes/use_node.rb +21 -21
- data/lib/tp_plus/nodes/user_alarm_node.rb +16 -15
- data/lib/tp_plus/nodes/var_method_node.rb +23 -23
- data/lib/tp_plus/nodes/var_node.rb +39 -39
- data/lib/tp_plus/nodes/vision_register_node.rb +22 -21
- data/lib/tp_plus/nodes/wait_for_node.rb +54 -54
- data/lib/tp_plus/nodes/wait_until_node.rb +65 -65
- data/lib/tp_plus/nodes/while_node.rb +42 -36
- data/lib/tp_plus/parser.rb +1682 -1592
- data/lib/tp_plus/scanner.rb +283 -383
- data/lib/tp_plus/token.rb +97 -0
- data/lib/tp_plus/version.rb +3 -3
- data/lib/tp_plus.rb +66 -62
- data/test/test_helper.rb +5 -5
- data/test/tp_plus/test_interpreter.rb +1309 -1168
- data/test/tp_plus/test_parser.rb +496 -489
- data/test/tp_plus/test_scanner.rb +577 -522
- data/tp_plus.gemspec +31 -28
- metadata +61 -14
- data/lib/tp_plus/nodes/set_node.rb +0 -22
@@ -1,30 +1,31 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class IONode
|
4
|
-
attr_accessor :comment
|
5
|
-
|
6
|
-
|
7
|
-
@
|
8
|
-
@
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class IONode
|
4
|
+
attr_accessor :comment
|
5
|
+
attr_reader :id
|
6
|
+
def initialize(type, id)
|
7
|
+
@type = type
|
8
|
+
@id = id.to_i
|
9
|
+
@comment = ""
|
10
|
+
end
|
11
|
+
|
12
|
+
def requires_mixed_logic?(context)
|
13
|
+
["F","SO","SI","DI"].include?(@type) ? true : false
|
14
|
+
end
|
15
|
+
|
16
|
+
def result
|
17
|
+
"#{@type}[#{@id}:#{@comment}]"
|
18
|
+
end
|
19
|
+
|
20
|
+
def eval(context, options={})
|
21
|
+
s = result
|
22
|
+
|
23
|
+
if options[:disable_mixed_logic]
|
24
|
+
s = "#{s}=ON"
|
25
|
+
end
|
26
|
+
|
27
|
+
options[:force_parens] ? "(#{s})" : s
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -1,23 +1,23 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class JumpNode
|
4
|
-
def initialize(identifier)
|
5
|
-
@identifier = identifier
|
6
|
-
end
|
7
|
-
|
8
|
-
def requires_mixed_logic?(context)
|
9
|
-
false
|
10
|
-
end
|
11
|
-
|
12
|
-
def can_be_inlined?
|
13
|
-
true
|
14
|
-
end
|
15
|
-
|
16
|
-
def eval(context,options={})
|
17
|
-
raise "Label (#{@identifier}) not found" if context.labels[@identifier.to_sym].nil?
|
18
|
-
|
19
|
-
"JMP LBL[#{context.labels[@identifier.to_sym]}]"
|
20
|
-
end
|
21
|
-
end
|
22
|
-
end
|
23
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class JumpNode
|
4
|
+
def initialize(identifier)
|
5
|
+
@identifier = identifier
|
6
|
+
end
|
7
|
+
|
8
|
+
def requires_mixed_logic?(context)
|
9
|
+
false
|
10
|
+
end
|
11
|
+
|
12
|
+
def can_be_inlined?
|
13
|
+
true
|
14
|
+
end
|
15
|
+
|
16
|
+
def eval(context,options={})
|
17
|
+
raise "Label (#{@identifier}) not found" if context.labels[@identifier.to_sym].nil?
|
18
|
+
|
19
|
+
"JMP LBL[#{context.labels[@identifier.to_sym]}]"
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -1,21 +1,21 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class LabelDefinitionNode
|
4
|
-
attr_reader :identifier
|
5
|
-
def initialize(identifier)
|
6
|
-
@identifier = identifier
|
7
|
-
end
|
8
|
-
|
9
|
-
def long_identifier_comment(context)
|
10
|
-
return "" unless @identifier.length > 16
|
11
|
-
|
12
|
-
" ;\n! #{@identifier}"
|
13
|
-
end
|
14
|
-
|
15
|
-
def eval(context)
|
16
|
-
#context.add_label(@identifier)
|
17
|
-
"LBL[#{context.labels[@identifier.to_sym]}:#{@identifier[0,16]}]#{long_identifier_comment(context)}"
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class LabelDefinitionNode
|
4
|
+
attr_reader :identifier
|
5
|
+
def initialize(identifier)
|
6
|
+
@identifier = identifier
|
7
|
+
end
|
8
|
+
|
9
|
+
def long_identifier_comment(context)
|
10
|
+
return "" unless @identifier.length > 16
|
11
|
+
|
12
|
+
" ;\n! #{@identifier}"
|
13
|
+
end
|
14
|
+
|
15
|
+
def eval(context)
|
16
|
+
#context.add_label(@identifier)
|
17
|
+
"LBL[#{context.labels[@identifier.to_sym]}:#{@identifier[0,16]}]#{long_identifier_comment(context)}"
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -1,62 +1,62 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class MotionNode
|
4
|
-
def initialize(type, destination, modifiers)
|
5
|
-
@type = type
|
6
|
-
@destination = destination
|
7
|
-
@modifiers = modifiers
|
8
|
-
end
|
9
|
-
|
10
|
-
def prefix
|
11
|
-
case @type
|
12
|
-
when "linear_move"
|
13
|
-
"L"
|
14
|
-
when "joint_move"
|
15
|
-
"J"
|
16
|
-
when "circular_move"
|
17
|
-
"C"
|
18
|
-
else
|
19
|
-
raise "Unsupported motion"
|
20
|
-
end
|
21
|
-
end
|
22
|
-
|
23
|
-
def speed_node
|
24
|
-
@speed_node ||= @modifiers.select {|m| m.is_a? SpeedNode }.first
|
25
|
-
end
|
26
|
-
|
27
|
-
def termination_node
|
28
|
-
@termination_node ||= @modifiers.select {|m| m.is_a? TerminationNode }.first
|
29
|
-
end
|
30
|
-
|
31
|
-
def actual_modifiers
|
32
|
-
@actual_modifiers ||= @modifiers.reject {|m| m.is_a? SpeedNode}.reject {|m| m.is_a? TerminationNode }
|
33
|
-
end
|
34
|
-
|
35
|
-
def modifiers_string(context)
|
36
|
-
return "" unless actual_modifiers.any?
|
37
|
-
|
38
|
-
strings_array = [""] << actual_modifiers.map { |m| m.eval(context) }
|
39
|
-
@modifiers_string = strings_array.join(" ")
|
40
|
-
end
|
41
|
-
|
42
|
-
def speed_valid?(context)
|
43
|
-
case @type
|
44
|
-
when "linear_move"
|
45
|
-
return true if speed_node.eval(context) == "max_speed"
|
46
|
-
|
47
|
-
["mm/sec"].include? speed_node.units
|
48
|
-
when "joint_move"
|
49
|
-
return false if speed_node.eval(context) == "max_speed"
|
50
|
-
|
51
|
-
["%"].include? speed_node.units
|
52
|
-
end
|
53
|
-
end
|
54
|
-
|
55
|
-
def eval(context)
|
56
|
-
raise "Speed is invalid for motion type" unless speed_valid?(context)
|
57
|
-
|
58
|
-
"#{prefix} #{@destination.eval(context)} #{speed_node.eval(context)} #{termination_node.eval(context)}#{modifiers_string(context)}"
|
59
|
-
end
|
60
|
-
end
|
61
|
-
end
|
62
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class MotionNode
|
4
|
+
def initialize(type, destination, modifiers)
|
5
|
+
@type = type
|
6
|
+
@destination = destination
|
7
|
+
@modifiers = modifiers
|
8
|
+
end
|
9
|
+
|
10
|
+
def prefix
|
11
|
+
case @type
|
12
|
+
when "linear_move"
|
13
|
+
"L"
|
14
|
+
when "joint_move"
|
15
|
+
"J"
|
16
|
+
when "circular_move"
|
17
|
+
"C"
|
18
|
+
else
|
19
|
+
raise "Unsupported motion"
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
def speed_node
|
24
|
+
@speed_node ||= @modifiers.select {|m| m.is_a? SpeedNode }.first
|
25
|
+
end
|
26
|
+
|
27
|
+
def termination_node
|
28
|
+
@termination_node ||= @modifiers.select {|m| m.is_a? TerminationNode }.first
|
29
|
+
end
|
30
|
+
|
31
|
+
def actual_modifiers
|
32
|
+
@actual_modifiers ||= @modifiers.reject {|m| m.is_a? SpeedNode}.reject {|m| m.is_a? TerminationNode }
|
33
|
+
end
|
34
|
+
|
35
|
+
def modifiers_string(context)
|
36
|
+
return "" unless actual_modifiers.any?
|
37
|
+
|
38
|
+
strings_array = [""] << actual_modifiers.map { |m| m.eval(context) }
|
39
|
+
@modifiers_string = strings_array.join(" ")
|
40
|
+
end
|
41
|
+
|
42
|
+
def speed_valid?(context)
|
43
|
+
case @type
|
44
|
+
when "linear_move"
|
45
|
+
return true if speed_node.eval(context) == "max_speed"
|
46
|
+
|
47
|
+
["mm/sec"].include? speed_node.units
|
48
|
+
when "joint_move"
|
49
|
+
return false if speed_node.eval(context) == "max_speed"
|
50
|
+
|
51
|
+
["%"].include? speed_node.units
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
def eval(context)
|
56
|
+
raise "Speed is invalid for motion type" unless speed_valid?(context)
|
57
|
+
|
58
|
+
"#{prefix} #{@destination.eval(context)} #{speed_node.eval(context)} #{termination_node.eval(context)}#{modifiers_string(context)}"
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
@@ -1,16 +1,16 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class NamespaceNode
|
4
|
-
attr_reader :block
|
5
|
-
def initialize(name, block)
|
6
|
-
@name = name
|
7
|
-
@block = block
|
8
|
-
end
|
9
|
-
|
10
|
-
def eval(context)
|
11
|
-
context.add_namespace(@name, @block)
|
12
|
-
nil
|
13
|
-
end
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class NamespaceNode
|
4
|
+
attr_reader :block
|
5
|
+
def initialize(name, block)
|
6
|
+
@name = name
|
7
|
+
@block = block
|
8
|
+
end
|
9
|
+
|
10
|
+
def eval(context)
|
11
|
+
context.add_namespace(@name, @block)
|
12
|
+
nil
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -1,38 +1,38 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class NamespacedVarNode
|
4
|
-
attr_reader :namespaces
|
5
|
-
def initialize(namespaces, var_node)
|
6
|
-
@namespaces = namespaces
|
7
|
-
@var_node = var_node
|
8
|
-
end
|
9
|
-
|
10
|
-
def namespace(context)
|
11
|
-
@context = context
|
12
|
-
@namespaces.each do |ns|
|
13
|
-
if @context.get_namespace(ns)
|
14
|
-
@context = @context.get_namespace(ns)
|
15
|
-
end
|
16
|
-
end
|
17
|
-
|
18
|
-
@context
|
19
|
-
end
|
20
|
-
|
21
|
-
def identifier
|
22
|
-
@var_node.identifier
|
23
|
-
end
|
24
|
-
|
25
|
-
def target_node(context)
|
26
|
-
@var_node.target_node(namespace(context))
|
27
|
-
end
|
28
|
-
|
29
|
-
def requires_mixed_logic?(context)
|
30
|
-
@var_node.requires_mixed_logic?(namespace(context))
|
31
|
-
end
|
32
|
-
|
33
|
-
def eval(context,options={})
|
34
|
-
@var_node.eval(namespace(context), options)
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class NamespacedVarNode
|
4
|
+
attr_reader :namespaces
|
5
|
+
def initialize(namespaces, var_node)
|
6
|
+
@namespaces = namespaces
|
7
|
+
@var_node = var_node
|
8
|
+
end
|
9
|
+
|
10
|
+
def namespace(context)
|
11
|
+
@context = context
|
12
|
+
@namespaces.each do |ns|
|
13
|
+
if @context.get_namespace(ns)
|
14
|
+
@context = @context.get_namespace(ns)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
@context
|
19
|
+
end
|
20
|
+
|
21
|
+
def identifier
|
22
|
+
@var_node.identifier
|
23
|
+
end
|
24
|
+
|
25
|
+
def target_node(context)
|
26
|
+
@var_node.target_node(namespace(context))
|
27
|
+
end
|
28
|
+
|
29
|
+
def requires_mixed_logic?(context)
|
30
|
+
@var_node.requires_mixed_logic?(namespace(context))
|
31
|
+
end
|
32
|
+
|
33
|
+
def eval(context,options={})
|
34
|
+
@var_node.eval(namespace(context), options)
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -1,25 +1,26 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class NumregNode
|
4
|
-
attr_accessor :comment
|
5
|
-
|
6
|
-
|
7
|
-
@
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class NumregNode
|
4
|
+
attr_accessor :comment
|
5
|
+
attr_reader :id
|
6
|
+
def initialize(id)
|
7
|
+
@id = id
|
8
|
+
@comment = ""
|
9
|
+
end
|
10
|
+
|
11
|
+
def requires_mixed_logic?(context)
|
12
|
+
false
|
13
|
+
end
|
14
|
+
|
15
|
+
def comment_string
|
16
|
+
return "" if @comment == ""
|
17
|
+
|
18
|
+
":#{@comment}"
|
19
|
+
end
|
20
|
+
|
21
|
+
def eval(context,options={})
|
22
|
+
"R[#{@id}#{comment_string}]"
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -1,27 +1,27 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class OffsetNode
|
4
|
-
def initialize(type, var)
|
5
|
-
@type = type
|
6
|
-
@var = var
|
7
|
-
end
|
8
|
-
|
9
|
-
def name
|
10
|
-
case @type.downcase
|
11
|
-
when "offset"
|
12
|
-
"Offset"
|
13
|
-
when "tool_offset"
|
14
|
-
"Tool_Offset"
|
15
|
-
when "vision_offset"
|
16
|
-
"VOFFSET"
|
17
|
-
else
|
18
|
-
raise "Invalid type"
|
19
|
-
end
|
20
|
-
end
|
21
|
-
|
22
|
-
def eval(context)
|
23
|
-
"#{name},#{@var.eval(context)}"
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
27
|
-
end
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class OffsetNode
|
4
|
+
def initialize(type, var)
|
5
|
+
@type = type
|
6
|
+
@var = var
|
7
|
+
end
|
8
|
+
|
9
|
+
def name
|
10
|
+
case @type.downcase
|
11
|
+
when "offset"
|
12
|
+
"Offset"
|
13
|
+
when "tool_offset"
|
14
|
+
"Tool_Offset"
|
15
|
+
when "vision_offset"
|
16
|
+
"VOFFSET"
|
17
|
+
else
|
18
|
+
raise "Invalid type"
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def eval(context)
|
23
|
+
"#{name},#{@var.eval(context)}"
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -1,72 +1,78 @@
|
|
1
|
-
module TPPlus
|
2
|
-
module Nodes
|
3
|
-
class OperatorNode
|
4
|
-
attr_reader :string
|
5
|
-
def initialize(string)
|
6
|
-
@string = string
|
7
|
-
end
|
8
|
-
|
9
|
-
def bang?
|
10
|
-
@string == "!"
|
11
|
-
end
|
12
|
-
|
13
|
-
def requires_mixed_logic?(context)
|
14
|
-
case @string
|
15
|
-
when "&&", "||", "!"
|
16
|
-
true
|
17
|
-
else
|
18
|
-
false
|
19
|
-
end
|
20
|
-
end
|
21
|
-
|
22
|
-
def boolean?
|
23
|
-
case @string
|
24
|
-
when "&&", "||", "!"#, "==", "<>", ">", ">=", "<", "<="
|
25
|
-
true
|
26
|
-
else
|
27
|
-
false
|
28
|
-
end
|
29
|
-
end
|
30
|
-
|
31
|
-
def eval(context,options={})
|
32
|
-
if options[:opposite]
|
33
|
-
case @string
|
34
|
-
when "=="
|
35
|
-
"<>"
|
36
|
-
when "!=", "<>"
|
37
|
-
"="
|
38
|
-
when ">"
|
39
|
-
"<="
|
40
|
-
when "<"
|
41
|
-
">="
|
42
|
-
when ">="
|
43
|
-
"<"
|
44
|
-
when "<="
|
45
|
-
">"
|
46
|
-
when "!"
|
47
|
-
""
|
48
|
-
when "||"
|
49
|
-
" AND "
|
50
|
-
when "&&"
|
51
|
-
" OR "
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
when "
|
60
|
-
"
|
61
|
-
when "
|
62
|
-
"
|
63
|
-
when "
|
64
|
-
"
|
65
|
-
|
66
|
-
"
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class OperatorNode
|
4
|
+
attr_reader :string
|
5
|
+
def initialize(string)
|
6
|
+
@string = string
|
7
|
+
end
|
8
|
+
|
9
|
+
def bang?
|
10
|
+
@string == "!"
|
11
|
+
end
|
12
|
+
|
13
|
+
def requires_mixed_logic?(context)
|
14
|
+
case @string
|
15
|
+
when "&&", "||", "!"
|
16
|
+
true
|
17
|
+
else
|
18
|
+
false
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def boolean?
|
23
|
+
case @string
|
24
|
+
when "&&", "||", "!"#, "==", "<>", ">", ">=", "<", "<="
|
25
|
+
true
|
26
|
+
else
|
27
|
+
false
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
def eval(context,options={})
|
32
|
+
if options[:opposite]
|
33
|
+
case @string
|
34
|
+
when "=="
|
35
|
+
"<>"
|
36
|
+
when "!=", "<>"
|
37
|
+
"="
|
38
|
+
when ">"
|
39
|
+
"<="
|
40
|
+
when "<"
|
41
|
+
">="
|
42
|
+
when ">="
|
43
|
+
"<"
|
44
|
+
when "<="
|
45
|
+
">"
|
46
|
+
when "!"
|
47
|
+
""
|
48
|
+
when "||"
|
49
|
+
" AND "
|
50
|
+
when "&&"
|
51
|
+
" OR "
|
52
|
+
when "DIV"
|
53
|
+
" MOD "
|
54
|
+
else
|
55
|
+
"#{@string}"
|
56
|
+
end
|
57
|
+
else
|
58
|
+
case @string
|
59
|
+
when "=="
|
60
|
+
"="
|
61
|
+
when "!="
|
62
|
+
"<>"
|
63
|
+
when "&&"
|
64
|
+
" AND "
|
65
|
+
when "||"
|
66
|
+
" OR "
|
67
|
+
when "%"
|
68
|
+
" MOD "
|
69
|
+
when "DIV"
|
70
|
+
" DIV "
|
71
|
+
else
|
72
|
+
"#{@string}"
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
78
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
module TPPlus
|
2
|
+
module Nodes
|
3
|
+
class ParenExpressionNode
|
4
|
+
def initialize(x)
|
5
|
+
@x = x
|
6
|
+
end
|
7
|
+
|
8
|
+
def requires_mixed_logic?(context)
|
9
|
+
@x.requires_mixed_logic?(context)
|
10
|
+
end
|
11
|
+
|
12
|
+
def eval(context, options={})
|
13
|
+
"(#{@x.eval(context, options)})"
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|