Example: Overloading the Help and Print Procedures
In this example, we create the spaceCraftObject_doc class, which stores a spacecraft’s name and mass. We overload the class’s _overloadHelp, _overloadImpliedPrint,
and _overloadPrint
methods, so that calling the help or print procedures with this class of object results in the output we desire.
The spaceCraftObject_doc object definition and overloaded function method code listed in this section is contained in the procedure file spacecraftobject_doc__define.pro
, and is located in the examples/doc/objects
subdirectory of the IDL distribution. To view the file in an IDL editor window, enter .EDIT spacecraftobject_doc__define.pro
at the IDL command line.
For more information, refer to
FUNCTION spaceCraftObject_doc::Init, type, mass
self.shipType = type
self.shipMass = mass
RETURN, 1
END
FUNCTION spaceCraftObject_doc::_overloadHelp, varname
tempString = varname + ' = ' + '{spaceCraftObject_doc: ' $
+ self.shipType + STRING(self.shipMass) + '}'
RETURN, tempString
END
FUNCTION spaceCraftObject_doc::_overloadPrint
tempString = self.shipType + ' ' + STRING(self.shipMass) $
+ ' kg'
RETURN, tempString
END
FUNCTION spaceCraftObject_doc::_overloadImpliedPrint, varname
return, self->spaceCraftObject_doc::_overloadPrint()
END
PRO spaceCraftObject_doc__define
struct = {spaceCraftObject_doc, INHERITS IDL_Object, $
shipType: '', $
shipMass: 0 }
END
Now enter the following commands in IDL:
IDL> a=SpaceCraftObject_doc('Soyuz', 6650)
IDL> HELP, a
IDL> PRINT, a
IDL> a
IDL prints:
A = {spaceCraftObject_doc: Soyuz 6650}
Soyuz 6650 kg
Soyuz 6650 kg
Notice that for the _overloadImpliedPrint
method we called our _overloadPrint
method. This ensures that we get the same output whether we are using Implied Print or the PRINT procedure.