xref: /template/strap/vendor/antlr/antlr4-php-runtime/src/Atn/Actions/LexerPushModeAction.php (revision 37748cd8654635afbeca80942126742f0f4cc346)
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