HTMLPurifier_ConfigSchema_Interchange   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 36
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 3
eloc 8
dl 0
loc 36
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A validate() 0 4 1
A addDirective() 0 6 2
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