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: