annotate vendor/psy/psysh/src/TabCompletion/Matcher/ObjectAttributesMatcher.php @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents 129ea1e6d783
children
rev   line source
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 }