<?php
/** * Super-class for definition datatype objects, implements serialization * functions for the class. */ abstract class HTMLPurifier_Definition {
/** * Has setup() been called yet? */ public $setup = false;
/** * If true, write out the final definition object to the cache after * setup. This will be true only if all invocations to get a raw * definition object are also optimized. This does not cause file * system thrashing because on subsequent calls the cached object * is used and any writes to the raw definition object are short * circuited. See enduser-customize.html for the high-level * picture. */ public $optimized = null;
/** * What type of definition is it? */ public $type;
/** * Sets up the definition object into the final form, something * not done by the constructor * @param $config HTMLPurifier_Config instance */ abstract protected function doSetup($config);
/** * Setup function that aborts if already setup * @param $config HTMLPurifier_Config instance */ public function setup($config) { if ($this->setup) return; $this->setup = true; $this->doSetup($config); }
}
// vim: et sw=4 sts=4
|