Class ClassVariable

java.lang.Object
org.jruby.embed.variable.ClassVariable
All Implemented Interfaces:
BiVariable

public class ClassVariable extends Object
An implementation of BiVariable for a Ruby class variable.
Author:
Yoko Harada <[email protected]>
  • Field Details

    • receiver

      protected final IRubyObject receiver
    • name

      protected final String name
    • javaObject

      protected volatile Object javaObject
    • javaType

      protected volatile Class javaType
    • rubyObject

      protected volatile IRubyObject rubyObject
    • fromRuby

      protected volatile boolean fromRuby
  • Method Details

    • getInstance

      public static BiVariable getInstance(RubyObject receiver, String name, Object... javaObject)
      Returns an instance of this class. This factory method is used when a class variables is put in BiVariableMap. This variable is originated from Java.
      Parameters:
      receiver - Receiver object returned when a script is evaluated.
      name - a variable name
      javaObject - Java object that should be assigned to.
      Returns:
      the instance of ClassVariable
    • retrieve

      public static void retrieve(RubyObject receiver, BiVariableMap vars)
      Retrieves class variables from Ruby after the evaluation.
      Parameters:
      receiver - receiver object returned when a script is evaluated.
      vars - map to save retrieved class variables.
    • retrieveByKey

      public static void retrieveByKey(RubyObject receiver, BiVariableMap vars, String name)
      Retrieves a class variable by key from Ruby runtime after the evaluation. This method is used when eager retrieval is off.
      Parameters:
      receiver - receiver object returned when a script is evaluated.
      vars - map to save retrieved instance variables.
      name - instace varible name
    • getType

      public BiVariable.Type getType()
      Returns enum type of this variable defined in BiVariable.
      Returns:
      this enum type, BiVariable.Type.ClassVariable.
    • isValidName

      public static boolean isValidName(Object name)
      Returns true if the given name is a decent Ruby class variable. Unless returns false.
      Parameters:
      name - is a name to be checked.
      Returns:
      true if the given name is of a Ruby class variable.
    • inject

      public void inject()
      Injects a class variable value to a parsed Ruby script. This method is invoked during EvalUnit#run() is executed.
    • remove

      public void remove()
      Attempts to remove this variable from top self or receiver.
    • updateByJavaObject

      protected void updateByJavaObject(Ruby runtime, Object... values)
    • updateRubyObject

      protected void updateRubyObject(IRubyObject rubyObject)
    • getReceiver

      public IRubyObject getReceiver()
      Description copied from interface: BiVariable
      Returns the original receiver where this variable has been retrieved.
      Specified by:
      getReceiver in interface BiVariable
      Returns:
      an original receiver.
    • isReceiverIdentical

      public boolean isReceiverIdentical(RubyObject receiver)
      Returns true if a given receiver is identical to the receiver this object has.
      Specified by:
      isReceiverIdentical in interface BiVariable
      Returns:
      true if identical otherwise false
    • getName

      public String getName()
      Description copied from interface: BiVariable
      Returns a name of the variable this object holds. The name follows Ruby's naming rule.
      Specified by:
      getName in interface BiVariable
      Returns:
      a name of the variable
    • getJavaObject

      public Object getJavaObject()
      Description copied from interface: BiVariable
      Returns a value of the variable this object holds in Java type.
      Specified by:
      getJavaObject in interface BiVariable
      Returns:
      a value in Java type.
    • setJavaObject

      public void setJavaObject(Ruby runtime, Object javaObject)
      Description copied from interface: BiVariable
      Sets a Java object as a value of this object. At the same time, an equivalent Ruby object is set automatically.
      Specified by:
      setJavaObject in interface BiVariable
      Parameters:
      runtime - is used to convert a Java object to Ruby object.
      javaObject - is a variable value to be set.
    • getRubyObject

      public IRubyObject getRubyObject()
      Description copied from interface: BiVariable
      Returns a value of the variable this object holds in a org.jruby.runtime.builtin.IRubyObject type.
      Specified by:
      getRubyObject in interface BiVariable
      Returns:
      a value in IRubyObject type.
    • setRubyObject

      public void setRubyObject(IRubyObject rubyObject)
      Description copied from interface: BiVariable
      Sets a org.jruby.runtime.builtin.IRubyObject type, Ruby object as a value of this object. At the same time, an equivalent Java object is set automatically.
      Specified by:
      setRubyObject in interface BiVariable
      Parameters:
      rubyObject - is a variable value to be set.
    • getRubyClass

      protected static RubyModule getRubyClass(Ruby runtime)
    • isValidName

      protected static boolean isValidName(String pattern, Object name)