| @@ -19,7 +19,9 @@ | ||
| 19 | 19 | $close = strpos($this->str, $closingChr, $open); | 
| 20 | 20 | |
| 21 | 21 | $cPos = $open+1; | 
| 22 | - while (($cPos = strpos($this->str, $openChr, $cPos+1)) !== false && $cPos < $close) $close = strpos($this->str, $closingChr, $close+1); | |
| 22 | +		while (($cPos = strpos($this->str, $openChr, $cPos+1)) !== false && $cPos < $close) { | |
| 23 | + $close = strpos($this->str, $closingChr, $close+1); | |
| 24 | + } | |
| 23 | 25 | |
| 24 | 26 | $this->startPos = $open; | 
| 25 | 27 | $this->endPos = $close; | 
| @@ -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); | 
| @@ -13,13 +13,17 @@ discard block | ||
| 13 | 13 | } | 
| 14 | 14 | |
| 15 | 15 |  	public function run($value, \DomElement $element, array $rules, \Transphporm\Hook\PseudoMatcher $pseudoMatcher, array $properties = []) { | 
| 16 | -		if ($element->getAttribute('transphporm') === 'added') return $element->parentNode->removeChild($element); | |
| 16 | +		if ($element->getAttribute('transphporm') === 'added') { | |
| 17 | + return $element->parentNode->removeChild($element); | |
| 18 | + } | |
| 17 | 19 | |
| 18 | 20 | $count = 0; | 
| 19 | 21 |  		foreach ($value as $key => $iteration) { | 
| 20 | 22 | $clone = $element->cloneNode(true); | 
| 21 | 23 | //Mark all but one of the nodes as having been added by transphporm, when the hook is run again, these are removed | 
| 22 | -			if ($count++ > 0) $clone->setAttribute('transphporm', 'added'); | |
| 24 | +			if ($count++ > 0) { | |
| 25 | +				$clone->setAttribute('transphporm', 'added'); | |
| 26 | + } | |
| 23 | 27 | $this->data->bind($clone, $iteration, 'iteration'); | 
| 24 | 28 | $this->data->bind($clone, $key, 'key'); | 
| 25 | 29 | $element->parentNode->insertBefore($clone, $element); | 
| @@ -36,7 +40,9 @@ discard block | ||
| 36 | 40 | |
| 37 | 41 |  	private function createHook($newRules, $pseudoMatcher, $properties) { | 
| 38 | 42 | $hook = new \Transphporm\Hook\PropertyHook($newRules, $pseudoMatcher, new \Transphporm\Parser\Value($this->data)); | 
| 39 | - foreach ($properties as $name => $property) $hook->registerProperty($name, $property); | |
| 43 | +		foreach ($properties as $name => $property) { | |
| 44 | + $hook->registerProperty($name, $property); | |
| 45 | + } | |
| 40 | 46 | return $hook; | 
| 41 | 47 | } | 
| 42 | 48 | } | 
| 43 | 49 | \ No newline at end of file | 
| @@ -20,11 +20,15 @@ discard block | ||
| 20 | 20 | |
| 21 | 21 |  	public function run(\DomElement $element) {	 | 
| 22 | 22 | //Don't run if there's a pseudo element like nth-child() and this element doesn't match it | 
| 23 | - if (!$this->pseudoMatcher->matches($element)) return; | |
| 23 | +		if (!$this->pseudoMatcher->matches($element)) { | |
| 24 | + return; | |
| 25 | + } | |
| 24 | 26 | |
| 25 | 27 |  		foreach ($this->rules as $name => $value) { | 
| 26 | 28 | $result = $this->callProperty($name, $element, $this->valueParser->parse(trim($value), $element)); | 
| 27 | - if ($result === false) break; | |
| 29 | +			if ($result === false) { | |
| 30 | + break; | |
| 31 | + } | |
| 28 | 32 | } | 
| 29 | 33 | } | 
| 30 | 34 | |
| @@ -45,7 +49,9 @@ discard block | ||
| 45 | 49 | } | 
| 46 | 50 | |
| 47 | 51 |  	private function callProperty($name, $element, $value) { | 
| 48 | - if (isset($this->properties[$name])) return $this->properties[$name]->run($value, $element, $this->rules, $this->pseudoMatcher, $this->properties); | |
| 52 | +		if (isset($this->properties[$name])) { | |
| 53 | + return $this->properties[$name]->run($value, $element, $this->rules, $this->pseudoMatcher, $this->properties); | |
| 54 | + } | |
| 49 | 55 | return false; | 
| 50 | 56 | } | 
| 51 | 57 | } | 
| @@ -23,7 +23,7 @@ | ||
| 23 | 23 | if (!$this->pseudoMatcher->matches($element)) return; | 
| 24 | 24 | |
| 25 | 25 |  		foreach ($this->rules as $name => $value) { | 
| 26 | - $result = $this->callProperty($name, $element, $this->valueParser->parse(trim($value), $element)) ; | |
| 26 | + $result = $this->callProperty($name, $element, $this->valueParser->parse(trim($value), $element)); | |
| 27 | 27 | if ($result === false) break; | 
| 28 | 28 | } | 
| 29 | 29 | } | 
| @@ -7,8 +7,12 @@ | ||
| 7 | 7 | namespace Transphporm\Property; | 
| 8 | 8 |  class Display implements \Transphporm\Property { | 
| 9 | 9 |  	public function run($value, \DomElement $element, array $rules, \Transphporm\Hook\PseudoMatcher $pseudoMatcher, array $properties = []) { | 
| 10 | -		if ($pseudoMatcher->hasFunction('attr')) $element->removeAttribute($pseudoMatcher->getFuncArgs('attr')); | |
| 11 | -		else if (strtolower($value[0]) === 'none') $element->setAttribute('transphporm', 'remove'); | |
| 12 | -		else $element->setAttribute('transphporm', 'show'); | |
| 10 | +		if ($pseudoMatcher->hasFunction('attr')) { | |
| 11 | +			$element->removeAttribute($pseudoMatcher->getFuncArgs('attr')); | |
| 12 | +		} else if (strtolower($value[0]) === 'none') { | |
| 13 | +			$element->setAttribute('transphporm', 'remove'); | |
| 14 | +		} else { | |
| 15 | +			$element->setAttribute('transphporm', 'show'); | |
| 16 | + } | |
| 13 | 17 | } | 
| 14 | 18 | } | 
| 15 | 19 | \ No newline at end of file | 
| @@ -15,8 +15,11 @@ | ||
| 15 | 15 | $bracketMatcher = new \Transphporm\Parser\BracketMatcher($element->getNodePath()); | 
| 16 | 16 |  			$num = $bracketMatcher->match('[', ']'); | 
| 17 | 17 | |
| 18 | - if (is_callable([$this, $criteria])) return $this->$criteria($num); | |
| 19 | - else return $num == $criteria; | |
| 18 | +			if (is_callable([$this, $criteria])) { | |
| 19 | + return $this->$criteria($num); | |
| 20 | +			} else { | |
| 21 | + return $num == $criteria; | |
| 22 | + } | |
| 20 | 23 | } | 
| 21 | 24 | return true; | 
| 22 | 25 | } | 
| @@ -31,7 +31,9 @@ discard block | ||
| 31 | 31 | |
| 32 | 32 |  	public function hasFunction($name) { | 
| 33 | 33 |  		foreach ($this->pseudo as $pseudo) { | 
| 34 | - if (strpos($pseudo, $name) === 0) return true; | |
| 34 | +			if (strpos($pseudo, $name) === 0) { | |
| 35 | + return true; | |
| 36 | + } | |
| 35 | 37 | } | 
| 36 | 38 | } | 
| 37 | 39 | |
| @@ -50,10 +52,16 @@ discard block | ||
| 50 | 52 |  		$parenthesis = strpos($pseudo, '('); | 
| 51 | 53 | $square = strpos($pseudo, ']'); | 
| 52 | 54 | |
| 53 | - if ($parenthesis === false) $parenthesis = 999; | |
| 54 | - if ($square === false) $square = 999; | |
| 55 | +		if ($parenthesis === false) { | |
| 56 | + $parenthesis = 999; | |
| 57 | + } | |
| 58 | +		if ($square === false) { | |
| 59 | + $square = 999; | |
| 60 | + } | |
| 55 | 61 | |
| 56 | -		if ($parenthesis < $square) return ['(', ')']; | |
| 62 | +		if ($parenthesis < $square) { | |
| 63 | +			return ['(', ')']; | |
| 64 | + } | |
| 57 | 65 | return ['[', ']']; | 
| 58 | 66 | } | 
| 59 | 67 | |
| @@ -30,7 +30,9 @@ | ||
| 30 | 30 | //Find all nodes matched by the expressions in the brackets :not(EXPR) | 
| 31 | 31 |  			foreach ($xpath->query($xpathString) as $matchedElement) { | 
| 32 | 32 | //Check to see whether this node was matched by the not query | 
| 33 | - if ($element->isSameNode($matchedElement)) return false; | |
| 33 | +				if ($element->isSameNode($matchedElement)) { | |
| 34 | + return false; | |
| 35 | + } | |
| 34 | 36 | } | 
| 35 | 37 | } | 
| 36 | 38 | return true; | 
| @@ -49,7 +49,7 @@ discard block | ||
| 49 | 49 | |
| 50 | 50 | $cachedOutput = $this->loadTemplate(); | 
| 51 | 51 | //To be a valid XML document it must have a root element, automatically wrap it in <template> to ensure it does | 
| 52 | -		$template = new Template($this->isValidDoc($cachedOutput['body']) ? str_ireplace('<!doctype', '<!DOCTYPE', $cachedOutput['body']) : '<template>' . $cachedOutput['body'] . '</template>' ); | |
| 52 | +		$template = new Template($this->isValidDoc($cachedOutput['body']) ? str_ireplace('<!doctype', '<!DOCTYPE', $cachedOutput['body']) : '<template>'.$cachedOutput['body'].'</template>'); | |
| 53 | 53 | |
| 54 | 54 | $this->processRules($template, $data, $featureSet); | 
| 55 | 55 | |
| @@ -98,11 +98,11 @@ discard block | ||
| 98 | 98 | //N.b. only files can be cached | 
| 99 | 99 |  	private function getRules($template, $valueParser) {		 | 
| 100 | 100 |  		if (is_file($this->tss)) { | 
| 101 | - $this->baseDir = dirname(realpath($this->tss)) . DIRECTORY_SEPARATOR; | |
| 101 | + $this->baseDir = dirname(realpath($this->tss)).DIRECTORY_SEPARATOR; | |
| 102 | 102 | //The cache for the key: the filename and template prefix | 
| 103 | 103 | //Each template may have a different prefix which changes the parsed TSS, | 
| 104 | 104 | //Because of this the cache needs to be generated for each template prefix. | 
| 105 | - $key = $this->tss . $template->getPrefix() . $this->baseDir; | |
| 105 | + $key = $this->tss.$template->getPrefix().$this->baseDir; | |
| 106 | 106 | //Try to load the cached rules, if not set in the cache (or expired) parse the supplied sheet | 
| 107 | 107 | $rules = $this->cache->load($key, filemtime($this->tss)); | 
| 108 | 108 | if (!$rules) return $this->cache->write($key, (new Parser\Sheet(file_get_contents($this->tss), $this->baseDir, $valueParser, $template->getPrefix()))->parse()); | 
| @@ -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 | 
| @@ -47,7 +49,9 @@ discard block | ||
| 47 | 49 | $data = new FunctionSet($elementData, $this->baseDir); | 
| 48 | 50 | $config = new Config($data, $elementData, new Hook\Formatter(), $headers, $this->baseDir); | 
| 49 | 51 | |
| 50 | - foreach ($this->modules as $module) $module->load($config); | |
| 52 | +		foreach ($this->modules as $module) { | |
| 53 | + $module->load($config); | |
| 54 | + } | |
| 51 | 55 | |
| 52 | 56 | $cachedOutput = $this->loadTemplate(); | 
| 53 | 57 | //To be a valid XML document it must have a root element, automatically wrap it in <template> to ensure it does | 
| @@ -67,7 +71,9 @@ discard block | ||
| 67 | 71 | $rules = $this->getRules($template, $valueParser); | 
| 68 | 72 | |
| 69 | 73 |  		foreach ($rules as $rule) { | 
| 70 | - if ($rule->shouldRun($this->time)) $this->executeTssRule($rule, $template, $valueParser, $config); | |
| 74 | +			if ($rule->shouldRun($this->time)) { | |
| 75 | + $this->executeTssRule($rule, $template, $valueParser, $config); | |
| 76 | + } | |
| 71 | 77 | } | 
| 72 | 78 | } | 
| 73 | 79 | |
| @@ -92,8 +98,9 @@ discard block | ||
| 92 | 98 |  		if (trim($this->template)[0] !== '<') {			 | 
| 93 | 99 | $xml = $this->cache->load($this->template, filemtime($this->template)); | 
| 94 | 100 | return $xml ? $xml : ['body' => file_get_contents($this->template), 'headers' => []]; | 
| 101 | +		} else { | |
| 102 | + return ['body' => $this->template, 'headers' => []]; | |
| 95 | 103 | } | 
| 96 | - else return ['body' => $this->template, 'headers' => []]; | |
| 97 | 104 | } | 
| 98 | 105 | |
| 99 | 106 | //Load the TSS rules either from a file or as a string | 
| @@ -107,10 +114,14 @@ discard block | ||
| 107 | 114 | $key = $this->tss . $template->getPrefix() . $this->baseDir; | 
| 108 | 115 | //Try to load the cached rules, if not set in the cache (or expired) parse the supplied sheet | 
| 109 | 116 | $rules = $this->cache->load($key, filemtime($this->tss)); | 
| 110 | - if (!$rules) return $this->cache->write($key, (new Parser\Sheet(file_get_contents($this->tss), $this->baseDir, $valueParser, $template->getPrefix()))->parse()); | |
| 111 | - else return $rules; | |
| 117 | +			if (!$rules) { | |
| 118 | + return $this->cache->write($key, (new Parser\Sheet(file_get_contents($this->tss), $this->baseDir, $valueParser, $template->getPrefix()))->parse()); | |
| 119 | +			} else { | |
| 120 | + return $rules; | |
| 121 | + } | |
| 122 | +		} else { | |
| 123 | + return (new Parser\Sheet($this->tss, $this->baseDir, $valueParser, $template->getPrefix()))->parse(); | |
| 112 | 124 | } | 
| 113 | - else return (new Parser\Sheet($this->tss, $this->baseDir, $valueParser, $template->getPrefix()))->parse(); | |
| 114 | 125 | } | 
| 115 | 126 | |
| 116 | 127 |  	public function setCache(\ArrayAccess $cache) { | 
| @@ -23,8 +23,8 @@ | ||
| 23 | 23 | $end = strpos($str, '"', $pos+1); | 
| 24 | 24 | if (!$end) break; | 
| 25 | 25 | while ($str[$end-1] == '\\') $end = strpos($str, '"', $end+1); | 
| 26 | - $strings['$___STR' . ++$num] = substr($str, $pos, $end-$pos+1); | |
| 27 | - $str = substr_replace($str, '$___STR' . $num, $pos, $end-$pos+1); | |
| 26 | + $strings['$___STR'.++$num] = substr($str, $pos, $end-$pos+1); | |
| 27 | + $str = substr_replace($str, '$___STR'.$num, $pos, $end-$pos+1); | |
| 28 | 28 | } | 
| 29 | 29 | |
| 30 | 30 | return [$str, $strings]; | 
| @@ -21,7 +21,9 @@ discard block | ||
| 21 | 21 | $strings = []; | 
| 22 | 22 |  		while (isset($str[$pos]) && ($pos = strpos($str, '"', $pos)) !== false) { | 
| 23 | 23 | $end = strpos($str, '"', $pos+1); | 
| 24 | - if (!$end) break; | |
| 24 | +			if (!$end) { | |
| 25 | + break; | |
| 26 | + } | |
| 25 | 27 | $end = $this->getNextPosEscaped($str, '\\', '"', $end); | 
| 26 | 28 | $strings['$___STR' . ++$num] = substr($str, $pos, $end-$pos+1); | 
| 27 | 29 | $str = substr_replace($str, '$___STR' . $num, $pos, $end-$pos+1); | 
| @@ -31,7 +33,9 @@ discard block | ||
| 31 | 33 | } | 
| 32 | 34 | |
| 33 | 35 |  	private function getNextPosEscaped($str, $escape, $chr, $start) { | 
| 34 | - while ($str[$start-1] == $escape) $start = strpos($str, $chr, $start+1); | |
| 36 | +		while ($str[$start-1] == $escape) { | |
| 37 | + $start = strpos($str, $chr, $start+1); | |
| 38 | + } | |
| 35 | 39 | return $start; | 
| 36 | 40 | } | 
| 37 | 41 | |