TreeWalkerChain.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662
  1. <?php
  2. /*
  3. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  4. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  5. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  6. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  7. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  8. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  9. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  10. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  11. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  12. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  13. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  14. *
  15. * This software consists of voluntary contributions made by many individuals
  16. * and is licensed under the MIT license. For more information, see
  17. * <http://www.doctrine-project.org>.
  18. */
  19. namespace Doctrine\ORM\Query;
  20. /**
  21. * Represents a chain of tree walkers that modify an AST and finally emit output.
  22. * Only the last walker in the chain can emit output. Any previous walkers can modify
  23. * the AST to influence the final output produced by the last walker.
  24. *
  25. * @author Roman Borschel <roman@code-factory.org>
  26. * @since 2.0
  27. */
  28. class TreeWalkerChain implements TreeWalker
  29. {
  30. /** The tree walkers. */
  31. private $_walkers = array();
  32. /** The original Query. */
  33. private $_query;
  34. /** The ParserResult of the original query that was produced by the Parser. */
  35. private $_parserResult;
  36. /** The query components of the original query (the "symbol table") that was produced by the Parser. */
  37. private $_queryComponents;
  38. /**
  39. * @inheritdoc
  40. */
  41. public function __construct($query, $parserResult, array $queryComponents)
  42. {
  43. $this->_query = $query;
  44. $this->_parserResult = $parserResult;
  45. $this->_queryComponents = $queryComponents;
  46. }
  47. /**
  48. * Adds a tree walker to the chain.
  49. *
  50. * @param string $walkerClass The class of the walker to instantiate.
  51. */
  52. public function addTreeWalker($walkerClass)
  53. {
  54. $this->_walkers[] = new $walkerClass($this->_query, $this->_parserResult, $this->_queryComponents);
  55. }
  56. /**
  57. * Walks down a SelectStatement AST node, thereby generating the appropriate SQL.
  58. *
  59. * @return string The SQL.
  60. */
  61. public function walkSelectStatement(AST\SelectStatement $AST)
  62. {
  63. foreach ($this->_walkers as $walker) {
  64. $walker->walkSelectStatement($AST);
  65. }
  66. }
  67. /**
  68. * Walks down a SelectClause AST node, thereby generating the appropriate SQL.
  69. *
  70. * @return string The SQL.
  71. */
  72. public function walkSelectClause($selectClause)
  73. {
  74. foreach ($this->_walkers as $walker) {
  75. $walker->walkSelectClause($selectClause);
  76. }
  77. }
  78. /**
  79. * Walks down a FromClause AST node, thereby generating the appropriate SQL.
  80. *
  81. * @return string The SQL.
  82. */
  83. public function walkFromClause($fromClause)
  84. {
  85. foreach ($this->_walkers as $walker) {
  86. $walker->walkFromClause($fromClause);
  87. }
  88. }
  89. /**
  90. * Walks down a FunctionNode AST node, thereby generating the appropriate SQL.
  91. *
  92. * @return string The SQL.
  93. */
  94. public function walkFunction($function)
  95. {
  96. foreach ($this->_walkers as $walker) {
  97. $walker->walkFunction($function);
  98. }
  99. }
  100. /**
  101. * Walks down an OrderByClause AST node, thereby generating the appropriate SQL.
  102. *
  103. * @param OrderByClause
  104. * @return string The SQL.
  105. */
  106. public function walkOrderByClause($orderByClause)
  107. {
  108. foreach ($this->_walkers as $walker) {
  109. $walker->walkOrderByClause($orderByClause);
  110. }
  111. }
  112. /**
  113. * Walks down an OrderByItem AST node, thereby generating the appropriate SQL.
  114. *
  115. * @param OrderByItem
  116. * @return string The SQL.
  117. */
  118. public function walkOrderByItem($orderByItem)
  119. {
  120. foreach ($this->_walkers as $walker) {
  121. $walker->walkOrderByItem($orderByItem);
  122. }
  123. }
  124. /**
  125. * Walks down a HavingClause AST node, thereby generating the appropriate SQL.
  126. *
  127. * @param HavingClause
  128. * @return string The SQL.
  129. */
  130. public function walkHavingClause($havingClause)
  131. {
  132. foreach ($this->_walkers as $walker) {
  133. $walker->walkHavingClause($havingClause);
  134. }
  135. }
  136. /**
  137. * Walks down a Join AST node and creates the corresponding SQL.
  138. *
  139. * @param Join $join
  140. * @return string The SQL.
  141. */
  142. public function walkJoin($join)
  143. {
  144. foreach ($this->_walkers as $walker) {
  145. $walker->walkJoin($join);
  146. }
  147. }
  148. /**
  149. * Walks down a SelectExpression AST node and generates the corresponding SQL.
  150. *
  151. * @param SelectExpression $selectExpression
  152. * @return string The SQL.
  153. */
  154. public function walkSelectExpression($selectExpression)
  155. {
  156. foreach ($this->_walkers as $walker) {
  157. $walker->walkSelectExpression($selectExpression);
  158. }
  159. }
  160. /**
  161. * Walks down a QuantifiedExpression AST node, thereby generating the appropriate SQL.
  162. *
  163. * @param QuantifiedExpression
  164. * @return string The SQL.
  165. */
  166. public function walkQuantifiedExpression($qExpr)
  167. {
  168. foreach ($this->_walkers as $walker) {
  169. $walker->walkQuantifiedExpression($qExpr);
  170. }
  171. }
  172. /**
  173. * Walks down a Subselect AST node, thereby generating the appropriate SQL.
  174. *
  175. * @param Subselect
  176. * @return string The SQL.
  177. */
  178. public function walkSubselect($subselect)
  179. {
  180. foreach ($this->_walkers as $walker) {
  181. $walker->walkSubselect($subselect);
  182. }
  183. }
  184. /**
  185. * Walks down a SubselectFromClause AST node, thereby generating the appropriate SQL.
  186. *
  187. * @param SubselectFromClause
  188. * @return string The SQL.
  189. */
  190. public function walkSubselectFromClause($subselectFromClause)
  191. {
  192. foreach ($this->_walkers as $walker) {
  193. $walker->walkSubselectFromClause($subselectFromClause);
  194. }
  195. }
  196. /**
  197. * Walks down a SimpleSelectClause AST node, thereby generating the appropriate SQL.
  198. *
  199. * @param SimpleSelectClause
  200. * @return string The SQL.
  201. */
  202. public function walkSimpleSelectClause($simpleSelectClause)
  203. {
  204. foreach ($this->_walkers as $walker) {
  205. $walker->walkSimpleSelectClause($simpleSelectClause);
  206. }
  207. }
  208. /**
  209. * Walks down a SimpleSelectExpression AST node, thereby generating the appropriate SQL.
  210. *
  211. * @param SimpleSelectExpression
  212. * @return string The SQL.
  213. */
  214. public function walkSimpleSelectExpression($simpleSelectExpression)
  215. {
  216. foreach ($this->_walkers as $walker) {
  217. $walker->walkSimpleSelectExpression($simpleSelectExpression);
  218. }
  219. }
  220. /**
  221. * Walks down an AggregateExpression AST node, thereby generating the appropriate SQL.
  222. *
  223. * @param AggregateExpression
  224. * @return string The SQL.
  225. */
  226. public function walkAggregateExpression($aggExpression)
  227. {
  228. foreach ($this->_walkers as $walker) {
  229. $walker->walkAggregateExpression($aggExpression);
  230. }
  231. }
  232. /**
  233. * Walks down a GroupByClause AST node, thereby generating the appropriate SQL.
  234. *
  235. * @param GroupByClause
  236. * @return string The SQL.
  237. */
  238. public function walkGroupByClause($groupByClause)
  239. {
  240. foreach ($this->_walkers as $walker) {
  241. $walker->walkGroupByClause($groupByClause);
  242. }
  243. }
  244. /**
  245. * Walks down a GroupByItem AST node, thereby generating the appropriate SQL.
  246. *
  247. * @param GroupByItem
  248. * @return string The SQL.
  249. */
  250. public function walkGroupByItem($groupByItem)
  251. {
  252. foreach ($this->_walkers as $walker) {
  253. $walker->walkGroupByItem($groupByItem);
  254. }
  255. }
  256. /**
  257. * Walks down an UpdateStatement AST node, thereby generating the appropriate SQL.
  258. *
  259. * @param UpdateStatement
  260. * @return string The SQL.
  261. */
  262. public function walkUpdateStatement(AST\UpdateStatement $AST)
  263. {
  264. foreach ($this->_walkers as $walker) {
  265. $walker->walkUpdateStatement($AST);
  266. }
  267. }
  268. /**
  269. * Walks down a DeleteStatement AST node, thereby generating the appropriate SQL.
  270. *
  271. * @param DeleteStatement
  272. * @return string The SQL.
  273. */
  274. public function walkDeleteStatement(AST\DeleteStatement $AST)
  275. {
  276. foreach ($this->_walkers as $walker) {
  277. $walker->walkDeleteStatement($AST);
  278. }
  279. }
  280. /**
  281. * Walks down a DeleteClause AST node, thereby generating the appropriate SQL.
  282. *
  283. * @param DeleteClause
  284. * @return string The SQL.
  285. */
  286. public function walkDeleteClause(AST\DeleteClause $deleteClause)
  287. {
  288. foreach ($this->_walkers as $walker) {
  289. $walker->walkDeleteClause($deleteClause);
  290. }
  291. }
  292. /**
  293. * Walks down an UpdateClause AST node, thereby generating the appropriate SQL.
  294. *
  295. * @param UpdateClause
  296. * @return string The SQL.
  297. */
  298. public function walkUpdateClause($updateClause)
  299. {
  300. foreach ($this->_walkers as $walker) {
  301. $walker->walkUpdateClause($updateClause);
  302. }
  303. }
  304. /**
  305. * Walks down an UpdateItem AST node, thereby generating the appropriate SQL.
  306. *
  307. * @param UpdateItem
  308. * @return string The SQL.
  309. */
  310. public function walkUpdateItem($updateItem)
  311. {
  312. foreach ($this->_walkers as $walker) {
  313. $walker->walkUpdateItem($updateItem);
  314. }
  315. }
  316. /**
  317. * Walks down a WhereClause AST node, thereby generating the appropriate SQL.
  318. *
  319. * @param WhereClause
  320. * @return string The SQL.
  321. */
  322. public function walkWhereClause($whereClause)
  323. {
  324. foreach ($this->_walkers as $walker) {
  325. $walker->walkWhereClause($whereClause);
  326. }
  327. }
  328. /**
  329. * Walks down a ConditionalExpression AST node, thereby generating the appropriate SQL.
  330. *
  331. * @param ConditionalExpression
  332. * @return string The SQL.
  333. */
  334. public function walkConditionalExpression($condExpr)
  335. {
  336. foreach ($this->_walkers as $walker) {
  337. $walker->walkConditionalExpression($condExpr);
  338. }
  339. }
  340. /**
  341. * Walks down a ConditionalTerm AST node, thereby generating the appropriate SQL.
  342. *
  343. * @param ConditionalTerm
  344. * @return string The SQL.
  345. */
  346. public function walkConditionalTerm($condTerm)
  347. {
  348. foreach ($this->_walkers as $walker) {
  349. $walker->walkConditionalTerm($condTerm);
  350. }
  351. }
  352. /**
  353. * Walks down a ConditionalFactor AST node, thereby generating the appropriate SQL.
  354. *
  355. * @param ConditionalFactor
  356. * @return string The SQL.
  357. */
  358. public function walkConditionalFactor($factor)
  359. {
  360. foreach ($this->_walkers as $walker) {
  361. $walker->walkConditionalFactor($factor);
  362. }
  363. }
  364. /**
  365. * Walks down a ConditionalPrimary AST node, thereby generating the appropriate SQL.
  366. *
  367. * @param ConditionalPrimary
  368. * @return string The SQL.
  369. */
  370. public function walkConditionalPrimary($condPrimary)
  371. {
  372. foreach ($this->_walkers as $walker) {
  373. $walker->walkConditionalPrimary($condPrimary);
  374. }
  375. }
  376. /**
  377. * Walks down an ExistsExpression AST node, thereby generating the appropriate SQL.
  378. *
  379. * @param ExistsExpression
  380. * @return string The SQL.
  381. */
  382. public function walkExistsExpression($existsExpr)
  383. {
  384. foreach ($this->_walkers as $walker) {
  385. $walker->walkExistsExpression($existsExpr);
  386. }
  387. }
  388. /**
  389. * Walks down a CollectionMemberExpression AST node, thereby generating the appropriate SQL.
  390. *
  391. * @param CollectionMemberExpression
  392. * @return string The SQL.
  393. */
  394. public function walkCollectionMemberExpression($collMemberExpr)
  395. {
  396. foreach ($this->_walkers as $walker) {
  397. $walker->walkCollectionMemberExpression($collMemberExpr);
  398. }
  399. }
  400. /**
  401. * Walks down an EmptyCollectionComparisonExpression AST node, thereby generating the appropriate SQL.
  402. *
  403. * @param EmptyCollectionComparisonExpression
  404. * @return string The SQL.
  405. */
  406. public function walkEmptyCollectionComparisonExpression($emptyCollCompExpr)
  407. {
  408. foreach ($this->_walkers as $walker) {
  409. $walker->walkEmptyCollectionComparisonExpression($emptyCollCompExpr);
  410. }
  411. }
  412. /**
  413. * Walks down a NullComparisonExpression AST node, thereby generating the appropriate SQL.
  414. *
  415. * @param NullComparisonExpression
  416. * @return string The SQL.
  417. */
  418. public function walkNullComparisonExpression($nullCompExpr)
  419. {
  420. foreach ($this->_walkers as $walker) {
  421. $walker->walkNullComparisonExpression($nullCompExpr);
  422. }
  423. }
  424. /**
  425. * Walks down an InExpression AST node, thereby generating the appropriate SQL.
  426. *
  427. * @param InExpression
  428. * @return string The SQL.
  429. */
  430. public function walkInExpression($inExpr)
  431. {
  432. foreach ($this->_walkers as $walker) {
  433. $walker->walkInExpression($inExpr);
  434. }
  435. }
  436. /**
  437. * Walks down an InstanceOfExpression AST node, thereby generating the appropriate SQL.
  438. *
  439. * @param InstanceOfExpression
  440. * @return string The SQL.
  441. */
  442. function walkInstanceOfExpression($instanceOfExpr)
  443. {
  444. foreach ($this->_walkers as $walker) {
  445. $walker->walkInstanceOfExpression($instanceOfExpr);
  446. }
  447. }
  448. /**
  449. * Walks down a literal that represents an AST node, thereby generating the appropriate SQL.
  450. *
  451. * @param mixed
  452. * @return string The SQL.
  453. */
  454. public function walkLiteral($literal)
  455. {
  456. foreach ($this->_walkers as $walker) {
  457. $walker->walkLiteral($literal);
  458. }
  459. }
  460. /**
  461. * Walks down a BetweenExpression AST node, thereby generating the appropriate SQL.
  462. *
  463. * @param BetweenExpression
  464. * @return string The SQL.
  465. */
  466. public function walkBetweenExpression($betweenExpr)
  467. {
  468. foreach ($this->_walkers as $walker) {
  469. $walker->walkBetweenExpression($betweenExpr);
  470. }
  471. }
  472. /**
  473. * Walks down a LikeExpression AST node, thereby generating the appropriate SQL.
  474. *
  475. * @param LikeExpression
  476. * @return string The SQL.
  477. */
  478. public function walkLikeExpression($likeExpr)
  479. {
  480. foreach ($this->_walkers as $walker) {
  481. $walker->walkLikeExpression($likeExpr);
  482. }
  483. }
  484. /**
  485. * Walks down a StateFieldPathExpression AST node, thereby generating the appropriate SQL.
  486. *
  487. * @param StateFieldPathExpression
  488. * @return string The SQL.
  489. */
  490. public function walkStateFieldPathExpression($stateFieldPathExpression)
  491. {
  492. foreach ($this->_walkers as $walker) {
  493. $walker->walkStateFieldPathExpression($stateFieldPathExpression);
  494. }
  495. }
  496. /**
  497. * Walks down a ComparisonExpression AST node, thereby generating the appropriate SQL.
  498. *
  499. * @param ComparisonExpression
  500. * @return string The SQL.
  501. */
  502. public function walkComparisonExpression($compExpr)
  503. {
  504. foreach ($this->_walkers as $walker) {
  505. $walker->walkComparisonExpression($compExpr);
  506. }
  507. }
  508. /**
  509. * Walks down an InputParameter AST node, thereby generating the appropriate SQL.
  510. *
  511. * @param InputParameter
  512. * @return string The SQL.
  513. */
  514. public function walkInputParameter($inputParam)
  515. {
  516. foreach ($this->_walkers as $walker) {
  517. $walker->walkInputParameter($inputParam);
  518. }
  519. }
  520. /**
  521. * Walks down an ArithmeticExpression AST node, thereby generating the appropriate SQL.
  522. *
  523. * @param ArithmeticExpression
  524. * @return string The SQL.
  525. */
  526. public function walkArithmeticExpression($arithmeticExpr)
  527. {
  528. foreach ($this->_walkers as $walker) {
  529. $walker->walkArithmeticExpression($arithmeticExpr);
  530. }
  531. }
  532. /**
  533. * Walks down an ArithmeticTerm AST node, thereby generating the appropriate SQL.
  534. *
  535. * @param mixed
  536. * @return string The SQL.
  537. */
  538. public function walkArithmeticTerm($term)
  539. {
  540. foreach ($this->_walkers as $walker) {
  541. $walker->walkArithmeticTerm($term);
  542. }
  543. }
  544. /**
  545. * Walks down a StringPrimary that represents an AST node, thereby generating the appropriate SQL.
  546. *
  547. * @param mixed
  548. * @return string The SQL.
  549. */
  550. public function walkStringPrimary($stringPrimary)
  551. {
  552. foreach ($this->_walkers as $walker) {
  553. $walker->walkStringPrimary($stringPrimary);
  554. }
  555. }
  556. /**
  557. * Walks down an ArithmeticFactor that represents an AST node, thereby generating the appropriate SQL.
  558. *
  559. * @param mixed
  560. * @return string The SQL.
  561. */
  562. public function walkArithmeticFactor($factor)
  563. {
  564. foreach ($this->_walkers as $walker) {
  565. $walker->walkArithmeticFactor($factor);
  566. }
  567. }
  568. /**
  569. * Walks down an SimpleArithmeticExpression AST node, thereby generating the appropriate SQL.
  570. *
  571. * @param SimpleArithmeticExpression
  572. * @return string The SQL.
  573. */
  574. public function walkSimpleArithmeticExpression($simpleArithmeticExpr)
  575. {
  576. foreach ($this->_walkers as $walker) {
  577. $walker->walkSimpleArithmeticExpression($simpleArithmeticExpr);
  578. }
  579. }
  580. /**
  581. * Walks down an PathExpression AST node, thereby generating the appropriate SQL.
  582. *
  583. * @param mixed
  584. * @return string The SQL.
  585. */
  586. public function walkPathExpression($pathExpr)
  587. {
  588. foreach ($this->_walkers as $walker) {
  589. $walker->walkPathExpression($pathExpr);
  590. }
  591. }
  592. /**
  593. * Walks down an ResultVariable AST node, thereby generating the appropriate SQL.
  594. *
  595. * @param string $resultVariable
  596. * @return string The SQL.
  597. */
  598. public function walkResultVariable($resultVariable)
  599. {
  600. foreach ($this->_walkers as $walker) {
  601. $walker->walkResultVariable($resultVariable);
  602. }
  603. }
  604. /**
  605. * Gets an executor that can be used to execute the result of this walker.
  606. *
  607. * @return AbstractExecutor
  608. */
  609. public function getExecutor($AST)
  610. {}
  611. }