Class: Native::Object
  
  
  
  
  
    - Inherits:
 
    - 
      BasicObject
      
    
 
  
  
  
  
  
  
  
      - Includes:
 
      - Wrapper
 
  
  
  
  
  
  
    - Defined in:
 
    - opal/stdlib/native.rb
 
  
  
 
  
    
      Instance Method Summary
      collapse
    
    
  
  
  
  
  
  
  
  
  
  Methods included from Wrapper
  included, #initialize, #to_n
  Dynamic Method Handling
  
    This class handles dynamic methods through the method_missing method
    
  
  
    
  
  
    #method_missing(mid, *args, &block)  ⇒ Object 
  
  
  
  
    
      
321
322
323
324
325
326
327
328
329
330 
     | 
    
      # File 'opal/stdlib/native.rb', line 321
def method_missing(mid, *args, &block)
  %x{
    if (mid.charAt(mid.length - 1) === '=') {
      return #{self[mid.slice(0, mid.length - 1)] = args[0]};
    }
    else {
      return #{::Native.call(@native, mid, *args, &block)};
    }
  }
end
     | 
  
 
  
 
  
    Instance Method Details
    
      
  
  
    #==(other)  ⇒ Object 
  
  
  
  
    
      
256
257
258 
     | 
    
      # File 'opal/stdlib/native.rb', line 256
def ==(other)
  `#{@native} === #{::Native.try_convert(other)}`
end
     | 
  
 
    
      
  
  
    
      
278
279
280
281
282
283
284
285
286
287
288
289 
     | 
    
      # File 'opal/stdlib/native.rb', line 278
def [](key)
  %x{
    var prop = #{@native}[key];
    if (prop instanceof Function) {
      return prop;
    }
    else {
      return #{::Native.call(@native, key)}
    }
  }
end
     | 
  
 
    
      
  
  
    #[]=(key, value)  ⇒ Object 
  
  
  
  
    
      
291
292
293
294
295
296
297
298
299 
     | 
    
      # File 'opal/stdlib/native.rb', line 291
def []=(key, value)
  native = ::Native.try_convert(value)
  if `#{native} === nil`
    `#{@native}[key] = #{value}`
  else
    `#{@native}[key] = #{native}`
  end
end
     | 
  
 
    
      
  
  
    
      
344
345
346 
     | 
    
      # File 'opal/stdlib/native.rb', line 344
def class
  `self.$$class`
end 
     | 
  
 
    
      
  
  
    #each(*args)  ⇒ Object 
  
  
  
  
    
      
264
265
266
267
268
269
270
271
272
273
274
275
276 
     | 
    
      # File 'opal/stdlib/native.rb', line 264
def each(*args)
  if block_given?
    %x{
      for (var key in #{@native}) {
        #{yield `key`, `#{@native}[key]`}
      }
    }
    self
  else
    method_missing(:each, *args)
  end
end
     | 
  
 
    
      
  
  
    #has_key?(name)  ⇒ Boolean 
  
  
    Also known as:
    include?, key?, member?
    
  
  
  
    
      
260
261
262 
     | 
    
      # File 'opal/stdlib/native.rb', line 260
def has_key?(name)
  `Opal.hasOwnProperty.call(#{@native}, #{name})`
end
     | 
  
 
    
      
  
  
    
      
352
353
354 
     | 
    
      # File 'opal/stdlib/native.rb', line 352
def inspect
  "#<Native:#{`String(#{@native})`}>"
end
     | 
  
 
    
      
  
  
    #instance_of?(klass)  ⇒ Boolean 
  
  
  
  
    
      
340
341
342 
     | 
    
      # File 'opal/stdlib/native.rb', line 340
def instance_of?(klass)
  `self.$$class === klass`
end 
     | 
  
 
    
      
  
  
    #is_a?(klass)  ⇒ Boolean 
  
  
    Also known as:
    kind_of?
    
  
  
  
    
      
336
337
338 
     | 
    
      # File 'opal/stdlib/native.rb', line 336
def is_a?(klass)
  `Opal.is_a(self, klass)`
end 
     | 
  
 
    
      
  
  
    #merge!(other)  ⇒ Object 
  
  
  
  
    
      
301
302
303
304
305
306
307
308
309
310
311 
     | 
    
      # File 'opal/stdlib/native.rb', line 301
def merge!(other)
  %x{
    other = #{::Native.convert(other)};
    for (var prop in other) {
      #{@native}[prop] = other[prop];
    }
  }
  self
end
     | 
  
 
    
      
  
  
    
      
332
333
334 
     | 
    
      # File 'opal/stdlib/native.rb', line 332
def nil?
  false
end 
     | 
  
 
    
      
  
  
    #respond_to?(name, include_all = false)  ⇒ Boolean 
  
  
  
  
    
      
313
314
315 
     | 
    
      # File 'opal/stdlib/native.rb', line 313
def respond_to?(name, include_all = false)
  ::Kernel.instance_method(:respond_to?).bind(self).call(name, include_all)
end 
     | 
  
 
    
      
  
  
    #respond_to_missing?(name, include_all = false)  ⇒ Boolean 
  
  
  
  
    
      
317
318
319 
     | 
    
      # File 'opal/stdlib/native.rb', line 317
def respond_to_missing?(name, include_all = false)
  `Opal.hasOwnProperty.call(#{@native}, #{name})`
end
     | 
  
 
    
      
  
  
    #to_a(options = {}, &block)  ⇒ Object 
  
  
  
  
    
      
348
349
350 
     | 
    
      # File 'opal/stdlib/native.rb', line 348
def to_a(options = {}, &block)
  ::Native::Array.new(@native, options, &block).to_a
end
     |