File: Expression.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (119 lines) | stat: -rw-r--r-- 2,782 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<?php
/**
 * @private
 * @see less-3.13.1.js#Expression.prototype
 */
class Less_Tree_Expression extends Less_Tree implements Less_Tree_HasValueProperty {

	/** @var Less_Tree[] */
	public $value = [];

	public $noSpacing;
	public $parens = null;

	public function __construct( $value, $noSpacing = false ) {
		$this->value = $value;
		$this->noSpacing = $noSpacing;
	}

	public function accept( $visitor ) {
		$this->value = $visitor->visitArray( $this->value );
	}

	public function compile( $env ) {
		$mathOn = $env->isMathOn();
		// NOTE: We don't support STRICT_LEGACY (Less.js 3.13)
		$inParenthesis = $this->parens && ( true || !$this->parensInOp );
		$doubleParen = false;
		if ( $inParenthesis ) {
			$env->inParenthesis();
		}

		if ( $this->value ) {

			if ( count( $this->value ) > 1 ) {
				$ret = [];
				foreach ( $this->value as $e ) {
					$ret[] = $e->compile( $env );
				}
				$returnValue = new self( $ret, $this->noSpacing );

			} else {
				// Implied `if ( count() === 1 )`
				if ( ( $this->value[0] instanceof self ) && $this->value[0]->parens && !$this->value[0]->parensInOp && !$env->inCalc ) {
					$doubleParen = true;
				}
				$returnValue = $this->value[0]->compile( $env );
			}
		} else {
			$returnValue = $this;
		}

		if ( $inParenthesis ) {
			$env->outOfParenthesis();
		}

		if ( $this->parens && $this->parensInOp && !$mathOn && !$doubleParen &&
			( !( $returnValue instanceof Less_Tree_Dimension ) )
		) {
			$returnValue = new Less_Tree_Paren( $returnValue );
		}
		return $returnValue;
	}

	/**
	 * @see Less_Tree::genCSS
	 */
	public function genCSS( $output ) {
		$val_len = count( $this->value );
		for ( $i = 0; $i < $val_len; $i++ ) {
			$this->value[$i]->genCSS( $output );
			if ( !$this->noSpacing && ( $i + 1 < $val_len ) ) {
				$output->add( ' ' );
			}
		}
	}

	public function throwAwayComments() {
		if ( is_array( $this->value ) ) {
			$new_value = [];
			foreach ( $this->value as $v ) {
				if ( $v instanceof Less_Tree_Comment ) {
					continue;
				}
				$new_value[] = $v;
			}
			$this->value = $new_value;
		}
	}

	public function markReferenced() {
		if ( is_array( $this->value ) ) {
			foreach ( $this->value as $v ) {
				if ( method_exists( $v, 'markReferenced' ) ) {
					$v->markReferenced();
				}
			}
		}
	}

	/**
	 * Should be used only in Less_Tree_Call::functionCaller()
	 * to retrieve expression without comments
	 * @internal
	 */
	public function mapToFunctionCallArgument() {
		if ( is_array( $this->value ) ) {
			$subNodes = [];
			foreach ( $this->value as $subNode ) {
				if ( !( $subNode instanceof Less_Tree_Comment ) ) {
					$subNodes[] = $subNode;
				}
			}
			return count( $subNodes ) === 1
				? $subNodes[0]
				: new Less_Tree_Expression( $subNodes );
		}
		return $this;
	}
}