annotate vendor/psy/psysh/src/TabCompletion/Matcher/ObjectMethodsMatcher.php @ 13:5fb285c0d0e3

Update Drupal core to 8.4.7 via Composer. Security update; I *think* we've been lucky to get away with this so far, as we don't support self-registration which seems to be used by the so-called "drupalgeddon 2" attack that 8.4.5 was vulnerable to.
author Chris Cannam
date Mon, 23 Apr 2018 09:33:26 +0100
parents
children 129ea1e6d783
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 method tab completion Matcher.
Chris@13 18 *
Chris@13 19 * This matcher provides completion for methods 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 ObjectMethodsMatcher 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@13 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@13 36 array_pop($tokens);
Chris@13 37 }
Chris@13 38 $objectToken = array_pop($tokens);
Chris@13 39 if (!is_array($objectToken)) {
Chris@13 40 return [];
Chris@13 41 }
Chris@13 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@13 50 if (!is_object($object)) {
Chris@13 51 return [];
Chris@13 52 }
Chris@13 53
Chris@13 54 return array_filter(
Chris@13 55 get_class_methods($object),
Chris@13 56 function ($var) use ($input) {
Chris@13 57 return AbstractMatcher::startsWith($input, $var) &&
Chris@13 58 // also check that we do not suggest invoking a super method(__construct, __wakeup, …)
Chris@13 59 !AbstractMatcher::startsWith('__', $var);
Chris@13 60 }
Chris@13 61 );
Chris@13 62 }
Chris@13 63
Chris@13 64 /**
Chris@13 65 * {@inheritdoc}
Chris@13 66 */
Chris@13 67 public function hasMatched(array $tokens)
Chris@13 68 {
Chris@13 69 $token = array_pop($tokens);
Chris@13 70 $prevToken = array_pop($tokens);
Chris@13 71
Chris@13 72 switch (true) {
Chris@13 73 case self::tokenIs($token, self::T_OBJECT_OPERATOR):
Chris@13 74 case self::tokenIs($prevToken, self::T_OBJECT_OPERATOR):
Chris@13 75 return true;
Chris@13 76 }
Chris@13 77
Chris@13 78 return false;
Chris@13 79 }
Chris@13 80 }