annotate vendor/psy/psysh/src/TabCompletion/Matcher/AbstractMatcher.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 /**
Chris@0 15 * Abstract tab completion Matcher.
Chris@0 16 *
Chris@0 17 * @author Marc Garcia <markcial@gmail.com>
Chris@0 18 */
Chris@0 19 abstract class AbstractMatcher
Chris@0 20 {
Chris@0 21 /** Syntax types */
Chris@0 22 const CONSTANT_SYNTAX = '^[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*$';
Chris@0 23 const VAR_SYNTAX = '^\$[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*$';
Chris@0 24 const MISC_OPERATORS = '+-*/^|&';
Chris@0 25 /** Token values */
Chris@0 26 const T_OPEN_TAG = 'T_OPEN_TAG';
Chris@0 27 const T_VARIABLE = 'T_VARIABLE';
Chris@0 28 const T_OBJECT_OPERATOR = 'T_OBJECT_OPERATOR';
Chris@0 29 const T_DOUBLE_COLON = 'T_DOUBLE_COLON';
Chris@0 30 const T_NEW = 'T_NEW';
Chris@0 31 const T_CLONE = 'T_CLONE';
Chris@0 32 const T_NS_SEPARATOR = 'T_NS_SEPARATOR';
Chris@0 33 const T_STRING = 'T_STRING';
Chris@0 34 const T_WHITESPACE = 'T_WHITESPACE';
Chris@0 35 const T_AND_EQUAL = 'T_AND_EQUAL';
Chris@0 36 const T_BOOLEAN_AND = 'T_BOOLEAN_AND';
Chris@0 37 const T_BOOLEAN_OR = 'T_BOOLEAN_OR';
Chris@0 38
Chris@0 39 const T_ENCAPSED_AND_WHITESPACE = 'T_ENCAPSED_AND_WHITESPACE';
Chris@0 40 const T_REQUIRE = 'T_REQUIRE';
Chris@0 41 const T_REQUIRE_ONCE = 'T_REQUIRE_ONCE';
Chris@0 42 const T_INCLUDE = 'T_INCLUDE';
Chris@0 43 const T_INCLUDE_ONCE = 'T_INCLUDE_ONCE';
Chris@0 44
Chris@0 45 /**
Chris@0 46 * Check whether this matcher can provide completions for $tokens.
Chris@0 47 *
Chris@0 48 * @param array $tokens Tokenized readline input
Chris@0 49 *
Chris@0 50 * @return bool
Chris@0 51 */
Chris@0 52 public function hasMatched(array $tokens)
Chris@0 53 {
Chris@0 54 return false;
Chris@0 55 }
Chris@0 56
Chris@0 57 /**
Chris@0 58 * Get current readline input word.
Chris@0 59 *
Chris@0 60 * @param array $tokens Tokenized readline input (see token_get_all)
Chris@0 61 *
Chris@0 62 * @return string
Chris@0 63 */
Chris@0 64 protected function getInput(array $tokens)
Chris@0 65 {
Chris@0 66 $var = '';
Chris@4 67 $firstToken = \array_pop($tokens);
Chris@0 68 if (self::tokenIs($firstToken, self::T_STRING)) {
Chris@0 69 $var = $firstToken[1];
Chris@0 70 }
Chris@0 71
Chris@0 72 return $var;
Chris@0 73 }
Chris@0 74
Chris@0 75 /**
Chris@0 76 * Get current namespace and class (if any) from readline input.
Chris@0 77 *
Chris@0 78 * @param array $tokens Tokenized readline input (see token_get_all)
Chris@0 79 *
Chris@0 80 * @return string
Chris@0 81 */
Chris@0 82 protected function getNamespaceAndClass($tokens)
Chris@0 83 {
Chris@0 84 $class = '';
Chris@0 85 while (self::hasToken(
Chris@0 86 [self::T_NS_SEPARATOR, self::T_STRING],
Chris@4 87 $token = \array_pop($tokens)
Chris@0 88 )) {
Chris@0 89 if (self::needCompleteClass($token)) {
Chris@0 90 continue;
Chris@0 91 }
Chris@0 92
Chris@0 93 $class = $token[1] . $class;
Chris@0 94 }
Chris@0 95
Chris@0 96 return $class;
Chris@0 97 }
Chris@0 98
Chris@0 99 /**
Chris@0 100 * Provide tab completion matches for readline input.
Chris@0 101 *
Chris@0 102 * @param array $tokens information substracted with get_token_all
Chris@0 103 * @param array $info readline_info object
Chris@0 104 *
Chris@0 105 * @return array The matches resulting from the query
Chris@0 106 */
Chris@0 107 abstract public function getMatches(array $tokens, array $info = []);
Chris@0 108
Chris@0 109 /**
Chris@0 110 * Check whether $word starts with $prefix.
Chris@0 111 *
Chris@0 112 * @param string $prefix
Chris@0 113 * @param string $word
Chris@0 114 *
Chris@0 115 * @return bool
Chris@0 116 */
Chris@0 117 public static function startsWith($prefix, $word)
Chris@0 118 {
Chris@4 119 return \preg_match(\sprintf('#^%s#', $prefix), $word);
Chris@0 120 }
Chris@0 121
Chris@0 122 /**
Chris@0 123 * Check whether $token matches a given syntax pattern.
Chris@0 124 *
Chris@0 125 * @param mixed $token A PHP token (see token_get_all)
Chris@0 126 * @param string $syntax A syntax pattern (default: variable pattern)
Chris@0 127 *
Chris@0 128 * @return bool
Chris@0 129 */
Chris@0 130 public static function hasSyntax($token, $syntax = self::VAR_SYNTAX)
Chris@0 131 {
Chris@4 132 if (!\is_array($token)) {
Chris@0 133 return false;
Chris@0 134 }
Chris@0 135
Chris@4 136 $regexp = \sprintf('#%s#', $syntax);
Chris@0 137
Chris@4 138 return (bool) \preg_match($regexp, $token[1]);
Chris@0 139 }
Chris@0 140
Chris@0 141 /**
Chris@0 142 * Check whether $token type is $which.
Chris@0 143 *
Chris@0 144 * @param string $which A PHP token type
Chris@0 145 * @param mixed $token A PHP token (see token_get_all)
Chris@0 146 *
Chris@0 147 * @return bool
Chris@0 148 */
Chris@0 149 public static function tokenIs($token, $which)
Chris@0 150 {
Chris@4 151 if (!\is_array($token)) {
Chris@0 152 return false;
Chris@0 153 }
Chris@0 154
Chris@4 155 return \token_name($token[0]) === $which;
Chris@0 156 }
Chris@0 157
Chris@0 158 /**
Chris@0 159 * Check whether $token is an operator.
Chris@0 160 *
Chris@0 161 * @param mixed $token A PHP token (see token_get_all)
Chris@0 162 *
Chris@0 163 * @return bool
Chris@0 164 */
Chris@0 165 public static function isOperator($token)
Chris@0 166 {
Chris@4 167 if (!\is_string($token)) {
Chris@0 168 return false;
Chris@0 169 }
Chris@0 170
Chris@4 171 return \strpos(self::MISC_OPERATORS, $token) !== false;
Chris@0 172 }
Chris@0 173
Chris@0 174 public static function needCompleteClass($token)
Chris@0 175 {
Chris@4 176 return \in_array($token[1], ['doc', 'ls', 'show']);
Chris@0 177 }
Chris@0 178
Chris@0 179 /**
Chris@0 180 * Check whether $token type is present in $coll.
Chris@0 181 *
Chris@0 182 * @param array $coll A list of token types
Chris@0 183 * @param mixed $token A PHP token (see token_get_all)
Chris@0 184 *
Chris@0 185 * @return bool
Chris@0 186 */
Chris@0 187 public static function hasToken(array $coll, $token)
Chris@0 188 {
Chris@4 189 if (!\is_array($token)) {
Chris@0 190 return false;
Chris@0 191 }
Chris@0 192
Chris@4 193 return \in_array(\token_name($token[0]), $coll);
Chris@0 194 }
Chris@0 195 }