|
Alembic 1.8.11
|
#include <BasePropertyWriter.h>
Public Member Functions | |
| virtual | ~BasePropertyWriter () |
| virtual const PropertyHeader & | getHeader () const =0 |
| const std::string & | getName () const |
| PropertyType | getPropertyType () const |
| bool | isScalar () const |
| bool | isArray () const |
| bool | isCompound () const |
| bool | isSimple () const |
| const MetaData & | getMetaData () const |
| const DataType & | getDataType () const |
| TimeSamplingPtr | getTimeSampling () const |
| virtual ObjectWriterPtr | getObject ()=0 |
| virtual CompoundPropertyWriterPtr | getParent ()=0 |
| virtual ScalarPropertyWriterPtr | asScalarPtr () |
| virtual ArrayPropertyWriterPtr | asArrayPtr () |
| virtual CompoundPropertyWriterPtr | asCompoundPtr () |
The BasePropertyWriter is the base class for all properties, from Simple (which encompasses Scalar and Array properties) to Compound. The functions here establish the things which all properties have in common - name, metaData, propertyType, as well as upcasting capabilities. We don't want to rely on dynamic_cast - it's slow and potentially has problems across DSO interfaces.
|
virtual |
Virtual destructor ...
|
virtual |
Up-cast this base property to an ArrayProperty, if such an upcast is valid. This can be checked with the isArray() function. If the upcast is not valid, an empty pointer will be returned. This default implementation returns an empty pointer.
Reimplemented in Alembic::AbcCoreHDF5::ALEMBIC_VERSION_NS::ApwImpl, and Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::ApwImpl.
|
virtual |
Up-cast this base property to a CompoundProperty, if such an upcast is valid. This can be checked with the isCompound() function. If the upcast is not valid, an empty pointer will be returned. This default implementation returns an empty pointer.
Reimplemented in Alembic::AbcCoreHDF5::ALEMBIC_VERSION_NS::CpwImpl, and Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::CpwImpl.
|
virtual |
Up-cast this base property to a ScalarProperty, if such an upcast is valid. This can be checked with the isScalar() function. If the upcast is not valid, an empty pointer will be returned. This default implementation returns an empty pointer.
Reimplemented in Alembic::AbcCoreHDF5::ALEMBIC_VERSION_NS::SpwImpl, and Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::SpwImpl.
|
inline |
|
pure virtual |
Properties are created with a collection of metadata that is stored in a lightweight structure called PropertyHeader. This returns a constant reference to the PropertyHeader which was given upon creation.
Implemented in Alembic::AbcCoreHDF5::ALEMBIC_VERSION_NS::CpwImpl, Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::ApwImpl, Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::CpwImpl, and Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::SpwImpl.
|
inline |
|
inline |
All properties have a name, which is unique amongst its siblings in the compund property they all live in. This is the name that was given when the property was created, and is part of the property header.
|
pure virtual |
All properties have an object that owns them, and in order to ensure the object stays alive as long as the properties do, they retain a shared pointer to their object.
Implemented in Alembic::AbcCoreHDF5::ALEMBIC_VERSION_NS::CpwImpl, Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::ApwImpl, Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::CpwImpl, and Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::SpwImpl.
|
pure virtual |
Most properties live in a compound property. (Except for the top-compound property in any object) This returns a pointer to the parent compound property.
Implemented in Alembic::AbcCoreHDF5::ALEMBIC_VERSION_NS::CpwImpl, Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::ApwImpl, Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::CpwImpl, and Alembic::AbcCoreOgawa::ALEMBIC_VERSION_NS::SpwImpl.
|
inline |
There are three types of abstract properties. They are Scalar, Array, and Compound properties. This function returns an enum PropertyType which indicates which property type is returned. This is simply a convenience function which returns data from the PropertyHeader.
|
inline |
Non-compound properties have a TimeSampling. It is an error to call this function for CompoundProperties, and an exception will be thrown. This is a convenience function which just returns the TimeSamplingType from the header that was used in creation.
|
inline |
Convenience to return whether the property is array. Same as getPropertyType() == kArrayProperty
|
inline |
Convenience to return whether the property is compound. Same as getPropertyType() == kCompoundProperty
|
inline |
Convenience to return whether the property is scalar. Same as getPropertyType() == kScalarProperty
|
inline |
Convenience to return whether the property is simple (non-compound) Same as getPropertyType() != kCompoundProperty