annotate vendor/psy/psysh/src/Psy/TabCompletion/Matcher/ObjectAttributesMatcher.php @ 0:4c8ae668cc8c

Initial import (non-working)
author Chris Cannam
date Wed, 29 Nov 2017 16:09:58 +0000
parents
children 7a779792577d
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-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 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 = array())
Chris@0 30 {
Chris@0 31 $input = $this->getInput($tokens);
Chris@0 32
Chris@0 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@0 36 array_pop($tokens);
Chris@0 37 }
Chris@0 38 $objectToken = array_pop($tokens);
Chris@0 39 if (!is_array($objectToken)) {
Chris@0 40 return array();
Chris@0 41 }
Chris@0 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 array();
Chris@0 48 }
Chris@0 49
Chris@0 50 if (!is_object($object)) {
Chris@0 51 return array();
Chris@0 52 }
Chris@0 53
Chris@0 54 return array_filter(
Chris@0 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@0 67 $token = array_pop($tokens);
Chris@0 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 }