Chris@13
|
1 <?php
|
Chris@13
|
2
|
Chris@13
|
3 /*
|
Chris@13
|
4 * This file is part of Psy Shell.
|
Chris@13
|
5 *
|
Chris@13
|
6 * (c) 2012-2018 Justin Hileman
|
Chris@13
|
7 *
|
Chris@13
|
8 * For the full copyright and license information, please view the LICENSE
|
Chris@13
|
9 * file that was distributed with this source code.
|
Chris@13
|
10 */
|
Chris@13
|
11
|
Chris@13
|
12 namespace Psy\TabCompletion\Matcher;
|
Chris@13
|
13
|
Chris@13
|
14 use InvalidArgumentException;
|
Chris@13
|
15
|
Chris@13
|
16 /**
|
Chris@13
|
17 * An object attribute tab completion Matcher.
|
Chris@13
|
18 *
|
Chris@13
|
19 * This matcher provides completion for properties of objects in the current
|
Chris@13
|
20 * Context.
|
Chris@13
|
21 *
|
Chris@13
|
22 * @author Marc Garcia <markcial@gmail.com>
|
Chris@13
|
23 */
|
Chris@13
|
24 class ObjectAttributesMatcher extends AbstractContextAwareMatcher
|
Chris@13
|
25 {
|
Chris@13
|
26 /**
|
Chris@13
|
27 * {@inheritdoc}
|
Chris@13
|
28 */
|
Chris@13
|
29 public function getMatches(array $tokens, array $info = [])
|
Chris@13
|
30 {
|
Chris@13
|
31 $input = $this->getInput($tokens);
|
Chris@13
|
32
|
Chris@17
|
33 $firstToken = \array_pop($tokens);
|
Chris@13
|
34 if (self::tokenIs($firstToken, self::T_STRING)) {
|
Chris@13
|
35 // second token is the object operator
|
Chris@17
|
36 \array_pop($tokens);
|
Chris@13
|
37 }
|
Chris@17
|
38 $objectToken = \array_pop($tokens);
|
Chris@17
|
39 if (!\is_array($objectToken)) {
|
Chris@13
|
40 return [];
|
Chris@13
|
41 }
|
Chris@17
|
42 $objectName = \str_replace('$', '', $objectToken[1]);
|
Chris@13
|
43
|
Chris@13
|
44 try {
|
Chris@13
|
45 $object = $this->getVariable($objectName);
|
Chris@13
|
46 } catch (InvalidArgumentException $e) {
|
Chris@13
|
47 return [];
|
Chris@13
|
48 }
|
Chris@13
|
49
|
Chris@17
|
50 if (!\is_object($object)) {
|
Chris@13
|
51 return [];
|
Chris@13
|
52 }
|
Chris@13
|
53
|
Chris@17
|
54 return \array_filter(
|
Chris@17
|
55 \array_keys(\get_class_vars(\get_class($object))),
|
Chris@13
|
56 function ($var) use ($input) {
|
Chris@13
|
57 return AbstractMatcher::startsWith($input, $var);
|
Chris@13
|
58 }
|
Chris@13
|
59 );
|
Chris@13
|
60 }
|
Chris@13
|
61
|
Chris@13
|
62 /**
|
Chris@13
|
63 * {@inheritdoc}
|
Chris@13
|
64 */
|
Chris@13
|
65 public function hasMatched(array $tokens)
|
Chris@13
|
66 {
|
Chris@17
|
67 $token = \array_pop($tokens);
|
Chris@17
|
68 $prevToken = \array_pop($tokens);
|
Chris@13
|
69
|
Chris@13
|
70 switch (true) {
|
Chris@13
|
71 case self::tokenIs($token, self::T_OBJECT_OPERATOR):
|
Chris@13
|
72 case self::tokenIs($prevToken, self::T_OBJECT_OPERATOR):
|
Chris@13
|
73 return true;
|
Chris@13
|
74 }
|
Chris@13
|
75
|
Chris@13
|
76 return false;
|
Chris@13
|
77 }
|
Chris@13
|
78 }
|