Chris@0
|
1 <?php
|
Chris@0
|
2
|
Chris@0
|
3 /*
|
Chris@0
|
4 * This file is part of Psy Shell.
|
Chris@0
|
5 *
|
Chris@0
|
6 * (c) 2012-2017 Justin Hileman
|
Chris@0
|
7 *
|
Chris@0
|
8 * For the full copyright and license information, please view the LICENSE
|
Chris@0
|
9 * file that was distributed with this source code.
|
Chris@0
|
10 */
|
Chris@0
|
11
|
Chris@0
|
12 namespace Psy\TabCompletion\Matcher;
|
Chris@0
|
13
|
Chris@0
|
14 /**
|
Chris@0
|
15 * A PHP keyword tab completion Matcher.
|
Chris@0
|
16 *
|
Chris@0
|
17 * This matcher provides completion for all function-like PHP keywords.
|
Chris@0
|
18 *
|
Chris@0
|
19 * @author Marc Garcia <markcial@gmail.com>
|
Chris@0
|
20 */
|
Chris@0
|
21 class KeywordsMatcher extends AbstractMatcher
|
Chris@0
|
22 {
|
Chris@0
|
23 protected $keywords = array(
|
Chris@0
|
24 'array', 'clone', 'declare', 'die', 'echo', 'empty', 'eval', 'exit', 'include',
|
Chris@0
|
25 'include_once', 'isset', 'list', 'print', 'require', 'require_once', 'unset',
|
Chris@0
|
26 );
|
Chris@0
|
27
|
Chris@0
|
28 protected $mandatoryStartKeywords = array(
|
Chris@0
|
29 'die', 'echo', 'print', 'unset',
|
Chris@0
|
30 );
|
Chris@0
|
31
|
Chris@0
|
32 /**
|
Chris@0
|
33 * Get all (completable) PHP keywords.
|
Chris@0
|
34 *
|
Chris@0
|
35 * @return array
|
Chris@0
|
36 */
|
Chris@0
|
37 public function getKeywords()
|
Chris@0
|
38 {
|
Chris@0
|
39 return $this->keywords;
|
Chris@0
|
40 }
|
Chris@0
|
41
|
Chris@0
|
42 /**
|
Chris@0
|
43 * Check whether $keyword is a (completable) PHP keyword.
|
Chris@0
|
44 *
|
Chris@0
|
45 * @param string $keyword
|
Chris@0
|
46 *
|
Chris@0
|
47 * @return bool
|
Chris@0
|
48 */
|
Chris@0
|
49 public function isKeyword($keyword)
|
Chris@0
|
50 {
|
Chris@0
|
51 return in_array($keyword, $this->keywords);
|
Chris@0
|
52 }
|
Chris@0
|
53
|
Chris@0
|
54 /**
|
Chris@0
|
55 * {@inheritdoc}
|
Chris@0
|
56 */
|
Chris@0
|
57 public function getMatches(array $tokens, array $info = array())
|
Chris@0
|
58 {
|
Chris@0
|
59 $input = $this->getInput($tokens);
|
Chris@0
|
60
|
Chris@0
|
61 return array_filter($this->keywords, function ($keyword) use ($input) {
|
Chris@0
|
62 return AbstractMatcher::startsWith($input, $keyword);
|
Chris@0
|
63 });
|
Chris@0
|
64 }
|
Chris@0
|
65
|
Chris@0
|
66 /**
|
Chris@0
|
67 * {@inheritdoc}
|
Chris@0
|
68 */
|
Chris@0
|
69 public function hasMatched(array $tokens)
|
Chris@0
|
70 {
|
Chris@0
|
71 $token = array_pop($tokens);
|
Chris@0
|
72 $prevToken = array_pop($tokens);
|
Chris@0
|
73
|
Chris@0
|
74 switch (true) {
|
Chris@0
|
75 case self::hasToken(array(self::T_OPEN_TAG, self::T_VARIABLE), $token):
|
Chris@0
|
76 // case is_string($token) && $token === '$':
|
Chris@0
|
77 case self::hasToken(array(self::T_OPEN_TAG, self::T_VARIABLE), $prevToken) &&
|
Chris@0
|
78 self::tokenIs($token, self::T_STRING):
|
Chris@0
|
79 case self::isOperator($token):
|
Chris@0
|
80 return true;
|
Chris@0
|
81 }
|
Chris@0
|
82
|
Chris@0
|
83 return false;
|
Chris@0
|
84 }
|
Chris@0
|
85 }
|