1*37748cd8SNickeau<?php 2*37748cd8SNickeau 3*37748cd8SNickeaudeclare(strict_types=1); 4*37748cd8SNickeau 5*37748cd8SNickeaunamespace Antlr\Antlr4\Runtime\Atn\Actions; 6*37748cd8SNickeau 7*37748cd8SNickeauuse Antlr\Antlr4\Runtime\Comparison\Hasher; 8*37748cd8SNickeauuse Antlr\Antlr4\Runtime\Lexer; 9*37748cd8SNickeau 10*37748cd8SNickeau/** 11*37748cd8SNickeau * Implements the `pushMode` lexer action by calling {@see Lexer::pushMode()} 12*37748cd8SNickeau * with the assigned mode. 13*37748cd8SNickeau * 14*37748cd8SNickeau * @author Sam Harwell 15*37748cd8SNickeau */ 16*37748cd8SNickeaufinal class LexerPushModeAction implements LexerAction 17*37748cd8SNickeau{ 18*37748cd8SNickeau /** @var int */ 19*37748cd8SNickeau private $mode; 20*37748cd8SNickeau 21*37748cd8SNickeau public function __construct(int $mode) 22*37748cd8SNickeau { 23*37748cd8SNickeau $this->mode = $mode; 24*37748cd8SNickeau } 25*37748cd8SNickeau 26*37748cd8SNickeau /** 27*37748cd8SNickeau * Get the lexer mode this action should transition the lexer to. 28*37748cd8SNickeau * 29*37748cd8SNickeau * @return int The lexer mode for this `pushMode` command. 30*37748cd8SNickeau */ 31*37748cd8SNickeau public function getMode() : int 32*37748cd8SNickeau { 33*37748cd8SNickeau return $this->mode; 34*37748cd8SNickeau } 35*37748cd8SNickeau 36*37748cd8SNickeau /** 37*37748cd8SNickeau * {@inheritdoc} 38*37748cd8SNickeau * 39*37748cd8SNickeau * @return int This method returns {@see LexerActionType::PUSH_MODE}. 40*37748cd8SNickeau */ 41*37748cd8SNickeau public function getActionType() : int 42*37748cd8SNickeau { 43*37748cd8SNickeau return LexerActionType::PUSH_MODE; 44*37748cd8SNickeau } 45*37748cd8SNickeau 46*37748cd8SNickeau /** 47*37748cd8SNickeau * {@inheritdoc} 48*37748cd8SNickeau * 49*37748cd8SNickeau * @return bool This method returns `false`. 50*37748cd8SNickeau */ 51*37748cd8SNickeau public function isPositionDependent() : bool 52*37748cd8SNickeau { 53*37748cd8SNickeau return false; 54*37748cd8SNickeau } 55*37748cd8SNickeau 56*37748cd8SNickeau /** 57*37748cd8SNickeau * {@inheritdoc} 58*37748cd8SNickeau * 59*37748cd8SNickeau * This action is implemented by calling {@see Lexer::pushMode()} with the 60*37748cd8SNickeau * value provided by {@see LexerPushModeAction::getMode()}. 61*37748cd8SNickeau */ 62*37748cd8SNickeau public function execute(Lexer $lexer) : void 63*37748cd8SNickeau { 64*37748cd8SNickeau $lexer->pushMode($this->mode); 65*37748cd8SNickeau } 66*37748cd8SNickeau 67*37748cd8SNickeau public function hashCode() : int 68*37748cd8SNickeau { 69*37748cd8SNickeau return Hasher::hash($this->getActionType(), $this->mode); 70*37748cd8SNickeau } 71*37748cd8SNickeau 72*37748cd8SNickeau public function equals(object $other) : bool 73*37748cd8SNickeau { 74*37748cd8SNickeau if ($this === $other) { 75*37748cd8SNickeau return true; 76*37748cd8SNickeau } 77*37748cd8SNickeau 78*37748cd8SNickeau if (!$other instanceof self) { 79*37748cd8SNickeau return false; 80*37748cd8SNickeau } 81*37748cd8SNickeau 82*37748cd8SNickeau return $this->mode === $other->mode; 83*37748cd8SNickeau } 84*37748cd8SNickeau 85*37748cd8SNickeau public function __toString() : string 86*37748cd8SNickeau { 87*37748cd8SNickeau return \sprintf('pushMode(%d)', $this->mode); 88*37748cd8SNickeau } 89*37748cd8SNickeau} 90