| @@ -9,7 +9,9 @@ discard block | ||
| 9 | 9 |  class Nth implements \Transphporm\Pseudo { | 
| 10 | 10 | |
| 11 | 11 |  	public function match($name, $args, \DomElement $element) { | 
| 12 | - if ($name !== 'nth-child') return true; | |
| 12 | +		if ($name !== 'nth-child') { | |
| 13 | + return true; | |
| 14 | + } | |
| 13 | 15 | |
| 14 | 16 | $criteria = $args[0]; | 
| 15 | 17 | |
| @@ -18,8 +20,11 @@ discard block | ||
| 18 | 20 | $pseudo = $tokenizer->getTokens(); | 
| 19 | 21 | $num = end($pseudo)['value'][0]['value']; | 
| 20 | 22 | |
| 21 | - if (is_callable([$this, $criteria])) return $this->$criteria($num); | |
| 22 | - else return $num == $criteria; | |
| 23 | +		if (is_callable([$this, $criteria])) { | |
| 24 | + return $this->$criteria($num); | |
| 25 | +		} else { | |
| 26 | + return $num == $criteria; | |
| 27 | + } | |
| 23 | 28 | } | 
| 24 | 29 | |
| 25 | 30 |  	private function odd($num) { | 
| @@ -16,7 +16,9 @@ discard block | ||
| 16 | 16 | } | 
| 17 | 17 | |
| 18 | 18 |  	public function match($name, $args, \DomElement $element) { | 
| 19 | - if ($name !== 'not') return true; | |
| 19 | +		if ($name !== 'not') { | |
| 20 | + return true; | |
| 21 | + } | |
| 20 | 22 | |
| 21 | 23 | $xpath = new \DomXpath($element->ownerDocument); | 
| 22 | 24 | return $this->notElement($args, $xpath, $element); | 
| @@ -29,7 +31,9 @@ discard block | ||
| 29 | 31 | //Find all nodes matched by the expressions in the brackets :not(EXPR) | 
| 30 | 32 |  			foreach ($xpath->query($xpathString) as $matchedElement) { | 
| 31 | 33 | //Check to see whether this node was matched by the not query | 
| 32 | - if ($element->isSameNode($matchedElement)) return false; | |
| 34 | +				if ($element->isSameNode($matchedElement)) { | |
| 35 | + return false; | |
| 36 | + } | |
| 33 | 37 | } | 
| 34 | 38 | } | 
| 35 | 39 | return true; | 
| @@ -26,7 +26,9 @@ discard block | ||
| 26 | 26 | $this->cache = new Cache(new \ArrayObject()); | 
| 27 | 27 | |
| 28 | 28 | $modules = is_array($modules) ? $modules : $this->defaultModules; | 
| 29 | - foreach ($modules as $module) $this->loadModule(new $module); | |
| 29 | +		foreach ($modules as $module) { | |
| 30 | + $this->loadModule(new $module); | |
| 31 | + } | |
| 30 | 32 | } | 
| 31 | 33 | |
| 32 | 34 | //Allow setting the time used by Transphporm for caching. This is for testing purposes | 
| @@ -51,7 +53,9 @@ discard block | ||
| 51 | 53 | $valueParser = new Parser\Value($data); | 
| 52 | 54 | $config = new Config($data, $valueParser, $elementData, new Hook\Formatter(), new Parser\CssToXpath($valueParser, $data, $template->getPrefix()), $headers, $this->baseDir); | 
| 53 | 55 | |
| 54 | - foreach ($this->modules as $module) $module->load($config); | |
| 56 | +		foreach ($this->modules as $module) { | |
| 57 | + $module->load($config); | |
| 58 | + } | |
| 55 | 59 | |
| 56 | 60 | $this->processRules($template, $config); | 
| 57 | 61 | |
| @@ -66,7 +70,9 @@ discard block | ||
| 66 | 70 | $rules = $this->getRules($template, $config); | 
| 67 | 71 | |
| 68 | 72 |  		foreach ($rules as $rule) { | 
| 69 | - if ($rule->shouldRun($this->time)) $this->executeTssRule($rule, $template, $config); | |
| 73 | +			if ($rule->shouldRun($this->time)) { | |
| 74 | + $this->executeTssRule($rule, $template, $config); | |
| 75 | + } | |
| 70 | 76 | } | 
| 71 | 77 | } | 
| 72 | 78 | |
| @@ -82,7 +88,9 @@ discard block | ||
| 82 | 88 | |
| 83 | 89 | // TODO: Once `Sheet` uses tokens this can be removed | 
| 84 | 90 | $pseudo = []; | 
| 85 | - foreach ($rule->pseudo as $pseudoString) $pseudo[] = (new \Transphporm\Parser\Tokenizer($pseudoString))->getTokens(); | |
| 91 | +		foreach ($rule->pseudo as $pseudoString) { | |
| 92 | + $pseudo[] = (new \Transphporm\Parser\Tokenizer($pseudoString))->getTokens(); | |
| 93 | + } | |
| 86 | 94 | |
| 87 | 95 | $pseudoMatcher = $config->createPseudoMatcher($pseudo); | 
| 88 | 96 | |
| @@ -96,8 +104,9 @@ discard block | ||
| 96 | 104 |  		if (trim($this->template)[0] !== '<') { | 
| 97 | 105 | $xml = $this->cache->load($this->template, filemtime($this->template)); | 
| 98 | 106 | return $xml ? $xml : ['body' => file_get_contents($this->template), 'headers' => []]; | 
| 107 | +		} else { | |
| 108 | + return ['body' => $this->template, 'headers' => []]; | |
| 99 | 109 | } | 
| 100 | - else return ['body' => $this->template, 'headers' => []]; | |
| 101 | 110 | } | 
| 102 | 111 | |
| 103 | 112 | //Load the TSS rules either from a file or as a string | 
| @@ -112,10 +121,14 @@ discard block | ||
| 112 | 121 | //Try to load the cached rules, if not set in the cache (or expired) parse the supplied sheet | 
| 113 | 122 | $rules = $this->cache->load($key, filemtime($this->tss)); | 
| 114 | 123 | |
| 115 | - if (!$rules) return $this->cache->write($key, (new Parser\Sheet(file_get_contents($this->tss), $this->baseDir, $config->getCssToXpath(), $config->getValueParser()))->parse()); | |
| 116 | - else return $rules; | |
| 124 | +			if (!$rules) { | |
| 125 | + return $this->cache->write($key, (new Parser\Sheet(file_get_contents($this->tss), $this->baseDir, $config->getCssToXpath(), $config->getValueParser()))->parse()); | |
| 126 | +			} else { | |
| 127 | + return $rules; | |
| 128 | + } | |
| 129 | +		} else { | |
| 130 | + return (new Parser\Sheet($this->tss, $this->baseDir, $config->getCssToXpath(), $config->getValueParser()))->parse(); | |
| 117 | 131 | } | 
| 118 | - else return (new Parser\Sheet($this->tss, $this->baseDir, $config->getCssToXpath(), $config->getValueParser()))->parse(); | |
| 119 | 132 | } | 
| 120 | 133 | |
| 121 | 134 |  	public function setCache(\ArrayAccess $cache) { | 
| @@ -7,8 +7,12 @@ | ||
| 7 | 7 | namespace Transphporm\Property; | 
| 8 | 8 |  class Display implements \Transphporm\Property { | 
| 9 | 9 |  	public function run(array $values, \DomElement $element, array $rules, \Transphporm\Hook\PseudoMatcher $pseudoMatcher, array $properties = []) { | 
| 10 | -		if ($pseudoMatcher->hasFunction('attr')) $element->removeAttribute($pseudoMatcher->getFuncArgs('attr', $element)[0]); | |
| 11 | -		else if (strtolower($values[0]) === 'none') $element->setAttribute('transphporm', 'remove'); | |
| 12 | -		else $element->setAttribute('transphporm', 'show'); | |
| 10 | +		if ($pseudoMatcher->hasFunction('attr')) { | |
| 11 | +			$element->removeAttribute($pseudoMatcher->getFuncArgs('attr', $element)[0]); | |
| 12 | +		} else if (strtolower($values[0]) === 'none') { | |
| 13 | +			$element->setAttribute('transphporm', 'remove'); | |
| 14 | +		} else { | |
| 15 | +			$element->setAttribute('transphporm', 'show'); | |
| 16 | + } | |
| 13 | 17 | } | 
| 14 | 18 | } | 
| @@ -14,7 +14,9 @@ | ||
| 14 | 14 | } | 
| 15 | 15 | |
| 16 | 16 |  	public function match($name, $args, \DomElement $element) { | 
| 17 | - if (!($name === null || in_array($name, ['data', 'iteration', 'root']))) return true; | |
| 17 | +		if (!($name === null || in_array($name, ['data', 'iteration', 'root']))) { | |
| 18 | + return true; | |
| 19 | + } | |
| 18 | 20 | return $args[0]; | 
| 19 | 21 | } | 
| 20 | 22 | } | 
| @@ -28,6 +28,9 @@ discard block | ||
| 28 | 28 | } | 
| 29 | 29 | } | 
| 30 | 30 | |
| 31 | + /** | |
| 32 | + * @param \DOMElement $element | |
| 33 | + */ | |
| 31 | 34 |  	private function shouldRun($element) { | 
| 32 | 35 |  		do { | 
| 33 | 36 |  			if ($element->getAttribute('transphporm') == 'includedtemplate') return false; | 
| @@ -40,6 +43,10 @@ discard block | ||
| 40 | 43 | return (isset($rules['content-mode'])) ? $rules['content-mode'] : 'append'; | 
| 41 | 44 | } | 
| 42 | 45 | |
| 46 | + /** | |
| 47 | + * @param \DOMElement $element | |
| 48 | + * @param \Transphporm\Hook\PseudoMatcher $pseudoMatcher | |
| 49 | + */ | |
| 43 | 50 |  	private function processPseudo($value, $element, $pseudoMatcher) { | 
| 44 | 51 | $pseudoContent = ['attr', 'header', 'before', 'after']; | 
| 45 | 52 |  		foreach ($pseudoContent as $pseudo) { | 
| @@ -96,6 +103,9 @@ discard block | ||
| 96 | 103 | } | 
| 97 | 104 | } | 
| 98 | 105 | |
| 106 | + /** | |
| 107 | + * @param \DOMElement $element | |
| 108 | + */ | |
| 99 | 109 |  	private function replaceContent($element, $content) { | 
| 100 | 110 | //If this rule was cached, the elements that were added last time need to be removed prior to running the rule again. | 
| 101 | 111 |  		foreach ($this->getNode($content, $element->ownerDocument) as $node) { | 
| @@ -104,12 +114,18 @@ discard block | ||
| 104 | 114 |  		$element->setAttribute('transphporm', 'remove'); | 
| 105 | 115 | } | 
| 106 | 116 | |
| 117 | + /** | |
| 118 | + * @param \DOMElement $element | |
| 119 | + */ | |
| 107 | 120 |  	private function appendContent($element, $content) { | 
| 108 | 121 |  		foreach ($this->getNode($content, $element->ownerDocument) as $node) { | 
| 109 | 122 | $element->appendChild($node); | 
| 110 | 123 | } | 
| 111 | 124 | } | 
| 112 | 125 | |
| 126 | + /** | |
| 127 | + * @param \DOMElement $element | |
| 128 | + */ | |
| 113 | 129 |  	private function removeAllChildren($element) { | 
| 114 | 130 | while ($element->hasChildNodes()) $element->removeChild($element->firstChild); | 
| 115 | 131 | } | 
| @@ -16,21 +16,28 @@ discard block | ||
| 16 | 16 | } | 
| 17 | 17 | |
| 18 | 18 |  	public function run(array $values, \DomElement $element, array $rules, \Transphporm\Hook\PseudoMatcher $pseudoMatcher, array $properties = []) { | 
| 19 | - if (!$this->shouldRun($element)) return false; | |
| 19 | +		if (!$this->shouldRun($element)) { | |
| 20 | + return false; | |
| 21 | + } | |
| 20 | 22 | $values = $this->formatter->format($values, $rules); | 
| 21 | 23 | |
| 22 | 24 |  		if (!$this->processPseudo($values, $element, $pseudoMatcher)) { | 
| 23 | 25 | //Remove the current contents | 
| 24 | 26 | $this->removeAllChildren($element); | 
| 25 | 27 | //Now make a text node | 
| 26 | - if ($this->getContentMode($rules) === 'replace') $this->replaceContent($element, $values); | |
| 27 | - else $this->appendContent($element, $values); | |
| 28 | +			if ($this->getContentMode($rules) === 'replace') { | |
| 29 | + $this->replaceContent($element, $values); | |
| 30 | +			} else { | |
| 31 | + $this->appendContent($element, $values); | |
| 32 | + } | |
| 28 | 33 | } | 
| 29 | 34 | } | 
| 30 | 35 | |
| 31 | 36 |  	private function shouldRun($element) { | 
| 32 | 37 |  		do { | 
| 33 | -			if ($element->getAttribute('transphporm') == 'includedtemplate') return false; | |
| 38 | +			if ($element->getAttribute('transphporm') == 'includedtemplate') { | |
| 39 | + return false; | |
| 40 | + } | |
| 34 | 41 | } | 
| 35 | 42 | while (($element = $element->parentNode) instanceof \DomElement); | 
| 36 | 43 | return true; | 
| @@ -54,16 +61,18 @@ discard block | ||
| 54 | 61 |  	private function getNode($node, $document) { | 
| 55 | 62 |  		foreach ($node as $n) { | 
| 56 | 63 |  			if (is_array($n)) { | 
| 57 | - foreach ($this->getNode($n, $document) as $new) yield $new; | |
| 58 | - } | |
| 59 | -			else { | |
| 64 | +				foreach ($this->getNode($n, $document) as $new) { | |
| 65 | + yield $new; | |
| 66 | + } | |
| 67 | +			} else { | |
| 60 | 68 |  				if ($n instanceof \DomElement) { | 
| 61 | 69 | $new = $document->importNode($n, true); | 
| 62 | 70 | //Removing this might cause problems with caching... | 
| 63 | 71 |  					//$new->setAttribute('transphporm', 'added'); | 
| 64 | - } | |
| 65 | -				else { | |
| 66 | - if ($n instanceof \DomText) $n = $n->nodeValue; | |
| 72 | +				} else { | |
| 73 | +					if ($n instanceof \DomText) { | |
| 74 | + $n = $n->nodeValue; | |
| 75 | + } | |
| 67 | 76 |  					$new = $document->createElement('text'); | 
| 68 | 77 | |
| 69 | 78 | $new->appendChild($document->createTextNode($n)); | 
| @@ -111,6 +120,8 @@ discard block | ||
| 111 | 120 | } | 
| 112 | 121 | |
| 113 | 122 |  	private function removeAllChildren($element) { | 
| 114 | - while ($element->hasChildNodes()) $element->removeChild($element->firstChild); | |
| 123 | +		while ($element->hasChildNodes()) { | |
| 124 | + $element->removeChild($element->firstChild); | |
| 125 | + } | |
| 115 | 126 | } | 
| 116 | 127 | } | 
| @@ -39,27 +39,35 @@ | ||
| 39 | 39 | $parts['name'] = $this->getFuncName($tokens); | 
| 40 | 40 |  		if ($parts['name'] === null || in_array($parts['name'], ['data', 'iteration', 'root'])) { | 
| 41 | 41 | $parts['args'] = $this->valueParser->parseTokens($tokens); | 
| 42 | +		} elseif (isset($tokens[1])) { | |
| 43 | + $parts['args'] = $this->valueParser->parseTokens($tokens[1]['value']); | |
| 44 | +		} else { | |
| 45 | + $parts['args'] = [['']]; | |
| 42 | 46 | } | 
| 43 | - elseif (isset($tokens[1])) $parts['args'] = $this->valueParser->parseTokens($tokens[1]['value']); | |
| 44 | - else $parts['args'] = [['']]; | |
| 45 | 47 | return $parts; | 
| 46 | 48 | } | 
| 47 | 49 | |
| 48 | 50 |  	private function getFuncName($tokens) { | 
| 49 | - if ($tokens[0]['type'] === Tokenizer::NAME) return $tokens[0]['value']; | |
| 51 | +		if ($tokens[0]['type'] === Tokenizer::NAME) { | |
| 52 | + return $tokens[0]['value']; | |
| 53 | + } | |
| 50 | 54 | return null; | 
| 51 | 55 | } | 
| 52 | 56 | |
| 53 | 57 |  	public function hasFunction($name) { | 
| 54 | 58 |  		foreach ($this->pseudo as $tokens) { | 
| 55 | - if ($name === $this->getFuncName($tokens)) return true; | |
| 59 | +			if ($name === $this->getFuncName($tokens)) { | |
| 60 | + return true; | |
| 61 | + } | |
| 56 | 62 | } | 
| 57 | 63 | } | 
| 58 | 64 | |
| 59 | 65 |  	public function getFuncArgs($name) { | 
| 60 | 66 |  		foreach ($this->pseudo as $tokens) { | 
| 61 | 67 | $parts = $this->getFuncParts($tokens); | 
| 62 | - if ($name === $parts['name']) return $parts['args']; | |
| 68 | +			if ($name === $parts['name']) { | |
| 69 | + return $parts['args']; | |
| 70 | + } | |
| 63 | 71 | } | 
| 64 | 72 | } | 
| 65 | 73 | } |