| @@ -12,6 +12,9 @@ | ||
| 12 | 12 | private $locale; | 
| 13 | 13 | private $baseDir; | 
| 14 | 14 | |
| 15 | + /** | |
| 16 | + * @param string $baseDir | |
| 17 | + */ | |
| 15 | 18 |  	public function __construct(\SplObjectStorage $objectStorage, $data, $locale, $baseDir) { | 
| 16 | 19 | $this->dataStorage = $objectStorage; | 
| 17 | 20 | $this->data = $data; | 
| @@ -63,6 +63,9 @@ discard block | ||
| 63 | 63 | return $array; | 
| 64 | 64 | } | 
| 65 | 65 | |
| 66 | + /** | |
| 67 | + * @param \DOMElement $element | |
| 68 | + */ | |
| 66 | 69 |  	private function callFunc($name, $params, $element) { | 
| 67 | 70 |  		if ($name && is_callable([$this->dataFunction, $name])) { | 
| 68 | 71 | return $this->dataFunction->$name($this->parse($params, $element), $element); | 
| @@ -70,6 +73,10 @@ discard block | ||
| 70 | 73 | return false; | 
| 71 | 74 | } | 
| 72 | 75 | |
| 76 | + /** | |
| 77 | + * @param string $remaining | |
| 78 | + * @param \DOMElement $element | |
| 79 | + */ | |
| 73 | 80 |  	private function parseNextValue($remaining, $result, $element) { | 
| 74 | 81 | if (strlen($remaining) > 0 && $remaining[0] == ',') $result = array_merge($result, $this->parse(trim(substr($remaining, 1)), $element)); | 
| 75 | 82 | return $result; | 
| @@ -50,6 +50,9 @@ | ||
| 50 | 50 | return $attr; | 
| 51 | 51 | } | 
| 52 | 52 | |
| 53 | + /** | |
| 54 | + * @param string $comparator | |
| 55 | + */ | |
| 53 | 56 |  	private static function compare($comparator, $a, $b) { | 
| 54 | 57 | if ($comparator == '=') return $a == $b; | 
| 55 | 58 | else if ($comparator == '!=') return $a != $b; | 
| @@ -34,6 +34,10 @@ discard block | ||
| 34 | 34 | return (isset($rules['content-mode'])) ? $rules['content-mode'] : 'append'; | 
| 35 | 35 | } | 
| 36 | 36 | |
| 37 | + /** | |
| 38 | + * @param \DOMElement $element | |
| 39 | + * @param \Transphporm\Hook\PseudoMatcher $pseudoMatcher | |
| 40 | + */ | |
| 37 | 41 |  	private function processPseudo($value, $element, $pseudoMatcher) { | 
| 38 | 42 | $pseudoContent = ['attr', 'header', 'before', 'after']; | 
| 39 | 43 |  		foreach ($pseudoContent as $pseudo) { | 
| @@ -91,6 +95,9 @@ discard block | ||
| 91 | 95 | foreach ($remove as $r) $r->parentNode->removeChild($r); | 
| 92 | 96 | } | 
| 93 | 97 | |
| 98 | + /** | |
| 99 | + * @param \DOMElement $element | |
| 100 | + */ | |
| 94 | 101 |  	private function replaceContent($element, $content) { | 
| 95 | 102 | //If this rule was cached, the elements that were added last time need to be removed prior to running the rule again. | 
| 96 | 103 | $this->removeAdded($element); | 
| @@ -100,12 +107,18 @@ discard block | ||
| 100 | 107 |  		$element->setAttribute('transphporm', 'remove'); | 
| 101 | 108 | } | 
| 102 | 109 | |
| 110 | + /** | |
| 111 | + * @param \DOMElement $element | |
| 112 | + */ | |
| 103 | 113 |  	private function appendContent($element, $content) { | 
| 104 | 114 |  		foreach ($this->getNode($content, $element->ownerDocument) as $node) { | 
| 105 | 115 | $element->appendChild($node); | 
| 106 | 116 | } | 
| 107 | 117 | } | 
| 108 | 118 | |
| 119 | + /** | |
| 120 | + * @param \DOMElement $element | |
| 121 | + */ | |
| 109 | 122 |  	private function removeAllChildren($element) { | 
| 110 | 123 | while ($element->hasChildNodes()) $element->removeChild($element->firstChild); | 
| 111 | 124 | } | 
| @@ -34,6 +34,9 @@ | ||
| 34 | 34 | return false; | 
| 35 | 35 | } | 
| 36 | 36 | |
| 37 | + /** | |
| 38 | + * @param \Transphporm\Hook\PseudoMatcher $pseudoMatcher | |
| 39 | + */ | |
| 37 | 40 |  	private function createHook($newRules, $pseudoMatcher, $properties) { | 
| 38 | 41 | $hook = new \Transphporm\Hook\PropertyHook($newRules, $pseudoMatcher, new \Transphporm\Parser\Value($this->data)); | 
| 39 | 42 | foreach ($properties as $name => $property) $hook->registerProperty($name, $property); | 
| @@ -12,6 +12,9 @@ discard block | ||
| 12 | 12 | private $prefix; | 
| 13 | 13 | private $valueParser; | 
| 14 | 14 | |
| 15 | + /** | |
| 16 | + * @param string $tss | |
| 17 | + */ | |
| 15 | 18 |  	public function __construct($tss, $baseDir, Value $valueParser, $prefix = '') { | 
| 16 | 19 | $this->tss = $this->stripComments($tss, '/*', '*/'); | 
| 17 | 20 | $this->tss = $this->stripComments($this->tss, '//', "\n"); | 
| @@ -38,6 +41,10 @@ discard block | ||
| 38 | 41 | return $rules; | 
| 39 | 42 | } | 
| 40 | 43 | |
| 44 | + /** | |
| 45 | + * @param string $selector | |
| 46 | + * @param integer $index | |
| 47 | + */ | |
| 41 | 48 |  	private function CssToRules($selector, $index, $properties) { | 
| 42 | 49 |  		$parts = explode(',', $selector); | 
| 43 | 50 | $rules = []; | 
| @@ -60,6 +67,11 @@ discard block | ||
| 60 | 67 | return $rules; | 
| 61 | 68 | } | 
| 62 | 69 | |
| 70 | + /** | |
| 71 | + * @param integer $pos | |
| 72 | + * @param integer $next | |
| 73 | + * @param integer $indexStart | |
| 74 | + */ | |
| 63 | 75 |  	private function processingInstructions($tss, $pos, $next, $indexStart) { | 
| 64 | 76 | $rules = []; | 
| 65 | 77 |  		while (($atPos = strpos($tss, '@', $pos)) !== false) { | 
| @@ -90,6 +102,10 @@ discard block | ||
| 90 | 102 | return ($a->depth < $b->depth) ? -1 : 1; | 
| 91 | 103 | } | 
| 92 | 104 | |
| 105 | + /** | |
| 106 | + * @param string $open | |
| 107 | + * @param string $close | |
| 108 | + */ | |
| 93 | 109 |  	private function stripComments($str, $open, $close) { | 
| 94 | 110 | $pos = 0; | 
| 95 | 111 |  		while (($pos = strpos($str, $open, $pos)) !== false) { | 
| @@ -100,6 +116,9 @@ discard block | ||
| 100 | 116 | return $str; | 
| 101 | 117 | } | 
| 102 | 118 | |
| 119 | + /** | |
| 120 | + * @param string $str | |
| 121 | + */ | |
| 103 | 122 |  	private function getProperties($str) { | 
| 104 | 123 | $stringExtractor = new StringExtractor($str); | 
| 105 | 124 |  		$rules = explode(';', $stringExtractor); | 
| @@ -19,6 +19,9 @@ discard block | ||
| 19 | 19 | '\\Transphporm\\Module\\Format' | 
| 20 | 20 | ]; | 
| 21 | 21 | |
| 22 | + /** | |
| 23 | + * @param string $template | |
| 24 | + */ | |
| 22 | 25 |  	public function __construct($template, $tss = '', $modules = null) { | 
| 23 | 26 | $this->template = $template; | 
| 24 | 27 | $this->tss = $tss; | 
| @@ -60,6 +63,11 @@ discard block | ||
| 60 | 63 | return (object) $result; | 
| 61 | 64 | } | 
| 62 | 65 | |
| 66 | + /** | |
| 67 | + * @param Template $template | |
| 68 | + * @param Hook\DataFunction $data | |
| 69 | + * @param FeatureSet $featureSet | |
| 70 | + */ | |
| 63 | 71 |  	private function processRules($template, $data, $featureSet) { | 
| 64 | 72 | $valueParser = new Parser\Value($data); | 
| 65 | 73 |  		foreach ($this->getRules($template, $valueParser) as $rule) { | 
| @@ -68,12 +76,20 @@ discard block | ||
| 68 | 76 | } | 
| 69 | 77 | |
| 70 | 78 | //Add a postprocessing hook. This cleans up anything transphporm has added to the markup which needs to be removed | 
| 79 | + | |
| 80 | + /** | |
| 81 | + * @param Template $template | |
| 82 | + */ | |
| 71 | 83 |  	private function doPostProcessing($template) { | 
| 72 | 84 |  		$template->addHook('//*[@transphporm]', new Hook\PostProcess()); | 
| 73 | 85 | return $template; | 
| 74 | 86 | } | 
| 75 | 87 | |
| 76 | 88 |  	//Process a TSS rule e.g. `ul li {content: "foo"; format: bar} | 
| 89 | + | |
| 90 | + /** | |
| 91 | + * @param Parser\Value $valueParser | |
| 92 | + */ | |
| 77 | 93 |  	private function executeTssRule($rule, $template, $valueParser, $featureSet) { | 
| 78 | 94 | $rule->touch(); | 
| 79 | 95 | $pseudoMatcher = new Hook\PseudoMatcher($rule->pseudo); | 
| @@ -96,6 +112,10 @@ discard block | ||
| 96 | 112 | |
| 97 | 113 | //Load the TSS rules either from a file or as a string | 
| 98 | 114 | //N.b. only files can be cached | 
| 115 | + | |
| 116 | + /** | |
| 117 | + * @param Parser\Value $valueParser | |
| 118 | + */ | |
| 99 | 119 |  	private function getRules($template, $valueParser) {		 | 
| 100 | 120 |  		if (is_file($this->tss)) { | 
| 101 | 121 | $this->baseDir = dirname(realpath($this->tss)) . DIRECTORY_SEPARATOR; | 
| @@ -14,6 +14,9 @@ discard block | ||
| 14 | 14 | return $this->data; | 
| 15 | 15 | } | 
| 16 | 16 | |
| 17 | + /** | |
| 18 | + * @return Hook\Formatter | |
| 19 | + */ | |
| 17 | 20 |  	public function getFormatter() { | 
| 18 | 21 | return $this->formatter; | 
| 19 | 22 | } | 
| @@ -26,6 +29,9 @@ discard block | ||
| 26 | 29 | $this->formatter->register($formatter); | 
| 27 | 30 | } | 
| 28 | 31 | |
| 32 | + /** | |
| 33 | + * @param string $name | |
| 34 | + */ | |
| 29 | 35 |  	public function registerProperty($name, Property $property) { | 
| 30 | 36 | $this->properties[$name] = $property; | 
| 31 | 37 | } |