All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.tuweni.toml.TokenName Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE
 * file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file
 * to You under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the
 * License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
 * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
 * specific language governing permissions and limitations under the License.
 */
package org.apache.tuweni.toml;

import org.apache.tuweni.toml.internal.TomlLexer;

import java.util.Arrays;
import java.util.BitSet;
import java.util.stream.Stream;

enum TokenName {
  // Ordered by display preference
  LOWER_ALPHA("a-z", TomlLexer.UnquotedKey),
  UPPER_ALPHA("A-Z", TomlLexer.UnquotedKey),
  DIGITS("0-9", TomlLexer.UnquotedKey),
  ARRAY_END("]", TomlLexer.ArrayEnd, TomlLexer.TableKeyEnd),
  ARRAY_TABLE_END("]]", TomlLexer.ArrayTableKeyEnd),
  INLINE_TABLE_END("}", TomlLexer.InlineTableEnd),
  DOT(".", TomlLexer.Dot),
  DASH("-", TomlLexer.Dash),
  PLUS("+", TomlLexer.Plus),
  COLON(":", TomlLexer.Colon),
  EQUALS("=", TomlLexer.Equals),
  COMMA("a comma", TomlLexer.Comma),
  Z("Z", TomlLexer.Z),
  APOSTROPHE("'", TomlLexer.Apostrophe, TomlLexer.MLLiteralStringEnd),
  QUOTATION_MARK("\"", TomlLexer.QuotationMark, TomlLexer.MLBasicStringEnd),
  TRIPLE_APOSTROPHE("'''", TomlLexer.TripleApostrophe),
  TRIPLE_QUOTATION_MARK("\"\"\"", TomlLexer.TripleQuotationMark),
  CHARACTER("a character", TomlLexer.EscapeSequence, TomlLexer.StringChar),
  NUMBER("a number", TomlLexer.DecimalInteger, TomlLexer.BinaryInteger, TomlLexer.OctalInteger, TomlLexer.HexInteger,
      TomlLexer.FloatingPoint, TomlLexer.FloatingPointInf, TomlLexer.FloatingPointNaN),
  BOOLEAN("a boolean", TomlLexer.TrueBoolean, TomlLexer.FalseBoolean),
  DATETIME("a date/time", TomlLexer.DateDigits),
  TIME("a time", TomlLexer.TimeDelimiter),
  ARRAY("an array", TomlLexer.ArrayStart),
  INLINE_TABLE("a table", TomlLexer.InlineTableStart),
  TABLE("a table key", TomlLexer.TableKeyStart, TomlLexer.ArrayTableKeyStart),
  NEWLINE("a newline", TomlLexer.NewLine),
  EOF("end-of-input", TomlLexer.EOF),
  NULL("NULL", 0, TomlLexer.WS, TomlLexer.Comment, TomlLexer.Error);

  private final String displayName;
  @SuppressWarnings("ImmutableEnumChecker")
  private final BitSet tokenTypes;

  TokenName(String displayName, int... tokenTypes) {
    this.displayName = displayName;
    // offset by 1 to account for EOF being -1 (moves it to zero)
    this.tokenTypes = new BitSet(TomlLexer.VOCABULARY.getMaxTokenType() + 1);
    for (int type : tokenTypes) {
      this.tokenTypes.set(type + 1);
    }
  }

  static Stream namesForToken(int tokenType) {
    return Arrays.stream(TokenName.values()).filter(n -> n.tokenTypes.get(tokenType + 1));
  }

  public String displayName() {
    return displayName;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy