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.
Files changed (72) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +74 -65
  3. data/Rakefile +35 -21
  4. data/bin/tpp +73 -73
  5. data/lib/tp_plus/interpreter.rb +152 -129
  6. data/lib/tp_plus/namespace.rb +66 -66
  7. data/lib/tp_plus/nodes/abort_node.rb +9 -9
  8. data/lib/tp_plus/nodes/address_node.rb +22 -0
  9. data/lib/tp_plus/nodes/argument_node.rb +20 -19
  10. data/lib/tp_plus/nodes/assignment_node.rb +45 -45
  11. data/lib/tp_plus/nodes/call_node.rb +34 -34
  12. data/lib/tp_plus/nodes/case_condition_node.rb +26 -26
  13. data/lib/tp_plus/nodes/case_node.rb +33 -33
  14. data/lib/tp_plus/nodes/comment_node.rb +22 -22
  15. data/lib/tp_plus/nodes/conditional_node.rb +60 -54
  16. data/lib/tp_plus/nodes/definition_node.rb +22 -22
  17. data/lib/tp_plus/nodes/digit_node.rb +22 -21
  18. data/lib/tp_plus/nodes/empty_stmt_node.rb +9 -0
  19. data/lib/tp_plus/nodes/eval_node.rb +13 -13
  20. data/lib/tp_plus/nodes/expression_node.rb +68 -65
  21. data/lib/tp_plus/nodes/for_node.rb +20 -20
  22. data/lib/tp_plus/nodes/header_node.rb +27 -27
  23. data/lib/tp_plus/nodes/indirect_node.rb +51 -49
  24. data/lib/tp_plus/nodes/inline_conditional_node.rb +40 -40
  25. data/lib/tp_plus/nodes/io_method_node.rb +55 -55
  26. data/lib/tp_plus/nodes/io_node.rb +31 -30
  27. data/lib/tp_plus/nodes/jump_node.rb +23 -23
  28. data/lib/tp_plus/nodes/label_definition_node.rb +21 -21
  29. data/lib/tp_plus/nodes/motion_node.rb +62 -62
  30. data/lib/tp_plus/nodes/namespace_node.rb +16 -16
  31. data/lib/tp_plus/nodes/namespaced_var_node.rb +38 -38
  32. data/lib/tp_plus/nodes/numreg_node.rb +26 -25
  33. data/lib/tp_plus/nodes/offset_node.rb +27 -27
  34. data/lib/tp_plus/nodes/operator_node.rb +78 -72
  35. data/lib/tp_plus/nodes/paren_expression_node.rb +17 -0
  36. data/lib/tp_plus/nodes/pause_node.rb +9 -9
  37. data/lib/tp_plus/nodes/position_data_node.rb +64 -50
  38. data/lib/tp_plus/nodes/position_node.rb +26 -25
  39. data/lib/tp_plus/nodes/posreg_node.rb +64 -48
  40. data/lib/tp_plus/nodes/raise_node.rb +13 -13
  41. data/lib/tp_plus/nodes/real_node.rb +27 -27
  42. data/lib/tp_plus/nodes/set_skip_node.rb +14 -0
  43. data/lib/tp_plus/nodes/skip_node.rb +22 -22
  44. data/lib/tp_plus/nodes/speed_node.rb +29 -29
  45. data/lib/tp_plus/nodes/string_node.rb +13 -13
  46. data/lib/tp_plus/nodes/string_register_node.rb +26 -25
  47. data/lib/tp_plus/nodes/termination_node.rb +23 -18
  48. data/lib/tp_plus/nodes/terminator_node.rb +16 -16
  49. data/lib/tp_plus/nodes/time_node.rb +24 -24
  50. data/lib/tp_plus/nodes/timer_method_node.rb +37 -37
  51. data/lib/tp_plus/nodes/timer_node.rb +16 -21
  52. data/lib/tp_plus/nodes/units_node.rb +20 -20
  53. data/lib/tp_plus/nodes/use_node.rb +21 -21
  54. data/lib/tp_plus/nodes/user_alarm_node.rb +16 -15
  55. data/lib/tp_plus/nodes/var_method_node.rb +23 -23
  56. data/lib/tp_plus/nodes/var_node.rb +39 -39
  57. data/lib/tp_plus/nodes/vision_register_node.rb +22 -21
  58. data/lib/tp_plus/nodes/wait_for_node.rb +54 -54
  59. data/lib/tp_plus/nodes/wait_until_node.rb +65 -65
  60. data/lib/tp_plus/nodes/while_node.rb +42 -36
  61. data/lib/tp_plus/parser.rb +1682 -1592
  62. data/lib/tp_plus/scanner.rb +283 -383
  63. data/lib/tp_plus/token.rb +97 -0
  64. data/lib/tp_plus/version.rb +3 -3
  65. data/lib/tp_plus.rb +66 -62
  66. data/test/test_helper.rb +5 -5
  67. data/test/tp_plus/test_interpreter.rb +1309 -1168
  68. data/test/tp_plus/test_parser.rb +496 -489
  69. data/test/tp_plus/test_scanner.rb +577 -522
  70. data/tp_plus.gemspec +31 -28
  71. metadata +61 -14
  72. 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
- def initialize(type, id)
6
- @type = type
7
- @id = id.to_i
8
- @comment = ""
9
- end
10
-
11
- def requires_mixed_logic?(context)
12
- ["F","SO","SI","DI"].include?(@type) ? true : false
13
- end
14
-
15
- def result
16
- "#{@type}[#{@id}:#{@comment}]"
17
- end
18
-
19
- def eval(context, options={})
20
- s = result
21
-
22
- if options[:disable_mixed_logic]
23
- s = "#{s}=ON"
24
- end
25
-
26
- options[:force_parens] ? "(#{s})" : s
27
- end
28
- end
29
- end
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
- def initialize(id)
6
- @id = id
7
- @comment = ""
8
- end
9
-
10
- def requires_mixed_logic?(context)
11
- false
12
- end
13
-
14
- def comment_string
15
- return "" if @comment == ""
16
-
17
- ":#{@comment}"
18
- end
19
-
20
- def eval(context,options={})
21
- "R[#{@id}#{comment_string}]"
22
- end
23
- end
24
- end
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
- end
53
- else
54
- case @string
55
- when "=="
56
- "="
57
- when "!="
58
- "<>"
59
- when "&&"
60
- " AND "
61
- when "||"
62
- " OR "
63
- when "%"
64
- " MOD "
65
- else
66
- "#{@string}"
67
- end
68
- end
69
- end
70
- end
71
- end
72
- end
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