4 * Converts HTMLPurifier_ConfigSchema_Interchange to an XML format,
5 * which can be further processed to generate documentation.
7 class HTMLPurifier_ConfigSchema_Builder_Xml
extends XMLWriter
11 * @type HTMLPurifier_ConfigSchema_Interchange
13 protected $interchange;
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
39 protected function export($var)
41 if ($var === array()) {
44 return var_export($var, true);
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) {
68 $this->endElement(); // configdoc
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) {
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);
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