mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2025-01-22 19:11:53 +00:00
145 lines
4.3 KiB
PHP
145 lines
4.3 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* Converts HTMLPurifier_ConfigSchema_Interchange to an XML format,
|
||
|
* which can be further processed to generate documentation.
|
||
|
*/
|
||
|
class HTMLPurifier_ConfigSchema_Builder_Xml extends XMLWriter
|
||
|
{
|
||
|
|
||
|
/**
|
||
|
* @type HTMLPurifier_ConfigSchema_Interchange
|
||
|
*/
|
||
|
protected $interchange;
|
||
|
|
||
|
/**
|
||
|
* @type string
|
||
|
*/
|
||
|
private $namespace;
|
||
|
|
||
|
/**
|
||
|
* @param string $html
|
||
|
*/
|
||
|
protected function writeHTMLDiv($html)
|
||
|
{
|
||
|
$this->startElement('div');
|
||
|
|
||
|
$purifier = HTMLPurifier::getInstance();
|
||
|
$html = $purifier->purify($html);
|
||
|
$this->writeAttribute('xmlns', 'http://www.w3.org/1999/xhtml');
|
||
|
$this->writeRaw($html);
|
||
|
|
||
|
$this->endElement(); // div
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param mixed $var
|
||
|
* @return string
|
||
|
*/
|
||
|
protected function export($var)
|
||
|
{
|
||
|
if ($var === array()) {
|
||
|
return 'array()';
|
||
|
}
|
||
|
return var_export($var, true);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param HTMLPurifier_ConfigSchema_Interchange $interchange
|
||
|
*/
|
||
|
public function build($interchange)
|
||
|
{
|
||
|
// global access, only use as last resort
|
||
|
$this->interchange = $interchange;
|
||
|
|
||
|
$this->setIndent(true);
|
||
|
$this->startDocument('1.0', 'UTF-8');
|
||
|
$this->startElement('configdoc');
|
||
|
$this->writeElement('title', $interchange->name);
|
||
|
|
||
|
foreach ($interchange->directives as $directive) {
|
||
|
$this->buildDirective($directive);
|
||
|
}
|
||
|
|
||
|
if ($this->namespace) {
|
||
|
$this->endElement();
|
||
|
} // namespace
|
||
|
|
||
|
$this->endElement(); // configdoc
|
||
|
$this->flush();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param HTMLPurifier_ConfigSchema_Interchange_Directive $directive
|
||
|
*/
|
||
|
public function buildDirective($directive)
|
||
|
{
|
||
|
// Kludge, although I suppose having a notion of a "root namespace"
|
||
|
// certainly makes things look nicer when documentation is built.
|
||
|
// Depends on things being sorted.
|
||
|
if (!$this->namespace || $this->namespace !== $directive->id->getRootNamespace()) {
|
||
|
if ($this->namespace) {
|
||
|
$this->endElement();
|
||
|
} // namespace
|
||
|
$this->namespace = $directive->id->getRootNamespace();
|
||
|
$this->startElement('namespace');
|
||
|
$this->writeAttribute('id', $this->namespace);
|
||
|
$this->writeElement('name', $this->namespace);
|
||
|
}
|
||
|
|
||
|
$this->startElement('directive');
|
||
|
$this->writeAttribute('id', $directive->id->toString());
|
||
|
|
||
|
$this->writeElement('name', $directive->id->getDirective());
|
||
|
|
||
|
$this->startElement('aliases');
|
||
|
foreach ($directive->aliases as $alias) {
|
||
|
$this->writeElement('alias', $alias->toString());
|
||
|
}
|
||
|
$this->endElement(); // aliases
|
||
|
|
||
|
$this->startElement('constraints');
|
||
|
if ($directive->version) {
|
||
|
$this->writeElement('version', $directive->version);
|
||
|
}
|
||
|
$this->startElement('type');
|
||
|
if ($directive->typeAllowsNull) {
|
||
|
$this->writeAttribute('allow-null', 'yes');
|
||
|
}
|
||
|
$this->text($directive->type);
|
||
|
$this->endElement(); // type
|
||
|
if ($directive->allowed) {
|
||
|
$this->startElement('allowed');
|
||
|
foreach ($directive->allowed as $value => $x) {
|
||
|
$this->writeElement('value', $value);
|
||
|
}
|
||
|
$this->endElement(); // allowed
|
||
|
}
|
||
|
$this->writeElement('default', $this->export($directive->default));
|
||
|
$this->writeAttribute('xml:space', 'preserve');
|
||
|
if ($directive->external) {
|
||
|
$this->startElement('external');
|
||
|
foreach ($directive->external as $project) {
|
||
|
$this->writeElement('project', $project);
|
||
|
}
|
||
|
$this->endElement();
|
||
|
}
|
||
|
$this->endElement(); // constraints
|
||
|
|
||
|
if ($directive->deprecatedVersion) {
|
||
|
$this->startElement('deprecated');
|
||
|
$this->writeElement('version', $directive->deprecatedVersion);
|
||
|
$this->writeElement('use', $directive->deprecatedUse->toString());
|
||
|
$this->endElement(); // deprecated
|
||
|
}
|
||
|
|
||
|
$this->startElement('description');
|
||
|
$this->writeHTMLDiv($directive->description);
|
||
|
$this->endElement(); // description
|
||
|
|
||
|
$this->endElement(); // directive
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// vim: et sw=4 sts=4
|