This is a general, flexible Context object that is used for callbacks. Instances of this object are used to pass information to the C++ API callbacks that implement a PluginItem.
The main reason context objects are used in XSI is to ensure backward compatibility for XSI plugins. In future versions it will be possible to add additional information and functionality to the context object without changing the signature of the callback routines.
In some cases a specialized class will be provided rather than a basic Context object. Some of these classes derive from Context (as is the case with PPGEventContext) whereas others do not (for example PluginRegistrar).
#include <xsi_context.h>
Public Member Functions | |
Context () | |
~Context () | |
Context (const CRef &in_ref) | |
Context (const Context &in_obj) | |
bool | IsA (siClassID in_ClassID) const |
siClassID | GetClassID () const |
Context & | operator= (const Context &in_obj) |
Context & | operator= (const CRef &in_ref) |
CRef | GetSource () const |
CValue | GetAttribute (const CString &in_AttributeName) |
CStatus | PutAttribute (const CString &in_AttributeName, const CValue &in_val) |
CStatus | PutArrayAttribute (const CString &in_AttributeName, const CRefArray &in_array) |
CRefArray | GetArrayAttribute (const CString &in_AttributeName) const |
CValue | GetUserData () |
CStatus | PutUserData (const CValue &in_val) |
Context | ( | ) |
Default constructor.
~Context | ( | ) |
Default destructor.
bool IsA | ( | siClassID | in_ClassID | ) | const [virtual] |
Returns true if a given class type is compatible with this API class.
in_ClassID | class type. |
Reimplemented from CBase.
Reimplemented in CustomPrimitiveContext, HardwareShaderContext, ICENodeContext, OperatorContext, PPGEventContext, RendererContext, and ToolContext.
siClassID GetClassID | ( | ) | const [virtual] |
Returns the type of the API class.
Implements CBase.
Reimplemented in CustomPrimitiveContext, HardwareShaderContext, ICENodeContext, OperatorContext, PPGEventContext, RendererContext, and ToolContext.
Creates an object from another object.
in_obj | constant class object. |
Creates an object from a reference object. The newly created object is set to empty if the input reference object is not compatible.
in_ref | constant class object. |
Reimplemented in CustomPrimitiveContext, HardwareShaderContext, ICENodeContext, OperatorContext, PPGEventContext, RendererContext, and ToolContext.
CRef GetSource | ( | ) | const |
Returns the object that is the cause of the callback being fired. The type of object returned depends on the callback. For example this returns a CustomProperty object in the context of a Define
callback for a CustomProperty PluginItem, and it returns a PPGLayout object in the context of a DefineLayout
callback. This specific information is documented along with the callbacks of each PluginItem.
Returns an attribute on the context. Attributes are used to provide additional context information above and beyond the object returned by Context::GetSource. Supported attributes, if any, are documented along with the callbacks of each PluginItem.
in_AttributeName | The name of the attribute to get. |
Sets a single attribute value on the context. This is a way to pass additional information or instructions to XSI regarding the outcome of the callback. Supported attributes, if any, are documented along with the callbacks of each PluginItem. If the attribute does not exist it is added, otherwise the existing value is replaced by the new value.
in_AttributeName | The name of the attribute to set. |
in_val | The attribute value to set. |
Sets an attribute value as an array of values on the context. If the attribute does not exist it is added, otherwise the existing value is replaced by the new value.
in_AttributeName | The name of the attribute to set. |
in_array | The attribute values to set. |
Returns an attribute value as an array of values on the context.
in_AttributeName | The name of the attribute to get. |
CValue GetUserData | ( | ) |
Returns the user data stored in the context.
Allows you to store a CValue inside the context object. This is called User Data because XSI does not care about the content or meaning of the data. This information is not persisted. A common use for this feature is to store a pointer to a newly allocated C++ object during an Init
callback, and then to use Context::GetUserData to retrieve the pointer when other callbacks are called.
Init
callback, the object should be destroyed during the Term
callback.in_val | User data to be set. |