annotate vendor/psy/psysh/src/Psy/Reflection/ReflectionLanguageConstructParameter.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\Reflection;
Chris@0 13
Chris@0 14 /**
Chris@0 15 * A fake ReflectionParameter but for language construct parameters.
Chris@0 16 *
Chris@0 17 * It stubs out all the important bits and returns whatever was passed in $opts.
Chris@0 18 */
Chris@0 19 class ReflectionLanguageConstructParameter extends \ReflectionParameter
Chris@0 20 {
Chris@0 21 private $function;
Chris@0 22 private $parameter;
Chris@0 23 private $opts;
Chris@0 24
Chris@0 25 public function __construct($function, $parameter, array $opts)
Chris@0 26 {
Chris@0 27 $this->function = $function;
Chris@0 28 $this->parameter = $parameter;
Chris@0 29 $this->opts = $opts;
Chris@0 30 }
Chris@0 31
Chris@0 32 /**
Chris@0 33 * No class here.
Chris@0 34 */
Chris@0 35 public function getClass()
Chris@0 36 {
Chris@0 37 return;
Chris@0 38 }
Chris@0 39
Chris@0 40 /**
Chris@0 41 * Is the param an array?
Chris@0 42 *
Chris@0 43 * @return bool
Chris@0 44 */
Chris@0 45 public function isArray()
Chris@0 46 {
Chris@0 47 return array_key_exists('isArray', $this->opts) && $this->opts['isArray'];
Chris@0 48 }
Chris@0 49
Chris@0 50 /**
Chris@0 51 * Get param default value.
Chris@0 52 *
Chris@0 53 * @return mixed
Chris@0 54 */
Chris@0 55 public function getDefaultValue()
Chris@0 56 {
Chris@0 57 if ($this->isDefaultValueAvailable()) {
Chris@0 58 return $this->opts['defaultValue'];
Chris@0 59 }
Chris@0 60 }
Chris@0 61
Chris@0 62 /**
Chris@0 63 * Get param name.
Chris@0 64 *
Chris@0 65 * @return string
Chris@0 66 */
Chris@0 67 public function getName()
Chris@0 68 {
Chris@0 69 return $this->parameter;
Chris@0 70 }
Chris@0 71
Chris@0 72 /**
Chris@0 73 * Is the param optional?
Chris@0 74 *
Chris@0 75 * @return bool
Chris@0 76 */
Chris@0 77 public function isOptional()
Chris@0 78 {
Chris@0 79 return array_key_exists('isOptional', $this->opts) && $this->opts['isOptional'];
Chris@0 80 }
Chris@0 81
Chris@0 82 /**
Chris@0 83 * Does the param have a default value?
Chris@0 84 *
Chris@0 85 * @return bool
Chris@0 86 */
Chris@0 87 public function isDefaultValueAvailable()
Chris@0 88 {
Chris@0 89 return array_key_exists('defaultValue', $this->opts);
Chris@0 90 }
Chris@0 91
Chris@0 92 /**
Chris@0 93 * Is the param passed by reference?
Chris@0 94 *
Chris@0 95 * (I don't think this is true for anything we need to fake a param for)
Chris@0 96 *
Chris@0 97 * @return bool
Chris@0 98 */
Chris@0 99 public function isPassedByReference()
Chris@0 100 {
Chris@0 101 return array_key_exists('isPassedByReference', $this->opts) && $this->opts['isPassedByReference'];
Chris@0 102 }
Chris@0 103 }