next up previous contents
Next: Compiler and RTL source Up: Anatomy of a unit Previous: The sections

Creating ppufiles

Creating a new ppufile works almost the same as writing. First you need to init the object and call create:

  ppufile:=new(pppufile,'output.ppu');
  ppufile.create;

After that you can simply write all needed entries. You'll have to take care that you write at least the basic entries for the sections:

  ibendinterface
  ibenddefs
  ibendsyms
  ibendbrowser (only when you've set uf_has_browser!)
  ibendimplementation
  ibend

Writing an entry is a little different than reading it. You need to first put everything in the entry with ppufile.putxxx:

procedure putdata(var b;len:longint);                                       
procedure putbyte(b:byte);                                                  
procedure putword(w:word);                                                  
procedure putlongint(l:longint);                                            
procedure putreal(d:ppureal);                                               
procedure putstring(s:string);

After putting all the things in the entry you need to call ppufile.writeentry(ibnr:byte) where ibnr is the entry number you're writing.

At the end of the file you need to call ppufile.writeheader to write the new header to the file. This takes automatically care of the new size of the ppufile. When that is also done you can call ppufile.close and dispose the object.

Extra functions/variables available for writing are:

ppufile.NewHeader;                                           
ppufile.NewEntry;
This will give you a clean header or entry. Normally called automatically in ppufile.writeentry, so you can't forget it.
ppufile.flush;

to flush the current buffers to the disk

ppufile.do_crc:boolean;
set to false if you don't want that the crc is updated, this is necessary if you write for example the browser data.



Michael Van Canneyt
Thu Sep 10 14:04:11 CEST 1998