mirror of
				https://bitbucket.org/jsuto/piler.git
				synced 2025-11-04 04:32:28 +01: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
 |