llvm.org GIT mirror llvm / release_60 include / llvm / TableGen / SearchableTable.td

Tree @release_60 (Download .tar.gz)

SearchableTable.td @release_60raw · history · blame

//===- SearchableTable.td ----------------------------------*- tablegen -*-===//
//                     The LLVM Compiler Infrastructure
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
// This file defines the key top-level classes needed to produce a reasonably
// generic table that can be binary-searched via int and string entries.
// Each table must instantiate "Mappingkind", listing the fields that should be
// included and fields that shoould be searchable. Only two kinds of fields are
// searchable at the moment: "strings" (which are compared case-insensitively),
// and "bits".
// For each "MappingKind" the generated header will create GET_MAPPINGKIND_DECL
// Inside the DECL guard will be a set of function declarations:
// "lookup{InstanceClass}By{SearchableField}", returning "const {InstanceClass}
// *" and accepting either a StringRef or a uintN_t. Additionally, if
// EnumNameField is still defined, there will be an "enum {InstanceClass}Values"
// allowing C++ code to reference either the primary data table's entries (if
// EnumValueField is not defined) or some other field (e.g. encoding) if it is.
// Inside the IMPL guard will be a primary data table "{InstanceClass}sList" and
// as many searchable indexes as requested
// ("{InstanceClass}sBy{SearchableField}"). Additionally implementations of the
// lookup function will be provided.
// See AArch64SystemOperands.td and its generated header for example uses.

class SearchableTable {
  list<string> SearchableFields;
  string EnumNameField = "Name";
  string EnumValueField;