Laxkit
0.0.7.1
|
For complete interface class listings, see here.
***Insert Laxkit Interfaces tutorial here!!! ***WRITE THIS BETTER!!!!! please note that the below is quite out of date..
Each WhateverData class has three functions to provide easy reading and writing with files. These are:
SomeData::dump_out(FILE *,int indent) SomeData::dump_in(FILE*,int,Attribute**) SomeData::dump_in_atts(Attribute *att)
They use the file format of LaxFiles::Attribute classes. Data elements are delineated with indentation in the file. If you make derived classes from an interface data class, you can use the dump_in/out functions to dump in or out the base elements, then do the elements of the derived class. The dump_in() function by default just does a whole attribute dump in, and then calls dump_in_atts(), so derived classes need only redefine the dump_in_atts() function. This is usually fine, since the Attribute class is much easier to deal with then reading in straight from the file.
An interface can either draw its own data, or it can be passed temporary data to draw through DrawData(Displayer *, SomeData *, anOject *, anObject *). Each case calls the interface's Refresh() function, but the DrawData should replace all relevant state with what makes the temporary data draw appropriately. The refresh function should not push and pop the data's transform. It should assume that the calling code does that. This enables easy implementation of cloning.