Module: Opal::Nodes::Helpers
- Included in:
- Base
- Defined in:
- opal/lib/opal/nodes/helpers.rb
Instance Method Summary collapse
-
#conditional_send(recvr) {|receiver_temp| ... } ⇒ Object
Usefule for safe-operator calls: foo&.bar / foo&.bar ||= baz / ...
- #current_indent ⇒ Object
- #empty_line ⇒ Object
- #indent(&block) ⇒ Object
- #js_falsy(sexp) ⇒ Object
- #js_truthy(sexp) ⇒ Object
- #js_truthy_optimize(sexp) ⇒ Object
- #line(*strs) ⇒ Object
-
#mid_to_jsid(mid) ⇒ Object
Converts a ruby method name into its javascript equivalent for a method/function call.
- #property(name) ⇒ Object
- #valid_name?(name) ⇒ Boolean
Instance Method Details
#conditional_send(recvr) {|receiver_temp| ... } ⇒ Object
Usefule for safe-operator calls: foo&.bar / foo&.bar ||= baz / ...
96 97 98 99 100 101 102 103 104 105 |
# File 'opal/lib/opal/nodes/helpers.rb', line 96 def conditional_send(recvr) # temporary variable that stores method receiver receiver_temp = scope.new_temp push "#{receiver_temp} = ", recvr # execute the sexp only if the receiver isn't nil push ", (#{receiver_temp} === nil || #{receiver_temp} == null) ? nil : " yield receiver_temp wrap '(', ')' end |
#current_indent ⇒ Object
33 34 35 |
# File 'opal/lib/opal/nodes/helpers.rb', line 33 def current_indent compiler.parser_indent end |
#empty_line ⇒ Object
42 43 44 |
# File 'opal/lib/opal/nodes/helpers.rb', line 42 def empty_line push "\n" end |
#indent(&block) ⇒ Object
29 30 31 |
# File 'opal/lib/opal/nodes/helpers.rb', line 29 def indent(&block) compiler.indent(&block) end |
#js_falsy(sexp) ⇒ Object
55 56 57 58 59 60 61 62 63 64 65 66 |
# File 'opal/lib/opal/nodes/helpers.rb', line 55 def js_falsy(sexp) if sexp.type == :send mid = sexp.children[1] if mid == :block_given? scope.uses_block! return "#{scope.block_name} === nil" end end helper :falsy [fragment('$falsy('), expr(sexp), fragment(')')] end |
#js_truthy(sexp) ⇒ Object
46 47 48 49 50 51 52 53 |
# File 'opal/lib/opal/nodes/helpers.rb', line 46 def js_truthy(sexp) if optimize = js_truthy_optimize(sexp) return optimize end helper :truthy [fragment('$truthy('), expr(sexp), fragment(')')] end |
#js_truthy_optimize(sexp) ⇒ Object
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 |
# File 'opal/lib/opal/nodes/helpers.rb', line 68 def js_truthy_optimize(sexp) if sexp.type == :send mid = sexp.children[1] receiver_handler_class = (receiver = sexp.children[0]) && compiler.handlers[receiver.type] # Only operator calls on the truthy_optimize? node classes should be optimized. # Monkey patch method calls might return 'self'/aka a bridged instance and need # the nil check - see discussion at https://github.com/opal/opal/pull/1097 allow_optimization_on_type = Compiler::COMPARE.include?(mid.to_s) && receiver_handler_class && receiver_handler_class.truthy_optimize? if allow_optimization_on_type || mid == :block_given? || mid == :"==" expr(sexp) end end end |
#line(*strs) ⇒ Object
37 38 39 40 |
# File 'opal/lib/opal/nodes/helpers.rb', line 37 def line(*strs) push "\n#{current_indent}" push(*strs) end |
#mid_to_jsid(mid) ⇒ Object
Converts a ruby method name into its javascript equivalent for a method/function call. All ruby method names get prefixed with a '$', and if the name is a valid javascript identifier, it will have a '.' prefix (for dot-calling), otherwise it will be wrapped in brackets to use reference notation calling.
21 22 23 24 25 26 27 |
# File 'opal/lib/opal/nodes/helpers.rb', line 21 def mid_to_jsid(mid) if %r{\=|\+|\-|\*|\/|\!|\?|<|\>|\&|\||\^|\%|\~|\[} =~ mid.to_s "['$#{mid}']" else '.$' + mid end end |
#property(name) ⇒ Object
8 9 10 |
# File 'opal/lib/opal/nodes/helpers.rb', line 8 def property(name) valid_name?(name) ? ".#{name}" : "[#{name.inspect}]" end |
#valid_name?(name) ⇒ Boolean
12 13 14 |
# File 'opal/lib/opal/nodes/helpers.rb', line 12 def valid_name?(name) Opal::Rewriters::JsReservedWords.valid_name?(name) end |