/*
 * 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.
 */

package org.antlr.v4.runtime.tree.pattern;

import org.antlr.v4.runtime.CommonToken;
import org.antlr.v4.runtime.Token;

A Token object representing a token of a particular type; e.g., <ID>. These tokens are created for TagChunk chunks where the tag corresponds to a lexer rule or token type.
/** * A {@link Token} object representing a token of a particular type; e.g., * {@code <ID>}. These tokens are created for {@link TagChunk} chunks where the * tag corresponds to a lexer rule or token type. */
public class TokenTagToken extends CommonToken {
This is the backing field for getTokenName.
/** * This is the backing field for {@link #getTokenName}. */
private final String tokenName;
This is the backing field for getLabel.
/** * This is the backing field for {@link #getLabel}. */
private final String label;
Constructs a new instance of TokenTagToken for an unlabeled tag with the specified token name and type.
Params:
  • tokenName – The token name.
  • type – The token type.
/** * Constructs a new instance of {@link TokenTagToken} for an unlabeled tag * with the specified token name and type. * * @param tokenName The token name. * @param type The token type. */
public TokenTagToken(String tokenName, int type) { this(tokenName, type, null); }
Constructs a new instance of TokenTagToken with the specified token name, type, and label.
Params:
  • tokenName – The token name.
  • type – The token type.
  • label – The label associated with the token tag, or null if the token tag is unlabeled.
/** * Constructs a new instance of {@link TokenTagToken} with the specified * token name, type, and label. * * @param tokenName The token name. * @param type The token type. * @param label The label associated with the token tag, or {@code null} if * the token tag is unlabeled. */
public TokenTagToken(String tokenName, int type, String label) { super(type); this.tokenName = tokenName; this.label = label; }
Gets the token name.
Returns:The token name.
/** * Gets the token name. * @return The token name. */
public final String getTokenName() { return tokenName; }
Gets the label associated with the rule tag.
Returns:The name of the label associated with the rule tag, or null if this is an unlabeled rule tag.
/** * Gets the label associated with the rule tag. * * @return The name of the label associated with the rule tag, or * {@code null} if this is an unlabeled rule tag. */
public final String getLabel() { return label; }
{@inheritDoc}

The implementation for TokenTagToken returns the token tag formatted with < and > delimiters.

/** * {@inheritDoc} * * <p>The implementation for {@link TokenTagToken} returns the token tag * formatted with {@code <} and {@code >} delimiters.</p> */
@Override public String getText() { if (label != null) { return "<" + label + ":" + tokenName + ">"; } return "<" + tokenName + ">"; }
{@inheritDoc}

The implementation for TokenTagToken returns a string of the form tokenName:type.

/** * {@inheritDoc} * * <p>The implementation for {@link TokenTagToken} returns a string of the form * {@code tokenName:type}.</p> */
@Override public String toString() { return tokenName + ":" + type; } }