annotate vendor/psy/psysh/src/TabCompletion/Matcher/ClassMethodsMatcher.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 c2387f117808
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 /**
Chris@13 15 * A class method tab completion Matcher.
Chris@13 16 *
Chris@13 17 * Given a namespace and class, this matcher provides completion for static
Chris@13 18 * methods.
Chris@13 19 *
Chris@13 20 * @author Marc Garcia <markcial@gmail.com>
Chris@13 21 */
Chris@13 22 class ClassMethodsMatcher extends AbstractMatcher
Chris@13 23 {
Chris@13 24 /**
Chris@13 25 * {@inheritdoc}
Chris@13 26 */
Chris@13 27 public function getMatches(array $tokens, array $info = [])
Chris@13 28 {
Chris@13 29 $input = $this->getInput($tokens);
Chris@13 30
Chris@13 31 $firstToken = array_pop($tokens);
Chris@13 32 if (self::tokenIs($firstToken, self::T_STRING)) {
Chris@13 33 // second token is the nekudotayim operator
Chris@13 34 array_pop($tokens);
Chris@13 35 }
Chris@13 36
Chris@13 37 $class = $this->getNamespaceAndClass($tokens);
Chris@13 38
Chris@13 39 try {
Chris@13 40 $reflection = new \ReflectionClass($class);
Chris@13 41 } catch (\ReflectionException $re) {
Chris@13 42 return [];
Chris@13 43 }
Chris@13 44
Chris@13 45 $methods = $reflection->getMethods(\ReflectionMethod::IS_STATIC);
Chris@13 46 $methods = array_map(function (\ReflectionMethod $method) {
Chris@13 47 return $method->getName();
Chris@13 48 }, $methods);
Chris@13 49
Chris@13 50 return array_map(
Chris@13 51 function ($name) use ($class) {
Chris@13 52 return $class . '::' . $name;
Chris@13 53 },
Chris@13 54 array_filter($methods, function ($method) use ($input) {
Chris@13 55 return AbstractMatcher::startsWith($input, $method);
Chris@13 56 })
Chris@13 57 );
Chris@13 58 }
Chris@13 59
Chris@13 60 /**
Chris@13 61 * {@inheritdoc}
Chris@13 62 */
Chris@13 63 public function hasMatched(array $tokens)
Chris@13 64 {
Chris@13 65 $token = array_pop($tokens);
Chris@13 66 $prevToken = array_pop($tokens);
Chris@13 67
Chris@13 68 switch (true) {
Chris@13 69 case self::tokenIs($prevToken, self::T_DOUBLE_COLON) && self::tokenIs($token, self::T_STRING):
Chris@13 70 case self::tokenIs($token, self::T_DOUBLE_COLON):
Chris@13 71 return true;
Chris@13 72 }
Chris@13 73
Chris@13 74 return false;
Chris@13 75 }
Chris@13 76 }