All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jruby.runtime.builtin.InstanceVariables Maven / Gradle / Ivy

There is a newer version: 9.4.7.0
Show newest version
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package org.jruby.runtime.builtin;

import java.util.List;

/**
 * Interface that represents the instance variable aspect of Ruby
 * objects.
 *
 * @author headius
 */
public interface InstanceVariables {
    //
    // INSTANCE VARIABLE METHODS
    //

    /**
     * Returns true if object has the named instance variable.
     * 
     * @param name the name of an instance variable
     * @return true if object has the named instance variable.
     */
    boolean hasInstanceVariable(String name);

    /**
     * Returns true if object has the named instance variable. The
     * supplied name must have been previously interned.
     * 
     * @param internedName the interned name of an instance variable
     * @return true if object has the named instance variable, else false
     */
    boolean fastHasInstanceVariable(String internedName);
    
    /**
     * Returns the named instance variable if present, else null. 
     * 
     * @param name the name of an instance variable
     * @return the named instance variable if present, else null
     */
    IRubyObject getInstanceVariable(String name);

    /**
     * Returns the named instance variable if present, else null. The
     * supplied name must have been previously interned.
     * 
     * @param internedName the interned name of an instance variable
     * @return he named instance variable if present, else null
     */
    IRubyObject fastGetInstanceVariable(String internedName);

    /**
     * Sets the named instance variable to the specified value.
     * 
     * @param name the name of an instance variable
     * @param value the value to be set
     */    
    IRubyObject setInstanceVariable(String name, IRubyObject value);

    /**
     * Sets the named instance variable to the specified value. The
     * supplied name must have been previously interned.
     * 
     * @param internedName the interned name of an instance variable
     * @param value the value to be set
     */
    IRubyObject fastSetInstanceVariable(String internedName, IRubyObject value);

    /**
     * Removes the named instance variable, if present, returning its
     * value.
     * 
     * @param name the name of the variable to remove
     * @return the value of the remove variable, if present; else null
     */
    IRubyObject removeInstanceVariable(String name);

    /**
     * @return instance variables
     */
    List> getInstanceVariableList();

    /**
     * @return instance variable names
     */
    List getInstanceVariableNameList();

    /**
     * Copies all instance variables from the given object into the receiver
     */
    void copyInstanceVariablesInto(InstanceVariables other);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy