In Files

Class/Module Index [+]

Quicksearch

Celluloid::InstanceMethods

These are methods we don't want added to the Celluloid singleton but to be defined on all classes that use Celluloid

Public Instance Methods

bare_object() click to toggle source

Obtain the bare Ruby object the actor is wrapping. This is useful for only a limited set of use cases like runtime metaprogramming. Interacting directly with the bare object foregoes any kind of thread safety that Celluloid would ordinarily provide you, and the object is guaranteed to be shared with at least the actor thread. Tread carefully.

Bare objects can be identified via inspect output:

>> actor
 => #<Celluloid::Actor(Foo:0x3fefcb77c194)>
>> actor.bare_object
 => #<WARNING: BARE CELLULOID OBJECT (Foo:0x3fefcb77c194)>
# File lib/celluloid.rb, line 276
def bare_object; self; end
Also aliased as: wrapped_object
inspect() click to toggle source
# File lib/celluloid.rb, line 294
def inspect
  return "..." if Celluloid.detect_recursion

  str = "#<"

  if leaked?
    str << Celluloid::BARE_OBJECT_WARNING_MESSAGE
  else
    str << "Celluloid::ActorProxy"
  end

  str << "(#{self.class}:0x#{object_id.to_s(16)})"
  str << " " unless instance_variables.empty?

  instance_variables.each do |ivar|
    next if ivar == Celluloid::OWNER_IVAR
    str << "#{ivar}=#{instance_variable_get(ivar).inspect} "
  end

  str.sub!(/\s$/, '>')
end
leaked?() click to toggle source

Are we being invoked in a different thread from our owner?

# File lib/celluloid.rb, line 280
def leaked?
  @celluloid_owner != Thread.current[:celluloid_actor]
end
name() click to toggle source

Obtain the name of the current actor

# File lib/celluloid.rb, line 290
def name
  Actor.name
end
tap() click to toggle source
# File lib/celluloid.rb, line 284
def tap
  yield current_actor
  current_actor
end
wrapped_object() click to toggle source
Alias for: bare_object

[Validate]

Generated with the Darkfish Rdoc Generator 2.