class Opal::Nodes::Base
def self.children(*names)
def self.children(*names) names.each_with_index do |name, idx| define_method(name) do @sexp.children[idx] end end end
def self.handle(*types)
def self.handle(*types) types.each do |type| Base.handlers[type] = self end end
def self.handlers
def self.handlers @handlers ||= {} end
def self.truthy_optimize?
def self.truthy_optimize? false end
def add_gvar(name)
def add_gvar(name) scope.add_scope_gvar name end
def add_ivar(name)
def add_ivar(name) scope.add_scope_ivar name end
def add_local(name)
def add_local(name) scope.add_scope_local name.to_sym end
def add_temp(temp)
def add_temp(temp) scope.add_scope_temp temp end
def children
def children @sexp.children end
def class_variable_owner
def class_variable_owner if scope "#{scope.nesting}[#{class_variable_owner_nesting_level}]" else 'Opal.Object' end end
def class_variable_owner_nesting_level
def class_variable_owner_nesting_level cvar_scope = scope nesting_level = 0 while cvar_scope && !cvar_scope.class_scope? # Needs only `class << self`, `module`, and `class` # can increase nesting, but `class` & `module` are # covered by `class_scope?`. nesting_level += 1 if cvar_scope.sclass? cvar_scope = cvar_scope.parent end nesting_level end
def comments
def comments compiler.comments[@sexp.loc] end
def compile
def compile raise 'Not Implemented' end
def compile_to_fragments
def compile_to_fragments return @fragments if defined?(@fragments) @fragments = [] compile @fragments end
def error(msg)
def error(msg) @compiler.error msg end
def expr(sexp)
def expr(sexp) @compiler.process sexp, :expr end
def expr?
def expr? @level == :expr end
def expr_or_empty(sexp)
def expr_or_empty(sexp) sexp && sexp.type != :nil ? expr(sexp) : '' end
def expr_or_nil(sexp)
def expr_or_nil(sexp) sexp ? expr(sexp) : 'nil' end
def fragment(str, loc: true)
def fragment(str, loc: true) Opal::Fragment.new str, scope, loc && @sexp end
def has_rescue_else?
def has_rescue_else? scope.has_rescue_else? end
def helper(name)
def helper(name) @compiler.helper name end
def in_ensure(&block)
def in_ensure(&block) scope.in_ensure(&block) end
def in_ensure?
def in_ensure? scope.in_ensure? end
def in_resbody(&block)
def in_resbody(&block) scope.in_resbody(&block) end
def in_resbody?
def in_resbody? scope.in_resbody? end
def in_rescue(node, &block)
def in_rescue(node, &block) scope.in_rescue(node, &block) end
def in_while?
def in_while? @compiler.in_while? end
def initialize(sexp, level, compiler)
def initialize(sexp, level, compiler) @sexp = sexp @type = sexp.type @level = level @compiler = compiler @compiler.top_scope ||= self end
def process(sexp, level = :expr)
def process(sexp, level = :expr) @compiler.process sexp, level end
def push(*strs)
def push(*strs) strs.each do |str| str = fragment(str) if str.is_a?(String) @fragments << str end end
def recv(sexp)
def recv(sexp) @compiler.process sexp, :recv end
def recv?
def recv? @level == :recv end
def s(type, *children)
def s(type, *children) ::Opal::AST::Node.new(type, children, location: @sexp.loc) end
def scope
def scope @compiler.scope end
def source_location
def source_location expr = @sexp.loc.expression if expr.respond_to? :source_buffer file = expr.source_buffer.name file = "<internal:#{file}>" if file.start_with?("corelib/") file = "<js:#{file}>" if file.end_with?(".js") else file = "(eval)" end line = @sexp.loc.line "['#{file}', #{line}]" end
def stmt(sexp)
def stmt(sexp) @compiler.process sexp, :stmt end
def stmt?
def stmt? @level == :stmt end
def top_scope
def top_scope @compiler.top_scope end
def unshift(*strs)
def unshift(*strs) strs.reverse_each do |str| str = fragment(str) if str.is_a?(String) @fragments.unshift str end end
def while_loop
def while_loop @compiler.instance_variable_get(:@while_loop) end
def with_temp(&block)
def with_temp(&block) @compiler.with_temp(&block) end
def wrap(pre, post)
def wrap(pre, post) unshift pre push post end