Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
/* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
 * Use of this file is governed by the BSD 3-clause license that
 * can be found in the LICENSE.txt file in the project root.
 */
using Antlr4.Runtime;
using Antlr4.Runtime.Atn;
using Antlr4.Runtime.Misc;
using Antlr4.Runtime.Sharpen;

namespace Antlr4.Runtime.Atn
{
    /// <summary>
    /// Executes a custom lexer action by calling
    /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
    /// with the
    /// rule and action indexes assigned to the custom action. The implementation of
    /// a custom action is added to the generated code for the lexer in an override
    /// of
    /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
    /// when the grammar is compiled.
    /// <p>This class may represent embedded actions created with the <code>{...}</code>
    /// syntax in ANTLR 4, as well as actions created for lexer commands where the
    /// command argument could not be evaluated when the grammar was compiled.</p>
    /// </summary>
    /// <author>Sam Harwell</author>
    /// <since>4.2</since>
    public sealed class LexerCustomAction : ILexerAction
    {
        private readonly int ruleIndex;

        private readonly int actionIndex;

        /// <summary>
        /// Constructs a custom lexer action with the specified rule and action
        /// indexes.
        /// </summary>
        /// <remarks>
        /// Constructs a custom lexer action with the specified rule and action
        /// indexes.
        /// </remarks>
        /// <param name="ruleIndex">
        /// The rule index to use for calls to
        /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
        /// .
        /// </param>
        /// <param name="actionIndex">
        /// The action index to use for calls to
        /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
        /// .
        /// </param>
        public LexerCustomAction(int ruleIndex, int actionIndex)
        {
            this.ruleIndex = ruleIndex;
            this.actionIndex = actionIndex;
        }

        /// <summary>
        /// Gets the rule index to use for calls to
        /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
        /// .
        /// </summary>
        /// <returns>The rule index for the custom action.</returns>
        public int RuleIndex
        {
            get
            {
                return ruleIndex;
            }
        }

        /// <summary>
        /// Gets the action index to use for calls to
        /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
        /// .
        /// </summary>
        /// <returns>The action index for the custom action.</returns>
        public int ActionIndex
        {
            get
            {
                return actionIndex;
            }
        }

        /// <summary><inheritDoc/></summary>
        /// <returns>
        /// This method returns
        /// <see cref="LexerActionType.Custom"/>
        /// .
        /// </returns>
        public LexerActionType ActionType
        {
            get
            {
                return LexerActionType.Custom;
            }
        }

        /// <summary>Gets whether the lexer action is position-dependent.</summary>
        /// <remarks>
        /// Gets whether the lexer action is position-dependent. Position-dependent
        /// actions may have different semantics depending on the
        /// <see cref="Antlr4.Runtime.ICharStream"/>
        /// index at the time the action is executed.
        /// <p>Custom actions are position-dependent since they may represent a
        /// user-defined embedded action which makes calls to methods like
        /// <see cref="Antlr4.Runtime.Lexer.Text()"/>
        /// .</p>
        /// </remarks>
        /// <returns>
        /// This method returns
        /// <see langword="true"/>
        /// .
        /// </returns>
        public bool IsPositionDependent
        {
            get
            {
                return true;
            }
        }

        /// <summary>
        /// <inheritDoc/>
        /// <p>Custom actions are implemented by calling
        /// <see cref="Antlr4.Runtime.Recognizer{Symbol, ATNInterpreter}.Action(Antlr4.Runtime.RuleContext, int, int)"/>
        /// with the
        /// appropriate rule and action indexes.</p>
        /// </summary>
        public void Execute(Lexer lexer)
        {
            lexer.Action(null, ruleIndex, actionIndex);
        }

        public override int GetHashCode()
        {
            int hash = MurmurHash.Initialize();
            hash = MurmurHash.Update(hash, (int)(ActionType));
            hash = MurmurHash.Update(hash, ruleIndex);
            hash = MurmurHash.Update(hash, actionIndex);
            return MurmurHash.Finish(hash, 3);
        }

        public override bool Equals(object obj)
        {
            if (obj == this)
            {
                return true;
            }
            else
            {
                if (!(obj is Antlr4.Runtime.Atn.LexerCustomAction))
                {
                    return false;
                }
            }
            Antlr4.Runtime.Atn.LexerCustomAction other = (Antlr4.Runtime.Atn.LexerCustomAction)obj;
            return ruleIndex == other.ruleIndex && actionIndex == other.actionIndex;
        }
    }
}