class ExecJS::RubyRhinoRuntime::Context

def call(properties, *args)

def call(properties, *args)
  unbox @rhino_context.eval(properties).call(*args)
rescue ::Rhino::JSError => e
  if e.message == "syntax error"
    raise RuntimeError, e.message
  else
    raise ProgramError, e.message
  end
end

def eval(source, options = {})

def eval(source, options = {})
  source = encode(source)
  if /\S/ =~ source
    unbox @rhino_context.eval("(#{source})")
  end
rescue ::Rhino::JSError => e
  if e.message =~ /^syntax error/
    raise RuntimeError, e.message
  else
    raise ProgramError, e.message
  end
end

def exec(source, options = {})

def exec(source, options = {})
  source = encode(source)
  if /\S/ =~ source
    eval "(function(){#{source}})()", options
  end
end

def fix_memory_limit!(context)

Disables bytecode compiling which limits you to 64K scripts
def fix_memory_limit!(context)
  if context.respond_to?(:optimization_level=)
    context.optimization_level = -1
  else
    context.instance_eval { @native.setOptimizationLevel(-1) }
  end
end

def initialize(runtime, source = "")

def initialize(runtime, source = "")
  source = encode(source)
  @rhino_context = ::Rhino::Context.new
  fix_memory_limit! @rhino_context
  @rhino_context.eval(source)
end

def unbox(value)

def unbox(value)
  case value = ::Rhino::to_ruby(value)
  when Java::OrgMozillaJavascript::NativeFunction
    nil
  when Java::OrgMozillaJavascript::NativeObject
    value.inject({}) do |vs, (k, v)|
      case v
      when Java::OrgMozillaJavascript::NativeFunction, ::Rhino::JS::Function
        nil
      else
        vs[k] = unbox(v)
      end
      vs
    end
  when Array
    value.map { |v| unbox(v) }
  else
    value
  end
end