| 1: | <?php |
| 2: | |
| 3: | /** |
| 4: | * Generic schema interchange format that can be converted to a runtime |
| 5: | * representation (HTMLPurifier_ConfigSchema) or HTML documentation. Members |
| 6: | * are completely validated. |
| 7: | */ |
| 8: | class HTMLPurifier_ConfigSchema_Interchange |
| 9: | { |
| 10: | |
| 11: | /** |
| 12: | * Name of the application this schema is describing. |
| 13: | * @type string |
| 14: | */ |
| 15: | public $name; |
| 16: | |
| 17: | /** |
| 18: | * Array of Directive ID => array(directive info) |
| 19: | * @type HTMLPurifier_ConfigSchema_Interchange_Directive[] |
| 20: | */ |
| 21: | public $directives = array(); |
| 22: | |
| 23: | /** |
| 24: | * Adds a directive array to $directives |
| 25: | * @param HTMLPurifier_ConfigSchema_Interchange_Directive $directive |
| 26: | * @throws HTMLPurifier_ConfigSchema_Exception |
| 27: | */ |
| 28: | public function addDirective($directive) |
| 29: | { |
| 30: | if (isset($this->directives[$i = $directive->id->toString()])) { |
| 31: | throw new HTMLPurifier_ConfigSchema_Exception("Cannot redefine directive '$i'"); |
| 32: | } |
| 33: | $this->directives[$i] = $directive; |
| 34: | } |
| 35: | |
| 36: | /** |
| 37: | * Convenience function to perform standard validation. Throws exception |
| 38: | * on failed validation. |
| 39: | */ |
| 40: | public function validate() |
| 41: | { |
| 42: | $validator = new HTMLPurifier_ConfigSchema_Validator(); |
| 43: | return $validator->validate($this); |
| 44: | } |
| 45: | } |
| 46: | |
| 47: | // vim: et sw=4 sts=4 |
| 48: |