Prepended constants with C_ to avoid reserved words as per https://www.php.net/manual...
[htmlpurifier/darkodev.git] / library / HTMLPurifier / ConfigSchema / Builder / Xml.php
blob5fa56f7ddb631646eafac30c5039bdc72b8b768a
1 <?php
3 /**
4 * Converts HTMLPurifier_ConfigSchema_Interchange to an XML format,
5 * which can be further processed to generate documentation.
6 */
7 class HTMLPurifier_ConfigSchema_Builder_Xml extends XMLWriter
10 /**
11 * @type HTMLPurifier_ConfigSchema_Interchange
13 protected $interchange;
15 /**
16 * @type string
18 private $namespace;
20 /**
21 * @param string $html
23 protected function writeHTMLDiv($html)
25 $this->startElement('div');
27 $purifier = HTMLPurifier::getInstance();
28 $html = $purifier->purify($html);
29 $this->writeAttribute('xmlns', 'http://www.w3.org/1999/xhtml');
30 $this->writeRaw($html);
32 $this->endElement(); // div
35 /**
36 * @param mixed $var
37 * @return string
39 protected function export($var)
41 if ($var === array()) {
42 return 'array()';
44 return var_export($var, true);
47 /**
48 * @param HTMLPurifier_ConfigSchema_Interchange $interchange
50 public function build($interchange)
52 // global access, only use as last resort
53 $this->interchange = $interchange;
55 $this->setIndent(true);
56 $this->startDocument('1.0', 'UTF-8');
57 $this->startElement('configdoc');
58 $this->writeElement('title', $interchange->name);
60 foreach ($interchange->directives as $directive) {
61 $this->buildDirective($directive);
64 if ($this->namespace) {
65 $this->endElement();
66 } // namespace
68 $this->endElement(); // configdoc
69 $this->flush();
72 /**
73 * @param HTMLPurifier_ConfigSchema_Interchange_Directive $directive
75 public function buildDirective($directive)
77 // Kludge, although I suppose having a notion of a "root namespace"
78 // certainly makes things look nicer when documentation is built.
79 // Depends on things being sorted.
80 if (!$this->namespace || $this->namespace !== $directive->id->getRootNamespace()) {
81 if ($this->namespace) {
82 $this->endElement();
83 } // namespace
84 $this->namespace = $directive->id->getRootNamespace();
85 $this->startElement('namespace');
86 $this->writeAttribute('id', $this->namespace);
87 $this->writeElement('name', $this->namespace);
90 $this->startElement('directive');
91 $this->writeAttribute('id', $directive->id->toString());
93 $this->writeElement('name', $directive->id->getDirective());
95 $this->startElement('aliases');
96 foreach ($directive->aliases as $alias) {
97 $this->writeElement('alias', $alias->toString());
99 $this->endElement(); // aliases
101 $this->startElement('constraints');
102 if ($directive->version) {
103 $this->writeElement('version', $directive->version);
105 $this->startElement('type');
106 if ($directive->typeAllowsNull) {
107 $this->writeAttribute('allow-null', 'yes');
109 $this->text($directive->type);
110 $this->endElement(); // type
111 if ($directive->allowed) {
112 $this->startElement('allowed');
113 foreach ($directive->allowed as $value => $x) {
114 $this->writeElement('value', $value);
116 $this->endElement(); // allowed
118 $this->writeElement('default', $this->export($directive->default));
119 $this->writeAttribute('xml:space', 'preserve');
120 if ($directive->external) {
121 $this->startElement('external');
122 foreach ($directive->external as $project) {
123 $this->writeElement('project', $project);
125 $this->endElement();
127 $this->endElement(); // constraints
129 if ($directive->deprecatedVersion) {
130 $this->startElement('deprecated');
131 $this->writeElement('version', $directive->deprecatedVersion);
132 $this->writeElement('use', $directive->deprecatedUse->toString());
133 $this->endElement(); // deprecated
136 $this->startElement('description');
137 $this->writeHTMLDiv($directive->description);
138 $this->endElement(); // description
140 $this->endElement(); // directive
144 // vim: et sw=4 sts=4