annotate vendor/psy/psysh/src/TabCompletion/Matcher/ObjectAttributesMatcher.php @ 5:12f9dff5fda9 tip

Update to Drupal core 8.7.1
author Chris Cannam
date Thu, 09 May 2019 15:34:47 +0100
parents a9cd425dd02b
children
rev   line source
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-2018 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 use InvalidArgumentException;
Chris@0 15
Chris@0 16 /**
Chris@0 17 * An object attribute tab completion Matcher.
Chris@0 18 *
Chris@0 19 * This matcher provides completion for properties of objects in the current
Chris@0 20 * Context.
Chris@0 21 *
Chris@0 22 * @author Marc Garcia <markcial@gmail.com>
Chris@0 23 */
Chris@0 24 class ObjectAttributesMatcher extends AbstractContextAwareMatcher
Chris@0 25 {
Chris@0 26 /**
Chris@0 27 * {@inheritdoc}
Chris@0 28 */
Chris@0 29 public function getMatches(array $tokens, array $info = [])
Chris@0 30 {
Chris@0 31 $input = $this->getInput($tokens);
Chris@0 32
Chris@4 33 $firstToken = \array_pop($tokens);
Chris@0 34 if (self::tokenIs($firstToken, self::T_STRING)) {
Chris@0 35 // second token is the object operator
Chris@4 36 \array_pop($tokens);
Chris@0 37 }
Chris@4 38 $objectToken = \array_pop($tokens);
Chris@4 39 if (!\is_array($objectToken)) {
Chris@0 40 return [];
Chris@0 41 }
Chris@4 42 $objectName = \str_replace('$', '', $objectToken[1]);
Chris@0 43
Chris@0 44 try {
Chris@0 45 $object = $this->getVariable($objectName);
Chris@0 46 } catch (InvalidArgumentException $e) {
Chris@0 47 return [];
Chris@0 48 }
Chris@0 49
Chris@4 50 if (!\is_object($object)) {
Chris@0 51 return [];
Chris@0 52 }
Chris@0 53
Chris@4 54 return \array_filter(
Chris@4 55 \array_keys(\get_class_vars(\get_class($object))),
Chris@0 56 function ($var) use ($input) {
Chris@0 57 return AbstractMatcher::startsWith($input, $var);
Chris@0 58 }
Chris@0 59 );
Chris@0 60 }
Chris@0 61
Chris@0 62 /**
Chris@0 63 * {@inheritdoc}
Chris@0 64 */
Chris@0 65 public function hasMatched(array $tokens)
Chris@0 66 {
Chris@4 67 $token = \array_pop($tokens);
Chris@4 68 $prevToken = \array_pop($tokens);
Chris@0 69
Chris@0 70 switch (true) {
Chris@0 71 case self::tokenIs($token, self::T_OBJECT_OPERATOR):
Chris@0 72 case self::tokenIs($prevToken, self::T_OBJECT_OPERATOR):
Chris@0 73 return true;
Chris@0 74 }
Chris@0 75
Chris@0 76 return false;
Chris@0 77 }
Chris@0 78 }