blob: 85163b3f07ed8119728e2e4d782bcf2e21874859 [file] [log] [blame]
/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
|* *|
|* Attribute name matcher *|
|* *|
|* Automatically generated file, do not edit! *|
|* *|
\*===----------------------------------------------------------------------===*/
static AttributeCommonInfo::Kind getAttrKind(StringRef Name, AttributeCommonInfo::Syntax Syntax) {
if (AttributeCommonInfo::AS_GNU == Syntax) {
switch (Name.size()) {
default: break;
case 3: // 3 strings to match.
switch (Name[0]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "ar", 2) != 0)
break;
return AttributeCommonInfo::AT_MipsLongCall; // "far"
case 'h': // 1 string to match.
if (memcmp(Name.data()+1, "ot", 2) != 0)
break;
return AttributeCommonInfo::AT_Hot; // "hot"
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "cs", 2) != 0)
break;
return AttributeCommonInfo::AT_Pcs; // "pcs"
}
break;
case 4: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "old", 3) != 0)
break;
return AttributeCommonInfo::AT_Cold; // "cold"
case 'h': // 1 string to match.
if (memcmp(Name.data()+1, "ost", 3) != 0)
break;
return AttributeCommonInfo::AT_CUDAHost; // "host"
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "eaf", 3) != 0)
break;
return AttributeCommonInfo::AT_Leaf; // "leaf"
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "ode", 3) != 0)
break;
return AttributeCommonInfo::AT_Mode; // "mode"
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "ear", 3) != 0)
break;
return AttributeCommonInfo::AT_MipsShortCall; // "near"
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "ure", 3) != 0)
break;
return AttributeCommonInfo::AT_Pure; // "pure"
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "sed", 3) != 0)
break;
return AttributeCommonInfo::AT_Used; // "used"
case 'w': // 1 string to match.
if (memcmp(Name.data()+1, "eak", 3) != 0)
break;
return AttributeCommonInfo::AT_Weak; // "weak"
}
break;
case 5: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "lias", 4) != 0)
break;
return AttributeCommonInfo::AT_Alias; // "alias"
case 'c': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+2, "ecl", 3) != 0)
break;
return AttributeCommonInfo::AT_CDecl; // "cdecl"
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "nst", 3) != 0)
break;
return AttributeCommonInfo::AT_Const; // "const"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "func", 4) != 0)
break;
return AttributeCommonInfo::AT_IFunc; // "ifunc"
case 'n': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "ked", 3) != 0)
break;
return AttributeCommonInfo::AT_Naked; // "naked"
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "svm", 3) != 0)
break;
return AttributeCommonInfo::AT_OpenCLNoSVM; // "nosvm"
}
break;
}
break;
case 6: // 16 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "ssume", 5) != 0)
break;
return AttributeCommonInfo::AT_Assumption; // "assume"
case 'b': // 1 string to match.
if (memcmp(Name.data()+1, "locks", 5) != 0)
break;
return AttributeCommonInfo::AT_Blocks; // "blocks"
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "ommon", 5) != 0)
break;
return AttributeCommonInfo::AT_Common; // "common"
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "evice", 5) != 0)
break;
return AttributeCommonInfo::AT_CUDADevice; // "device"
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "ormat", 5) != 0)
break;
return AttributeCommonInfo::AT_Format; // "format"
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "lobal", 5) != 0)
break;
return AttributeCommonInfo::AT_CUDAGlobal; // "global"
case 'k': // 1 string to match.
if (memcmp(Name.data()+1, "ernel", 5) != 0)
break;
return AttributeCommonInfo::AT_RenderScriptKernel; // "kernel"
case 'm': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "lloc", 4) != 0)
break;
return AttributeCommonInfo::AT_Restrict; // "malloc"
case 'i': // 1 string to match.
if (memcmp(Name.data()+2, "ps16", 4) != 0)
break;
return AttributeCommonInfo::AT_Mips16; // "mips16"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_abi", 4) != 0)
break;
return AttributeCommonInfo::AT_MSABI; // "ms_abi"
}
break;
case 'p': // 2 strings to match.
if (Name[1] != 'a')
break;
switch (Name[2]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+3, "ked", 3) != 0)
break;
return AttributeCommonInfo::AT_Packed; // "packed"
case 's': // 1 string to match.
if (memcmp(Name.data()+3, "cal", 3) != 0)
break;
return AttributeCommonInfo::AT_Pascal; // "pascal"
}
break;
case 's': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+2, "ared", 4) != 0)
break;
return AttributeCommonInfo::AT_CUDAShared; // "shared"
case 'i': // 1 string to match.
if (memcmp(Name.data()+2, "gnal", 4) != 0)
break;
return AttributeCommonInfo::AT_AVRSignal; // "signal"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "arget", 5) != 0)
break;
return AttributeCommonInfo::AT_Target; // "target"
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "nused", 5) != 0)
break;
return AttributeCommonInfo::AT_Unused; // "unused"
}
break;
case 7: // 20 strings to match.
switch (Name[0]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+1, "_const", 6) != 0)
break;
return AttributeCommonInfo::AT_Const; // "__const"
case 'a': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+2, "i_tag", 5) != 0)
break;
return AttributeCommonInfo::AT_AbiTag; // "abi_tag"
case 'l': // 1 string to match.
if (memcmp(Name.data()+2, "igned", 5) != 0)
break;
return AttributeCommonInfo::AT_Aligned; // "aligned"
}
break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+1, "ounded", 6) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "bounded"
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "leanup", 6) != 0)
break;
return AttributeCommonInfo::AT_Cleanup; // "cleanup"
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "latten", 6) != 0)
break;
return AttributeCommonInfo::AT_Flatten; // "flatten"
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "insize", 6) != 0)
break;
return AttributeCommonInfo::AT_MinSize; // "minsize"
case 'n': // 6 strings to match.
switch (Name[1]) {
default: break;
case 'o': // 5 strings to match.
switch (Name[2]) {
default: break;
case 'd': // 2 strings to match.
if (Name[3] != 'e')
break;
switch (Name[4]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+5, "ug", 2) != 0)
break;
return AttributeCommonInfo::AT_NoDebug; // "nodebug"
case 'r': // 1 string to match.
if (memcmp(Name.data()+5, "ef", 2) != 0)
break;
return AttributeCommonInfo::AT_NoDeref; // "noderef"
}
break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+3, "erge", 4) != 0)
break;
return AttributeCommonInfo::AT_NoMerge; // "nomerge"
case 'n': // 1 string to match.
if (memcmp(Name.data()+3, "null", 4) != 0)
break;
return AttributeCommonInfo::AT_NonNull; // "nonnull"
case 't': // 1 string to match.
if (memcmp(Name.data()+3, "hrow", 4) != 0)
break;
return AttributeCommonInfo::AT_NoThrow; // "nothrow"
}
break;
case 'v': // 1 string to match.
if (memcmp(Name.data()+2, "_weak", 5) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "nv_weak"
}
break;
case 'o': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+2, "jc_gc", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCGC; // "objc_gc"
case 'p': // 1 string to match.
if (memcmp(Name.data()+2, "tnone", 5) != 0)
break;
return AttributeCommonInfo::AT_OptimizeNone; // "optnone"
}
break;
case 'r': // 2 strings to match.
if (memcmp(Name.data()+1, "eg", 2) != 0)
break;
switch (Name[3]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+4, "all", 3) != 0)
break;
return AttributeCommonInfo::AT_RegCall; // "regcall"
case 'p': // 1 string to match.
if (memcmp(Name.data()+4, "arm", 3) != 0)
break;
return AttributeCommonInfo::AT_Regparm; // "regparm"
}
break;
case 's': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "ction", 5) != 0)
break;
return AttributeCommonInfo::AT_Section; // "section"
case 't': // 1 string to match.
if (memcmp(Name.data()+2, "dcall", 5) != 0)
break;
return AttributeCommonInfo::AT_StdCall; // "stdcall"
}
break;
case 'w': // 1 string to match.
if (memcmp(Name.data()+1, "eakref", 6) != 0)
break;
return AttributeCommonInfo::AT_WeakRef; // "weakref"
}
break;
case 8: // 16 strings to match.
switch (Name[0]) {
default: break;
case 'N': // 1 string to match.
if (memcmp(Name.data()+1, "SObject", 7) != 0)
break;
return AttributeCommonInfo::AT_ObjCNSObject; // "NSObject"
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "nnotate", 7) != 0)
break;
return AttributeCommonInfo::AT_Annotate; // "annotate"
case 'c': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "llback", 6) != 0)
break;
return AttributeCommonInfo::AT_Callback; // "callback"
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "nstant", 6) != 0)
break;
return AttributeCommonInfo::AT_CUDAConstant; // "constant"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "astcall", 7) != 0)
break;
return AttributeCommonInfo::AT_FastCall; // "fastcall"
case 'i': // 2 strings to match.
if (Name[1] != 'b')
break;
switch (Name[2]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+3, "ction", 5) != 0)
break;
return AttributeCommonInfo::AT_IBAction; // "ibaction"
case 'o': // 1 string to match.
if (memcmp(Name.data()+3, "utlet", 5) != 0)
break;
return AttributeCommonInfo::AT_IBOutlet; // "iboutlet"
}
break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "ockable", 7) != 0)
break;
return AttributeCommonInfo::AT_Lockable; // "lockable"
case 'n': // 5 strings to match.
if (Name[1] != 'o')
break;
switch (Name[2]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+3, "ommon", 5) != 0)
break;
return AttributeCommonInfo::AT_NoCommon; // "nocommon"
case 'e': // 1 string to match.
if (memcmp(Name.data()+3, "scape", 5) != 0)
break;
return AttributeCommonInfo::AT_NoEscape; // "noescape"
case 'i': // 1 string to match.
if (memcmp(Name.data()+3, "nline", 5) != 0)
break;
return AttributeCommonInfo::AT_NoInline; // "noinline"
case 'm': // 1 string to match.
if (memcmp(Name.data()+3, "ips16", 5) != 0)
break;
return AttributeCommonInfo::AT_NoMips16; // "nomips16"
case 'r': // 1 string to match.
if (memcmp(Name.data()+3, "eturn", 5) != 0)
break;
return AttributeCommonInfo::AT_NoReturn; // "noreturn"
}
break;
case 's': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "ntinel", 6) != 0)
break;
return AttributeCommonInfo::AT_Sentinel; // "sentinel"
case 'y': // 1 string to match.
if (memcmp(Name.data()+2, "sv_abi", 6) != 0)
break;
return AttributeCommonInfo::AT_SysVABI; // "sysv_abi"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "hiscall", 7) != 0)
break;
return AttributeCommonInfo::AT_ThisCall; // "thiscall"
}
break;
case 9: // 13 strings to match.
switch (Name[0]) {
default: break;
case 'd': // 2 strings to match.
if (memcmp(Name.data()+1, "ll", 2) != 0)
break;
switch (Name[3]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+4, "xport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLExport; // "dllexport"
case 'i': // 1 string to match.
if (memcmp(Name.data()+4, "mport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLImport; // "dllimport"
}
break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "nable_if", 8) != 0)
break;
return AttributeCommonInfo::AT_EnableIf; // "enable_if"
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "lag_enum", 8) != 0)
break;
return AttributeCommonInfo::AT_FlagEnum; // "flag_enum"
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "nterrupt", 8) != 0)
break;
return AttributeCommonInfo::AT_Interrupt; // "interrupt"
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "ong_call", 8) != 0)
break;
return AttributeCommonInfo::AT_MipsLongCall; // "long_call"
case 'm': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "y_alias", 7) != 0)
break;
return AttributeCommonInfo::AT_MayAlias; // "may_alias"
case 'i': // 1 string to match.
if (memcmp(Name.data()+2, "cromips", 7) != 0)
break;
return AttributeCommonInfo::AT_MicroMips; // "micromips"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_struct", 7) != 0)
break;
return AttributeCommonInfo::AT_MSStruct; // "ms_struct"
}
break;
case 's': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "lectany", 7) != 0)
break;
return AttributeCommonInfo::AT_SelectAny; // "selectany"
case 'w': // 1 string to match.
if (memcmp(Name.data()+2, "iftcall", 7) != 0)
break;
return AttributeCommonInfo::AT_SwiftCall; // "swiftcall"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "ls_model", 8) != 0)
break;
return AttributeCommonInfo::AT_TLSModel; // "tls_model"
case 'v': // 1 string to match.
if (memcmp(Name.data()+1, "ecreturn", 8) != 0)
break;
return AttributeCommonInfo::AT_VecReturn; // "vecreturn"
}
break;
case 10: // 19 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+2, "loc_size", 8) != 0)
break;
return AttributeCommonInfo::AT_AllocSize; // "alloc_size"
case 'r': // 1 string to match.
if (memcmp(Name.data()+2, "tificial", 8) != 0)
break;
return AttributeCommonInfo::AT_Artificial; // "artificial"
}
break;
case 'c': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "pability", 8) != 0)
break;
return AttributeCommonInfo::AT_Capability; // "capability"
case 'o': // 2 strings to match.
if (Name[2] != 'n')
break;
switch (Name[3]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+4, "umable", 6) != 0)
break;
return AttributeCommonInfo::AT_Consumable; // "consumable"
case 'v': // 1 string to match.
if (memcmp(Name.data()+4, "ergent", 6) != 0)
break;
return AttributeCommonInfo::AT_Convergent; // "convergent"
}
break;
}
break;
case 'd': // 2 strings to match.
if (Name[1] != 'e')
break;
switch (Name[2]) {
default: break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+3, "recated", 7) != 0)
break;
return AttributeCommonInfo::AT_Deprecated; // "deprecated"
case 's': // 1 string to match.
if (memcmp(Name.data()+3, "tructor", 7) != 0)
break;
return AttributeCommonInfo::AT_Destructor; // "destructor"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "ormat_arg", 9) != 0)
break;
return AttributeCommonInfo::AT_FormatArg; // "format_arg"
case 'g': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+2, "u_inline", 8) != 0)
break;
return AttributeCommonInfo::AT_GNUInline; // "gnu_inline"
case 'u': // 1 string to match.
if (memcmp(Name.data()+2, "arded_by", 8) != 0)
break;
return AttributeCommonInfo::AT_GuardedBy; // "guarded_by"
}
break;
case 'n': // 3 strings to match.
if (Name[1] != 'o')
break;
switch (Name[2]) {
default: break;
case '_': // 2 strings to match.
switch (Name[3]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+4, "uiltin", 6) != 0)
break;
return AttributeCommonInfo::AT_NoBuiltin; // "no_builtin"
case 'd': // 1 string to match.
if (memcmp(Name.data()+4, "estroy", 6) != 0)
break;
return AttributeCommonInfo::AT_NoDestroy; // "no_destroy"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+3, "f_check", 7) != 0)
break;
return AttributeCommonInfo::AT_AnyX86NoCfCheck; // "nocf_check"
}
break;
case 's': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+2, "ort_call", 8) != 0)
break;
return AttributeCommonInfo::AT_MipsShortCall; // "short_call"
case 'w': // 2 strings to match.
if (memcmp(Name.data()+2, "ift_", 4) != 0)
break;
switch (Name[6]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+7, "ttr", 3) != 0)
break;
return AttributeCommonInfo::AT_SwiftAttr; // "swift_attr"
case 'n': // 1 string to match.
if (memcmp(Name.data()+7, "ame", 3) != 0)
break;
return AttributeCommonInfo::AT_SwiftName; // "swift_name"
}
break;
}
break;
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "se_handle", 9) != 0)
break;
return AttributeCommonInfo::AT_UseHandle; // "use_handle"
case 'v': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "ctorcall", 8) != 0)
break;
return AttributeCommonInfo::AT_VectorCall; // "vectorcall"
case 'i': // 1 string to match.
if (memcmp(Name.data()+2, "sibility", 8) != 0)
break;
return AttributeCommonInfo::AT_Visibility; // "visibility"
}
break;
}
break;
case 11: // 27 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 2 strings to match.
if (Name[1] != 'l')
break;
switch (Name[2]) {
default: break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+3, "gn_value", 8) != 0)
break;
return AttributeCommonInfo::AT_AlignValue; // "align_value"
case 'l': // 1 string to match.
if (memcmp(Name.data()+3, "oc_align", 8) != 0)
break;
return AttributeCommonInfo::AT_AllocAlign; // "alloc_align"
}
break;
case 'c': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "lled_once", 9) != 0)
break;
return AttributeCommonInfo::AT_CalledOnce; // "called_once"
case 'f': // 1 string to match.
if (memcmp(Name.data()+2, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_CFConsumed; // "cf_consumed"
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "nstructor", 9) != 0)
break;
return AttributeCommonInfo::AT_Constructor; // "constructor"
}
break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "iagnose_if", 10) != 0)
break;
return AttributeCommonInfo::AT_DiagnoseIf; // "diagnose_if"
case 'e': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+2, "force_tcb", 9) != 0)
break;
return AttributeCommonInfo::AT_EnforceTCB; // "enforce_tcb"
case 'x': // 1 string to match.
if (memcmp(Name.data()+2, "port_name", 9) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyExportName; // "export_name"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "allthrough", 10) != 0)
break;
return AttributeCommonInfo::AT_FallThrough; // "fallthrough"
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "uarded_var", 10) != 0)
break;
return AttributeCommonInfo::AT_GuardedVar; // "guarded_var"
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "mport_name", 10) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyImportName; // "import_name"
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "atrix_type", 10) != 0)
break;
return AttributeCommonInfo::AT_MatrixType; // "matrix_type"
case 'n': // 4 strings to match.
switch (Name[1]) {
default: break;
case 'o': // 3 strings to match.
switch (Name[2]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+3, "sanitize", 8) != 0)
break;
return AttributeCommonInfo::AT_NoSanitize; // "no_sanitize"
case 'd': // 1 string to match.
if (memcmp(Name.data()+3, "uplicate", 8) != 0)
break;
return AttributeCommonInfo::AT_NoDuplicate; // "noduplicate"
case 'm': // 1 string to match.
if (memcmp(Name.data()+3, "icromips", 8) != 0)
break;
return AttributeCommonInfo::AT_NoMicroMips; // "nomicromips"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_NSConsumed; // "ns_consumed"
}
break;
case 'o': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+2, "jc_", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+6, "ridge", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridge; // "objc_bridge"
case 'd': // 1 string to match.
if (memcmp(Name.data()+6, "irect", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCDirect; // "objc_direct"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_OSConsumed; // "os_consumed"
}
break;
case 's': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'w': // 2 strings to match.
if (memcmp(Name.data()+2, "ift_", 4) != 0)
break;
switch (Name[6]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+7, "sync", 4) != 0)
break;
return AttributeCommonInfo::AT_SwiftAsync; // "swift_async"
case 'e': // 1 string to match.
if (memcmp(Name.data()+7, "rror", 4) != 0)
break;
return AttributeCommonInfo::AT_SwiftError; // "swift_error"
}
break;
case 'y': // 1 string to match.
if (memcmp(Name.data()+2, "cl_kernel", 9) != 0)
break;
return AttributeCommonInfo::AT_SYCLKernel; // "sycl_kernel"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "rivial_abi", 10) != 0)
break;
return AttributeCommonInfo::AT_TrivialABI; // "trivial_abi"
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "navailable", 10) != 0)
break;
return AttributeCommonInfo::AT_Unavailable; // "unavailable"
case 'v': // 1 string to match.
if (memcmp(Name.data()+1, "ector_size", 10) != 0)
break;
return AttributeCommonInfo::AT_VectorSize; // "vector_size"
case 'w': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "rn_unused", 9) != 0)
break;
return AttributeCommonInfo::AT_WarnUnused; // "warn_unused"
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "ak_import", 9) != 0)
break;
return AttributeCommonInfo::AT_WeakImport; // "weak_import"
}
break;
}
break;
case 12: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "vailability", 11) != 0)
break;
return AttributeCommonInfo::AT_Availability; // "availability"
case 'c': // 2 strings to match.
if (memcmp(Name.data()+1, "pu_", 3) != 0)
break;
switch (Name[4]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+5, "ispatch", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUDispatch; // "cpu_dispatch"
case 's': // 1 string to match.
if (memcmp(Name.data()+5, "pecific", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUSpecific; // "cpu_specific"
}
break;
case 'o': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+2, "jc_boxable", 10) != 0)
break;
return AttributeCommonInfo::AT_ObjCBoxable; // "objc_boxable"
case 'p': // 1 string to match.
if (memcmp(Name.data()+2, "encl_local", 10) != 0)
break;
return AttributeCommonInfo::AT_OpenCLLocalAddressSpace; // "opencl_local"
case 'v': // 1 string to match.
if (memcmp(Name.data()+2, "erloadable", 10) != 0)
break;
return AttributeCommonInfo::AT_Overloadable; // "overloadable"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "reserve_all", 11) != 0)
break;
return AttributeCommonInfo::AT_PreserveAll; // "preserve_all"
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "wift_bridge", 11) != 0)
break;
return AttributeCommonInfo::AT_SwiftBridge; // "swift_bridge"
}
break;
case 13: // 21 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+2, "dress_space", 11) != 0)
break;
return AttributeCommonInfo::AT_AddressSpace; // "address_space"
case 'l': // 1 string to match.
if (memcmp(Name.data()+2, "ways_inline", 11) != 0)
break;
return AttributeCommonInfo::AT_AlwaysInline; // "always_inline"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "allable_when", 12) != 0)
break;
return AttributeCommonInfo::AT_CallableWhen; // "callable_when"
case 'i': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+2, "port_module", 11) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyImportModule; // "import_module"
case 'n': // 1 string to match.
if (memcmp(Name.data()+2, "it_priority", 11) != 0)
break;
return AttributeCommonInfo::AT_InitPriority; // "init_priority"
}
break;
case 'l': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "unch_bounds", 11) != 0)
break;
return AttributeCommonInfo::AT_CUDALaunchBounds; // "launch_bounds"
case 'i': // 1 string to match.
if (memcmp(Name.data()+2, "fetimebound", 11) != 0)
break;
return AttributeCommonInfo::AT_LifetimeBound; // "lifetimebound"
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "ck_returned", 11) != 0)
break;
return AttributeCommonInfo::AT_LockReturned; // "lock_returned"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "pencl_global", 12) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalAddressSpace; // "opencl_global"
case 'p': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+2, "eserve_most", 11) != 0)
break;
return AttributeCommonInfo::AT_PreserveMost; // "preserve_most"
case 't': // 1 string to match.
if (memcmp(Name.data()+2, "_guarded_by", 11) != 0)
break;
return AttributeCommonInfo::AT_PtGuardedBy; // "pt_guarded_by"
}
break;
case 'r': // 2 strings to match.
if (Name[1] != 'e')
break;
switch (Name[2]) {
default: break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+3, "nitializes", 10) != 0)
break;
return AttributeCommonInfo::AT_Reinitializes; // "reinitializes"
case 't': // 1 string to match.
if (memcmp(Name.data()+3, "urns_twice", 10) != 0)
break;
return AttributeCommonInfo::AT_ReturnsTwice; // "returns_twice"
}
break;
case 's': // 5 strings to match.
switch (Name[1]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "t_typestate", 11) != 0)
break;
return AttributeCommonInfo::AT_SetTypestate; // "set_typestate"
case 'w': // 4 strings to match.
if (memcmp(Name.data()+2, "ift_", 4) != 0)
break;
switch (Name[6]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+7, "ontext", 6) != 0)
break;
return AttributeCommonInfo::AT_SwiftContext; // "swift_context"
case 'n': // 1 string to match.
if (memcmp(Name.data()+7, "ewtype", 6) != 0)
break;
return AttributeCommonInfo::AT_SwiftNewType; // "swift_newtype"
case 'p': // 1 string to match.
if (memcmp(Name.data()+7, "rivate", 6) != 0)
break;
return AttributeCommonInfo::AT_SwiftPrivate; // "swift_private"
case 'w': // 1 string to match.
if (memcmp(Name.data()+7, "rapper", 6) != 0)
break;
return AttributeCommonInfo::AT_SwiftNewType; // "swift_wrapper"
}
break;
}
break;
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "ninitialized", 12) != 0)
break;
return AttributeCommonInfo::AT_Uninitialized; // "uninitialized"
case 'v': // 1 string to match.
if (memcmp(Name.data()+1, "ec_type_hint", 12) != 0)
break;
return AttributeCommonInfo::AT_VecTypeHint; // "vec_type_hint"
case 'x': // 1 string to match.
if (memcmp(Name.data()+1, "ray_log_args", 12) != 0)
break;
return AttributeCommonInfo::AT_XRayLogArgs; // "xray_log_args"
}
break;
case 14: // 17 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 4 strings to match.
switch (Name[1]) {
default: break;
case 'c': // 2 strings to match.
if (memcmp(Name.data()+2, "quire", 5) != 0)
break;
switch (Name[7]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+8, "handle", 6) != 0)
break;
return AttributeCommonInfo::AT_AcquireHandle; // "acquire_handle"
case 'd': // 1 string to match.
if (memcmp(Name.data()+8, "_after", 6) != 0)
break;
return AttributeCommonInfo::AT_AcquiredAfter; // "acquired_after"
}
break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+2, "ways_destroy", 12) != 0)
break;
return AttributeCommonInfo::AT_AlwaysDestroy; // "always_destroy"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "sume_aligned", 12) != 0)
break;
return AttributeCommonInfo::AT_AssumeAligned; // "assume_aligned"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "udart_builtin", 13) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "cudart_builtin"
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "evice_builtin", 13) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "device_builtin"
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "ntel_ocl_bicc", 13) != 0)
break;
return AttributeCommonInfo::AT_IntelOclBicc; // "intel_ocl_bicc"
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "ocks_excluded", 13) != 0)
break;
return AttributeCommonInfo::AT_LocksExcluded; // "locks_excluded"
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "o_split_stack", 13) != 0)
break;
return AttributeCommonInfo::AT_NoSplitStack; // "no_split_stack"
case 'o': // 4 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+2, "jc_", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+6, "xception", 8) != 0)
break;
return AttributeCommonInfo::AT_ObjCException; // "objc_exception"
case 'o': // 1 string to match.
if (memcmp(Name.data()+6, "wnership", 8) != 0)
break;
return AttributeCommonInfo::AT_ObjCOwnership; // "objc_ownership"
}
break;
case 'p': // 2 strings to match.
if (memcmp(Name.data()+2, "encl_", 5) != 0)
break;
switch (Name[7]) {
default: break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+8, "eneric", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGenericAddressSpace; // "opencl_generic"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "rivate", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLPrivateAddressSpace; // "opencl_private"
}
break;
}
break;
case 'p': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+2, "eferred_name", 12) != 0)
break;
return AttributeCommonInfo::AT_PreferredName; // "preferred_name"
case 't': // 1 string to match.
if (memcmp(Name.data()+2, "_guarded_var", 12) != 0)
break;
return AttributeCommonInfo::AT_PtGuardedVar; // "pt_guarded_var"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "elease_handle", 13) != 0)
break;
return AttributeCommonInfo::AT_ReleaseHandle; // "release_handle"
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "est_typestate", 13) != 0)
break;
return AttributeCommonInfo::AT_TestTypestate; // "test_typestate"
}
break;
case 15: // 16 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+2, "quired_before", 13) != 0)
break;
return AttributeCommonInfo::AT_AcquiredBefore; // "acquired_before"
case 'm': // 2 strings to match.
if (memcmp(Name.data()+2, "dgpu_num_", 9) != 0)
break;
switch (Name[11]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+12, "gpr", 3) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUNumSGPR; // "amdgpu_num_sgpr"
case 'v': // 1 string to match.
if (memcmp(Name.data()+12, "gpr", 3) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUNumVGPR; // "amdgpu_num_vgpr"
}
break;
}
break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "xt_vector_type", 14) != 0)
break;
return AttributeCommonInfo::AT_ExtVectorType; // "ext_vector_type"
case 'n': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "t_tail_called", 13) != 0)
break;
return AttributeCommonInfo::AT_NotTailCalled; // "not_tail_called"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_error_domain", 13) != 0)
break;
return AttributeCommonInfo::AT_NSErrorDomain; // "ns_error_domain"
}
break;
case 'o': // 5 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+2, "jc_", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "lass_stub", 9) != 0)
break;
return AttributeCommonInfo::AT_ObjCClassStub; // "objc_class_stub"
case 'r': // 1 string to match.
if (memcmp(Name.data()+6, "oot_class", 9) != 0)
break;
return AttributeCommonInfo::AT_ObjCRootClass; // "objc_root_class"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+2, "encl_constant", 13) != 0)
break;
return AttributeCommonInfo::AT_OpenCLConstantAddressSpace; // "opencl_constant"
case 'w': // 2 strings to match.
if (memcmp(Name.data()+2, "nership_", 8) != 0)
break;
switch (Name[10]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+11, "olds", 4) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "ownership_holds"
case 't': // 1 string to match.
if (memcmp(Name.data()+11, "akes", 4) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "ownership_takes"
}
break;
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "aram_typestate", 14) != 0)
break;
return AttributeCommonInfo::AT_ParamTypestate; // "param_typestate"
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "eturns_nonnull", 14) != 0)
break;
return AttributeCommonInfo::AT_ReturnsNonNull; // "returns_nonnull"
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "coped_lockable", 14) != 0)
break;
return AttributeCommonInfo::AT_ScopedLockable; // "scoped_lockable"
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "ype_visibility", 14) != 0)
break;
return AttributeCommonInfo::AT_TypeVisibility; // "type_visibility"
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "nlock_function", 14) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "unlock_function"
}
break;
case 16: // 9 strings to match.
switch (Name[0]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "nforce_tcb_leaf", 15) != 0)
break;
return AttributeCommonInfo::AT_EnforceTCBLeaf; // "enforce_tcb_leaf"
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "nternal_linkage", 15) != 0)
break;
return AttributeCommonInfo::AT_InternalLinkage; // "internal_linkage"
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "in_vector_width", 15) != 0)
break;
return AttributeCommonInfo::AT_MinVectorWidth; // "min_vector_width"
case 'n': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+2, "on_vector_type", 14) != 0)
break;
return AttributeCommonInfo::AT_NeonVectorType; // "neon_vector_type"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_consumes_self", 14) != 0)
break;
return AttributeCommonInfo::AT_NSConsumesSelf; // "ns_consumes_self"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "s_consumes_this", 15) != 0)
break;
return AttributeCommonInfo::AT_OSConsumesThis; // "os_consumes_this"
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "ass_object_size", 15) != 0)
break;
return AttributeCommonInfo::AT_PassObjectSize; // "pass_object_size"
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "eturn_typestate", 15) != 0)
break;
return AttributeCommonInfo::AT_ReturnTypestate; // "return_typestate"
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "wift_async_name", 15) != 0)
break;
return AttributeCommonInfo::AT_SwiftAsyncName; // "swift_async_name"
}
break;
case 17: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+2, "alyzer_noreturn", 15) != 0)
break;
return AttributeCommonInfo::AT_AnalyzerNoReturn; // "analyzer_noreturn"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "sert_capability", 15) != 0)
break;
return AttributeCommonInfo::AT_AssertCapability; // "assert_capability"
}
break;
case 'o': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+2, "jc_runtime_name", 15) != 0)
break;
return AttributeCommonInfo::AT_ObjCRuntimeName; // "objc_runtime_name"
case 'w': // 1 string to match.
if (memcmp(Name.data()+2, "nership_returns", 15) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "ownership_returns"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "hared_capability", 16) != 0)
break;
return AttributeCommonInfo::AT_Capability; // "shared_capability"
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "ransparent_union", 16) != 0)
break;
return AttributeCommonInfo::AT_TransparentUnion; // "transparent_union"
}
break;
case 18: // 19 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "rch64_vector_pcs", 16) != 0)
break;
return AttributeCommonInfo::AT_AArch64VectorPcs; // "aarch64_vector_pcs"
case 'c': // 1 string to match.
if (memcmp(Name.data()+2, "quire_capability", 16) != 0)
break;
return AttributeCommonInfo::AT_AcquireCapability; // "acquire_capability"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "sert_shared_lock", 16) != 0)
break;
return AttributeCommonInfo::AT_AssertSharedLock; // "assert_shared_lock"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "arries_dependency", 17) != 0)
break;
return AttributeCommonInfo::AT_CarriesDependency; // "carries_dependency"
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "isable_tail_calls", 17) != 0)
break;
return AttributeCommonInfo::AT_DisableTailCalls; // "disable_tail_calls"
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "num_extensibility", 17) != 0)
break;
return AttributeCommonInfo::AT_EnumExtensibility; // "enum_extensibility"
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "boutletcollection", 17) != 0)
break;
return AttributeCommonInfo::AT_IBOutletCollection; // "iboutletcollection"
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "ig_server_routine", 17) != 0)
break;
return AttributeCommonInfo::AT_MIGServerRoutine; // "mig_server_routine"
case 'n': // 3 strings to match.
if (memcmp(Name.data()+1, "o_s", 3) != 0)
break;
switch (Name[4]) {
default: break;
case 'a': // 2 strings to match.
if (memcmp(Name.data()+5, "nitize_", 7) != 0)
break;
switch (Name[12]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+13, "emory", 5) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "no_sanitize_memory"
case 't': // 1 string to match.
if (memcmp(Name.data()+13, "hread", 5) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "no_sanitize_thread"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+5, "ack_protector", 13) != 0)
break;
return AttributeCommonInfo::AT_NoStackProtector; // "no_stack_protector"
}
break;
case 'o': // 4 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+2, "jc_", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+6, "ethod_family", 12) != 0)
break;
return AttributeCommonInfo::AT_ObjCMethodFamily; // "objc_method_family"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "onlazy_class", 12) != 0)
break;
return AttributeCommonInfo::AT_ObjCNonLazyClass; // "objc_nonlazy_class"
}
break;
case 'p': // 2 strings to match.
if (memcmp(Name.data()+2, "encl_", 5) != 0)
break;
switch (Name[7]) {
default: break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+8, "lobal_host", 10) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalHostAddressSpace; // "opencl_global_host"
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "nroll_hint", 10) != 0)
break;
return AttributeCommonInfo::AT_OpenCLUnrollHint; // "opencl_unroll_hint"
}
break;
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "elease_capability", 17) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "release_capability"
case 's': // 2 strings to match.
if (memcmp(Name.data()+1, "wift_", 5) != 0)
break;
switch (Name[6]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+7, "rror_result", 11) != 0)
break;
return AttributeCommonInfo::AT_SwiftErrorResult; // "swift_error_result"
case 'o': // 1 string to match.
if (memcmp(Name.data()+7, "bjc_members", 11) != 0)
break;
return AttributeCommonInfo::AT_SwiftObjCMembers; // "swift_objc_members"
}
break;
case 'w': // 1 string to match.
if (memcmp(Name.data()+1, "arn_unused_result", 17) != 0)
break;
return AttributeCommonInfo::AT_WarnUnusedResult; // "warn_unused_result"
}
break;
case 19: // 14 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+2, "dgpu_waves_per_eu", 17) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUWavesPerEU; // "amdgpu_waves_per_eu"
case 'r': // 1 string to match.
if (memcmp(Name.data()+2, "m_sve_vector_bits", 17) != 0)
break;
return AttributeCommonInfo::AT_ArmSveVectorBits; // "arm_sve_vector_bits"
}
break;
case 'c': // 4 strings to match.
switch (Name[1]) {
default: break;
case 'f': // 3 strings to match.
if (Name[2] != '_')
break;
switch (Name[3]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+4, "udited_transfer", 15) != 0)
break;
return AttributeCommonInfo::AT_CFAuditedTransfer; // "cf_audited_transfer"
case 'r': // 1 string to match.
if (memcmp(Name.data()+4, "eturns_retained", 15) != 0)
break;
return AttributeCommonInfo::AT_CFReturnsRetained; // "cf_returns_retained"
case 'u': // 1 string to match.
if (memcmp(Name.data()+4, "nknown_transfer", 15) != 0)
break;
return AttributeCommonInfo::AT_CFUnknownTransfer; // "cf_unknown_transfer"
}
break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+2, "se_nonsecure_call", 17) != 0)
break;
return AttributeCommonInfo::AT_CmseNSCall; // "cmse_nonsecure_call"
}
break;
case 'n': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "_sanitize_address", 17) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "no_sanitize_address"
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_returns_retained", 17) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsRetained; // "ns_returns_retained"
}
break;
case 'o': // 5 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 4 strings to match.
if (memcmp(Name.data()+2, "jc_", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+6, "ridge_", 6) != 0)
break;
switch (Name[12]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+13, "utable", 6) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridgeMutable; // "objc_bridge_mutable"
case 'r': // 1 string to match.
if (memcmp(Name.data()+13, "elated", 6) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridgeRelated; // "objc_bridge_related"
}
break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+6, "irect_members", 13) != 0)
break;
return AttributeCommonInfo::AT_ObjCDirectMembers; // "objc_direct_members"
case 'r': // 1 string to match.
if (memcmp(Name.data()+6, "equires_super", 13) != 0)
break;
return AttributeCommonInfo::AT_ObjCRequiresSuper; // "objc_requires_super"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_returns_retained", 17) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetained; // "os_returns_retained"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "equires_capability", 18) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "requires_capability"
}
break;
case 20: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "mse_nonsecure_entry", 19) != 0)
break;
return AttributeCommonInfo::AT_CmseNSEntry; // "cmse_nonsecure_entry"
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "oader_uninitialized", 19) != 0)
break;
return AttributeCommonInfo::AT_LoaderUninitialized; // "loader_uninitialized"
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "eon_polyvector_type", 19) != 0)
break;
return AttributeCommonInfo::AT_NeonPolyVectorType; // "neon_polyvector_type"
case 'o': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+2, "jc_runtime_visible", 18) != 0)
break;
return AttributeCommonInfo::AT_ObjCRuntimeVisible; // "objc_runtime_visible"
case 'p': // 1 string to match.
if (memcmp(Name.data()+2, "encl_global_device", 18) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalDeviceAddressSpace; // "opencl_global_device"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "eqd_work_group_size", 19) != 0)
break;
return AttributeCommonInfo::AT_ReqdWorkGroupSize; // "reqd_work_group_size"
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "hared_lock_function", 19) != 0)
break;
return AttributeCommonInfo::AT_AcquireCapability; // "shared_lock_function"
case 'w': // 1 string to match.
if (memcmp(Name.data()+1, "ork_group_size_hint", 19) != 0)
break;
return AttributeCommonInfo::AT_WorkGroupSizeHint; // "work_group_size_hint"
}
break;
case 21: // 10 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "ssert_exclusive_lock", 20) != 0)
break;
return AttributeCommonInfo::AT_AssertExclusiveLock; // "assert_exclusive_lock"
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "to_visibility_public", 20) != 0)
break;
return AttributeCommonInfo::AT_LTOVisibilityPublic; // "lto_visibility_public"
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "bjc_precise_lifetime", 20) != 0)
break;
return AttributeCommonInfo::AT_ObjCPreciseLifetime; // "objc_precise_lifetime"
case 'p': // 2 strings to match.
switch (Name[1]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+2, "inter_with_type_tag", 19) != 0)
break;
return AttributeCommonInfo::AT_ArgumentWithTypeTag; // "pointer_with_type_tag"
case 'r': // 1 string to match.
if (memcmp(Name.data()+2, "eserve_access_index", 19) != 0)
break;
return AttributeCommonInfo::AT_BPFPreserveAccessIndex; // "preserve_access_index"
}
break;
case 's': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+2, "ared_locks_required", 19) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "shared_locks_required"
case 'w': // 2 strings to match.
if (memcmp(Name.data()+2, "ift_", 4) != 0)
break;
switch (Name[6]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+7, "ridged_typedef", 14) != 0)
break;
return AttributeCommonInfo::AT_SwiftBridgedTypedef; // "swift_bridged_typedef"
case 'i': // 1 string to match.
if (memcmp(Name.data()+7, "ndirect_result", 14) != 0)
break;
return AttributeCommonInfo::AT_SwiftIndirectResult; // "swift_indirect_result"
}
break;
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "ype_tag_for_datatype", 20) != 0)
break;
return AttributeCommonInfo::AT_TypeTagForDatatype; // "type_tag_for_datatype"
case 'x': // 1 string to match.
if (memcmp(Name.data()+1, "ray_never_instrument", 20) != 0)
break;
return AttributeCommonInfo::AT_XRayInstrument; // "xray_never_instrument"
}
break;
case 22: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "rgument_with_type_tag", 21) != 0)
break;
return AttributeCommonInfo::AT_ArgumentWithTypeTag; // "argument_with_type_tag"
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "xternal_source_symbol", 21) != 0)
break;
return AttributeCommonInfo::AT_ExternalSourceSymbol; // "external_source_symbol"
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "o_instrument_function", 21) != 0)
break;
return AttributeCommonInfo::AT_NoInstrumentFunction; // "no_instrument_function"
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "bjc_independent_class", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCIndependentClass; // "objc_independent_class"
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "ry_acquire_capability", 21) != 0)
break;
return AttributeCommonInfo::AT_TryAcquireCapability; // "try_acquire_capability"
case 'x': // 1 string to match.
if (memcmp(Name.data()+1, "ray_always_instrument", 21) != 0)
break;
return AttributeCommonInfo::AT_XRayInstrument; // "xray_always_instrument"
}
break;
case 23: // 7 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "f_returns_not_retained", 22) != 0)
break;
return AttributeCommonInfo::AT_CFReturnsNotRetained; // "cf_returns_not_retained"
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "xclusive_lock_function", 22) != 0)
break;
return AttributeCommonInfo::AT_AcquireCapability; // "exclusive_lock_function"
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "orce_align_arg_pointer", 22) != 0)
break;
return AttributeCommonInfo::AT_X86ForceAlignArgPointer; // "force_align_arg_pointer"
case 'n': // 2 strings to match.
if (memcmp(Name.data()+1, "s_returns_", 10) != 0)
break;
switch (Name[11]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+12, "utoreleased", 11) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsAutoreleased; // "ns_returns_autoreleased"
case 'n': // 1 string to match.
if (memcmp(Name.data()+12, "ot_retained", 11) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsNotRetained; // "ns_returns_not_retained"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "s_returns_not_retained", 22) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsNotRetained; // "os_returns_not_retained"
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "hared_trylock_function", 22) != 0)
break;
return AttributeCommonInfo::AT_SharedTrylockFunction; // "shared_trylock_function"
}
break;
case 24: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "ssert_shared_capability", 23) != 0)
break;
return AttributeCommonInfo::AT_AssertCapability; // "assert_shared_capability"
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "fi_canonical_jump_table", 23) != 0)
break;
return AttributeCommonInfo::AT_CFICanonicalJumpTable; // "cfi_canonical_jump_table"
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "xclusive_locks_required", 23) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "exclusive_locks_required"
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "bjc_externally_retained", 23) != 0)
break;
return AttributeCommonInfo::AT_ObjCExternallyRetained; // "objc_externally_retained"
case 'p': // 2 strings to match.
if (Name[1] != 'a')
break;
switch (Name[2]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+3, "s_dynamic_object_size", 21) != 0)
break;
return AttributeCommonInfo::AT_PassObjectSize; // "pass_dynamic_object_size"
case 't': // 1 string to match.
if (memcmp(Name.data()+3, "chable_function_entry", 21) != 0)
break;
return AttributeCommonInfo::AT_PatchableFunctionEntry; // "patchable_function_entry"
}
break;
}
break;
case 25: // 7 strings to match.
switch (Name[0]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+1, "_clang_arm_builtin_alias", 24) != 0)
break;
return AttributeCommonInfo::AT_ArmBuiltinAlias; // "__clang_arm_builtin_alias"
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "cquire_shared_capability", 24) != 0)
break;
return AttributeCommonInfo::AT_AcquireCapability; // "acquire_shared_capability"
case 'i': // 1 string to match.
if (memcmp(Name.data()+1, "ntel_reqd_sub_group_size", 24) != 0)
break;
return AttributeCommonInfo::AT_OpenCLIntelReqdSubGroupSize; // "intel_reqd_sub_group_size"
case 'n': // 2 strings to match.
if (memcmp(Name.data()+1, "o_", 2) != 0)
break;
switch (Name[3]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+4, "aller_saved_registers", 21) != 0)
break;
return AttributeCommonInfo::AT_AnyX86NoCallerSavedRegisters; // "no_caller_saved_registers"
case 't': // 1 string to match.
if (memcmp(Name.data()+4, "hread_safety_analysis", 21) != 0)
break;
return AttributeCommonInfo::AT_NoThreadSafetyAnalysis; // "no_thread_safety_analysis"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "bjc_non_runtime_protocol", 24) != 0)
break;
return AttributeCommonInfo::AT_ObjCNonRuntimeProtocol; // "objc_non_runtime_protocol"
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "elease_shared_capability", 24) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "release_shared_capability"
}
break;
case 26: // 7 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "onsumable_auto_cast_state", 25) != 0)
break;
return AttributeCommonInfo::AT_ConsumableAutoCast; // "consumable_auto_cast_state"
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "xclusive_trylock_function", 25) != 0)
break;
return AttributeCommonInfo::AT_ExclusiveTrylockFunction; // "exclusive_trylock_function"
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "o_address_safety_analysis", 25) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "no_address_safety_analysis"
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "bjc_returns_inner_pointer", 25) != 0)
break;
return AttributeCommonInfo::AT_ObjCReturnsInnerPointer; // "objc_returns_inner_pointer"
case 'r': // 2 strings to match.
if (Name[1] != 'e')
break;
switch (Name[2]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+3, "ease_generic_capability", 23) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "release_generic_capability"
case 'q': // 1 string to match.
if (memcmp(Name.data()+3, "uires_shared_capability", 23) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "requires_shared_capability"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "peculative_load_hardening", 25) != 0)
break;
return AttributeCommonInfo::AT_SpeculativeLoadHardening; // "speculative_load_hardening"
}
break;
case 27: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "mdgpu_flat_work_group_size", 26) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUFlatWorkGroupSize; // "amdgpu_flat_work_group_size"
case 'd': // 2 strings to match.
if (memcmp(Name.data()+1, "evice_builtin_", 14) != 0)
break;
switch (Name[15]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+16, "urface_type", 11) != 0)
break;
return AttributeCommonInfo::AT_CUDADeviceBuiltinSurfaceType; // "device_builtin_surface_type"
case 't': // 1 string to match.
if (memcmp(Name.data()+16, "exture_type", 11) != 0)
break;
return AttributeCommonInfo::AT_CUDADeviceBuiltinTextureType; // "device_builtin_texture_type"
}
break;
case 'o': // 3 strings to match.
switch (Name[1]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+2, "jc_", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+6, "esignated_initializer", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCDesignatedInitializer; // "objc_designated_initializer"
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "ubclassing_restricted", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCSubclassingRestricted; // "objc_subclassing_restricted"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "_returns_retained_on_zero", 25) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetainedOnZero; // "os_returns_retained_on_zero"
}
break;
}
break;
case 28: // 1 string to match.
if (memcmp(Name.data()+0, "consumable_set_state_on_read", 28) != 0)
break;
return AttributeCommonInfo::AT_ConsumableSetOnRead; // "consumable_set_state_on_read"
case 29: // 2 strings to match.
switch (Name[0]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "o_speculative_load_hardening", 28) != 0)
break;
return AttributeCommonInfo::AT_NoSpeculativeLoadHardening; // "no_speculative_load_hardening"
case 't': // 1 string to match.
if (memcmp(Name.data()+1, "ry_acquire_shared_capability", 28) != 0)
break;
return AttributeCommonInfo::AT_TryAcquireCapability; // "try_acquire_shared_capability"
}
break;
case 31: // 2 strings to match.
switch (Name[0]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "s_returns_retained_on_non_zero", 30) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetainedOnNonZero; // "os_returns_retained_on_non_zero"
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "equire_constant_initialization", 30) != 0)
break;
return AttributeCommonInfo::AT_ConstInit; // "require_constant_initialization"
}
break;
case 34: // 1 string to match.
if (memcmp(Name.data()+0, "objc_requires_property_definitions", 34) != 0)
break;
return AttributeCommonInfo::AT_ObjCRequiresPropertyDefs; // "objc_requires_property_definitions"
case 35: // 3 strings to match.
switch (Name[0]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+1, "_clang_arm_mve_strict_polymorphism", 34) != 0)
break;
return AttributeCommonInfo::AT_ArmMveStrictPolymorphism; // "__clang_arm_mve_strict_polymorphism"
case 'e': // 1 string to match.
if (memcmp(Name.data()+1, "xclude_from_explicit_instantiation", 34) != 0)
break;
return AttributeCommonInfo::AT_ExcludeFromExplicitInstantiation; // "exclude_from_explicit_instantiation"
case 'o': // 1 string to match.
if (memcmp(Name.data()+1, "bjc_arc_weak_reference_unavailable", 34) != 0)
break;
return AttributeCommonInfo::AT_ArcWeakrefUnavailable; // "objc_arc_weak_reference_unavailable"
}
break;
case 46: // 1 string to match.
if (memcmp(Name.data()+0, "objc_protocol_requires_explicit_implementation", 46) != 0)
break;
return AttributeCommonInfo::AT_ObjCExplicitProtocolImpl; // "objc_protocol_requires_explicit_implementation"
}
} else if (AttributeCommonInfo::AS_Declspec == Syntax) {
switch (Name.size()) {
default: break;
case 4: // 1 string to match.
if (memcmp(Name.data()+0, "uuid", 4) != 0)
break;
return AttributeCommonInfo::AT_Uuid; // "uuid"
case 5: // 3 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "lign", 4) != 0)
break;
return AttributeCommonInfo::AT_Aligned; // "align"
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "uard", 4) != 0)
break;
return AttributeCommonInfo::AT_CFGuard; // "guard"
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "aked", 4) != 0)
break;
return AttributeCommonInfo::AT_Naked; // "naked"
}
break;
case 6: // 1 string to match.
if (memcmp(Name.data()+0, "thread", 6) != 0)
break;
return AttributeCommonInfo::AT_Thread; // "thread"
case 7: // 2 strings to match.
if (memcmp(Name.data()+0, "no", 2) != 0)
break;
switch (Name[2]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+3, "lias", 4) != 0)
break;
return AttributeCommonInfo::AT_NoAlias; // "noalias"
case 't': // 1 string to match.
if (memcmp(Name.data()+3, "hrow", 4) != 0)
break;
return AttributeCommonInfo::AT_NoThrow; // "nothrow"
}
break;
case 8: // 8 strings to match.
switch (Name[0]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+1, "_host__", 7) != 0)
break;
return AttributeCommonInfo::AT_CUDAHost; // "__host__"
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "llocate", 7) != 0)
break;
return AttributeCommonInfo::AT_Section; // "allocate"
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "ode_seg", 7) != 0)
break;
return AttributeCommonInfo::AT_CodeSeg; // "code_seg"
case 'n': // 3 strings to match.
if (Name[1] != 'o')
break;
switch (Name[2]) {
default: break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+3, "nline", 5) != 0)
break;
return AttributeCommonInfo::AT_NoInline; // "noinline"
case 'r': // 1 string to match.
if (memcmp(Name.data()+3, "eturn", 5) != 0)
break;
return AttributeCommonInfo::AT_NoReturn; // "noreturn"
case 'v': // 1 string to match.
if (memcmp(Name.data()+3, "table", 5) != 0)
break;
return AttributeCommonInfo::AT_MSNoVTable; // "novtable"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "roperty", 7) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "property"
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "estrict", 7) != 0)
break;
return AttributeCommonInfo::AT_Restrict; // "restrict"
}
break;
case 9: // 4 strings to match.
switch (Name[0]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "llocator", 8) != 0)
break;
return AttributeCommonInfo::AT_MSAllocator; // "allocator"
case 'd': // 2 strings to match.
if (memcmp(Name.data()+1, "ll", 2) != 0)
break;
switch (Name[3]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+4, "xport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLExport; // "dllexport"
case 'i': // 1 string to match.
if (memcmp(Name.data()+4, "mport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLImport; // "dllimport"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+1, "electany", 8) != 0)
break;
return AttributeCommonInfo::AT_SelectAny; // "selectany"
}
break;
case 10: // 4 strings to match.
switch (Name[0]) {
default: break;
case '_': // 3 strings to match.
if (Name[1] != '_')
break;
switch (Name[2]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+3, "evice__", 7) != 0)
break;
return AttributeCommonInfo::AT_CUDADevice; // "__device__"
case 'g': // 1 string to match.
if (memcmp(Name.data()+3, "lobal__", 7) != 0)
break;
return AttributeCommonInfo::AT_CUDAGlobal; // "__global__"
case 's': // 1 string to match.
if (memcmp(Name.data()+3, "hared__", 7) != 0)
break;
return AttributeCommonInfo::AT_CUDAShared; // "__shared__"
}
break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "eprecated", 9) != 0)
break;
return AttributeCommonInfo::AT_Deprecated; // "deprecated"
}
break;
case 11: // 1 string to match.
if (memcmp(Name.data()+0, "empty_bases", 11) != 0)
break;
return AttributeCommonInfo::AT_EmptyBases; // "empty_bases"
case 12: // 3 strings to match.
switch (Name[0]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+1, "_constant__", 11) != 0)
break;
return AttributeCommonInfo::AT_CUDAConstant; // "__constant__"
case 'c': // 2 strings to match.
if (memcmp(Name.data()+1, "pu_", 3) != 0)
break;
switch (Name[4]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+5, "ispatch", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUDispatch; // "cpu_dispatch"
case 's': // 1 string to match.
if (memcmp(Name.data()+5, "pecific", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUSpecific; // "cpu_specific"
}
break;
}
break;
case 14: // 1 string to match.
if (memcmp(Name.data()+0, "layout_version", 14) != 0)
break;
return AttributeCommonInfo::AT_LayoutVersion; // "layout_version"
case 17: // 1 string to match.
if (memcmp(Name.data()+0, "__launch_bounds__", 17) != 0)
break;
return AttributeCommonInfo::AT_CUDALaunchBounds; // "__launch_bounds__"
case 18: // 2 strings to match.
if (memcmp(Name.data()+0, "__", 2) != 0)
break;
switch (Name[2]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+3, "udart_builtin__", 15) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "__cudart_builtin__"
case 'd': // 1 string to match.
if (memcmp(Name.data()+3, "evice_builtin__", 15) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "__device_builtin__"
}
break;
case 31: // 2 strings to match.
if (memcmp(Name.data()+0, "__device_builtin_", 17) != 0)
break;
switch (Name[17]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+18, "urface_type__", 13) != 0)
break;
return AttributeCommonInfo::AT_CUDADeviceBuiltinSurfaceType; // "__device_builtin_surface_type__"
case 't': // 1 string to match.
if (memcmp(Name.data()+18, "exture_type__", 13) != 0)
break;
return AttributeCommonInfo::AT_CUDADeviceBuiltinTextureType; // "__device_builtin_texture_type__"
}
break;
}
} else if (AttributeCommonInfo::AS_Microsoft == Syntax) {
switch (Name.size()) {
default: break;
case 4: // 1 string to match.
if (memcmp(Name.data()+0, "uuid", 4) != 0)
break;
return AttributeCommonInfo::AT_Uuid; // "uuid"
}
} else if (AttributeCommonInfo::AS_CXX11 == Syntax) {
switch (Name.size()) {
default: break;
case 6: // 1 string to match.
if (memcmp(Name.data()+0, "likely", 6) != 0)
break;
return AttributeCommonInfo::AT_Likely; // "likely"
case 8: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'g': // 3 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "ar", 2) != 0)
break;
return AttributeCommonInfo::AT_MipsLongCall; // "gnu::far"
case 'h': // 1 string to match.
if (memcmp(Name.data()+6, "ot", 2) != 0)
break;
return AttributeCommonInfo::AT_Hot; // "gnu::hot"
case 'p': // 1 string to match.
if (memcmp(Name.data()+6, "cs", 2) != 0)
break;
return AttributeCommonInfo::AT_Pcs; // "gnu::pcs"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "oreturn", 7) != 0)
break;
return AttributeCommonInfo::AT_CXX11NoReturn; // "noreturn"
case 'u': // 1 string to match.
if (memcmp(Name.data()+1, "nlikely", 7) != 0)
break;
return AttributeCommonInfo::AT_Unlikely; // "unlikely"
}
break;
case 9: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'g': // 7 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "old", 3) != 0)
break;
return AttributeCommonInfo::AT_Cold; // "gnu::cold"
case 'l': // 1 string to match.
if (memcmp(Name.data()+6, "eaf", 3) != 0)
break;
return AttributeCommonInfo::AT_Leaf; // "gnu::leaf"
case 'm': // 1 string to match.
if (memcmp(Name.data()+6, "ode", 3) != 0)
break;
return AttributeCommonInfo::AT_Mode; // "gnu::mode"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "ear", 3) != 0)
break;
return AttributeCommonInfo::AT_MipsShortCall; // "gnu::near"
case 'p': // 1 string to match.
if (memcmp(Name.data()+6, "ure", 3) != 0)
break;
return AttributeCommonInfo::AT_Pure; // "gnu::pure"
case 'u': // 1 string to match.
if (memcmp(Name.data()+6, "sed", 3) != 0)
break;
return AttributeCommonInfo::AT_Used; // "gnu::used"
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "eak", 3) != 0)
break;
return AttributeCommonInfo::AT_Weak; // "gnu::weak"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "odiscard", 8) != 0)
break;
return AttributeCommonInfo::AT_WarnUnusedResult; // "nodiscard"
}
break;
case 10: // 7 strings to match.
switch (Name[0]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "eprecated", 9) != 0)
break;
return AttributeCommonInfo::AT_Deprecated; // "deprecated"
case 'g': // 6 strings to match.
switch (Name[1]) {
default: break;
case 'n': // 5 strings to match.
if (memcmp(Name.data()+2, "u::", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "lias", 4) != 0)
break;
return AttributeCommonInfo::AT_Alias; // "gnu::alias"
case 'c': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+7, "ecl", 3) != 0)
break;
return AttributeCommonInfo::AT_CDecl; // "gnu::cdecl"
case 'o': // 1 string to match.
if (memcmp(Name.data()+7, "nst", 3) != 0)
break;
return AttributeCommonInfo::AT_Const; // "gnu::const"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+6, "func", 4) != 0)
break;
return AttributeCommonInfo::AT_IFunc; // "gnu::ifunc"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "aked", 4) != 0)
break;
return AttributeCommonInfo::AT_Naked; // "gnu::naked"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "l::Owner", 8) != 0)
break;
return AttributeCommonInfo::AT_Owner; // "gsl::Owner"
}
break;
}
break;
case 11: // 10 strings to match.
switch (Name[0]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "allthrough", 10) != 0)
break;
return AttributeCommonInfo::AT_FallThrough; // "fallthrough"
case 'g': // 9 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "ommon", 5) != 0)
break;
return AttributeCommonInfo::AT_Common; // "gnu::common"
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "ormat", 5) != 0)
break;
return AttributeCommonInfo::AT_Format; // "gnu::format"
case 'm': // 3 strings to match.
switch (Name[6]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+7, "lloc", 4) != 0)
break;
return AttributeCommonInfo::AT_Restrict; // "gnu::malloc"
case 'i': // 1 string to match.
if (memcmp(Name.data()+7, "ps16", 4) != 0)
break;
return AttributeCommonInfo::AT_Mips16; // "gnu::mips16"
case 's': // 1 string to match.
if (memcmp(Name.data()+7, "_abi", 4) != 0)
break;
return AttributeCommonInfo::AT_MSABI; // "gnu::ms_abi"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+6, "acked", 5) != 0)
break;
return AttributeCommonInfo::AT_Packed; // "gnu::packed"
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "ignal", 5) != 0)
break;
return AttributeCommonInfo::AT_AVRSignal; // "gnu::signal"
case 't': // 1 string to match.
if (memcmp(Name.data()+6, "arget", 5) != 0)
break;
return AttributeCommonInfo::AT_Target; // "gnu::target"
case 'u': // 1 string to match.
if (memcmp(Name.data()+6, "nused", 5) != 0)
break;
return AttributeCommonInfo::AT_Unused; // "gnu::unused"
}
break;
}
break;
case 12: // 15 strings to match.
switch (Name[0]) {
default: break;
case 'g': // 14 strings to match.
switch (Name[1]) {
default: break;
case 'n': // 13 strings to match.
if (memcmp(Name.data()+2, "u::", 3) != 0)
break;
switch (Name[5]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+6, "_const", 6) != 0)
break;
return AttributeCommonInfo::AT_Const; // "gnu::__const"
case 'a': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+7, "i_tag", 5) != 0)
break;
return AttributeCommonInfo::AT_AbiTag; // "gnu::abi_tag"
case 'l': // 1 string to match.
if (memcmp(Name.data()+7, "igned", 5) != 0)
break;
return AttributeCommonInfo::AT_Aligned; // "gnu::aligned"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "leanup", 6) != 0)
break;
return AttributeCommonInfo::AT_Cleanup; // "gnu::cleanup"
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "latten", 6) != 0)
break;
return AttributeCommonInfo::AT_Flatten; // "gnu::flatten"
case 'n': // 3 strings to match.
if (Name[6] != 'o')
break;
switch (Name[7]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+8, "ebug", 4) != 0)
break;
return AttributeCommonInfo::AT_NoDebug; // "gnu::nodebug"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "null", 4) != 0)
break;
return AttributeCommonInfo::AT_NonNull; // "gnu::nonnull"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "hrow", 4) != 0)
break;
return AttributeCommonInfo::AT_NoThrow; // "gnu::nothrow"
}
break;
case 'r': // 2 strings to match.
if (memcmp(Name.data()+6, "eg", 2) != 0)
break;
switch (Name[8]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+9, "all", 3) != 0)
break;
return AttributeCommonInfo::AT_RegCall; // "gnu::regcall"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "arm", 3) != 0)
break;
return AttributeCommonInfo::AT_Regparm; // "gnu::regparm"
}
break;
case 's': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+7, "ction", 5) != 0)
break;
return AttributeCommonInfo::AT_Section; // "gnu::section"
case 't': // 1 string to match.
if (memcmp(Name.data()+7, "dcall", 5) != 0)
break;
return AttributeCommonInfo::AT_StdCall; // "gnu::stdcall"
}
break;
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "eakref", 6) != 0)
break;
return AttributeCommonInfo::AT_WeakRef; // "gnu::weakref"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "l::Pointer", 10) != 0)
break;
return AttributeCommonInfo::AT_Pointer; // "gsl::Pointer"
}
break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "aybe_unused", 11) != 0)
break;
return AttributeCommonInfo::AT_Unused; // "maybe_unused"
}
break;
case 13: // 12 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 3 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "ssume", 5) != 0)
break;
return AttributeCommonInfo::AT_Assumption; // "clang::assume"
case 'b': // 1 string to match.
if (memcmp(Name.data()+8, "locks", 5) != 0)
break;
return AttributeCommonInfo::AT_Blocks; // "clang::blocks"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "ascal", 5) != 0)
break;
return AttributeCommonInfo::AT_Pascal; // "clang::pascal"
}
break;
case 'g': // 9 strings to match.
switch (Name[1]) {
default: break;
case 'n': // 8 strings to match.
if (memcmp(Name.data()+2, "u::", 3) != 0)
break;
switch (Name[5]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "astcall", 7) != 0)
break;
return AttributeCommonInfo::AT_FastCall; // "gnu::fastcall"
case 'n': // 4 strings to match.
if (Name[6] != 'o')
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "ommon", 5) != 0)
break;
return AttributeCommonInfo::AT_NoCommon; // "gnu::nocommon"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "nline", 5) != 0)
break;
return AttributeCommonInfo::AT_NoInline; // "gnu::noinline"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "ips16", 5) != 0)
break;
return AttributeCommonInfo::AT_NoMips16; // "gnu::nomips16"
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "eturn", 5) != 0)
break;
return AttributeCommonInfo::AT_NoReturn; // "gnu::noreturn"
}
break;
case 's': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+7, "ntinel", 6) != 0)
break;
return AttributeCommonInfo::AT_Sentinel; // "gnu::sentinel"
case 'y': // 1 string to match.
if (memcmp(Name.data()+7, "sv_abi", 6) != 0)
break;
return AttributeCommonInfo::AT_SysVABI; // "gnu::sysv_abi"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+6, "hiscall", 7) != 0)
break;
return AttributeCommonInfo::AT_ThisCall; // "gnu::thiscall"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "l::suppress", 11) != 0)
break;
return AttributeCommonInfo::AT_Suppress; // "gsl::suppress"
}
break;
}
break;
case 14: // 14 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 5 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "insize", 6) != 0)
break;
return AttributeCommonInfo::AT_MinSize; // "clang::minsize"
case 'n': // 2 strings to match.
if (Name[8] != 'o')
break;
switch (Name[9]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+10, "eref", 4) != 0)
break;
return AttributeCommonInfo::AT_NoDeref; // "clang::noderef"
case 'm': // 1 string to match.
if (memcmp(Name.data()+10, "erge", 4) != 0)
break;
return AttributeCommonInfo::AT_NoMerge; // "clang::nomerge"
}
break;
case 'o': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_gc", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCGC; // "clang::objc_gc"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "tnone", 5) != 0)
break;
return AttributeCommonInfo::AT_OptimizeNone; // "clang::optnone"
}
break;
}
break;
case 'g': // 9 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'd': // 2 strings to match.
if (memcmp(Name.data()+6, "ll", 2) != 0)
break;
switch (Name[8]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+9, "xport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLExport; // "gnu::dllexport"
case 'i': // 1 string to match.
if (memcmp(Name.data()+9, "mport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLImport; // "gnu::dllimport"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+6, "nterrupt", 8) != 0)
break;
return AttributeCommonInfo::AT_Interrupt; // "gnu::interrupt"
case 'l': // 1 string to match.
if (memcmp(Name.data()+6, "ong_call", 8) != 0)
break;
return AttributeCommonInfo::AT_MipsLongCall; // "gnu::long_call"
case 'm': // 3 strings to match.
switch (Name[6]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+7, "y_alias", 7) != 0)
break;
return AttributeCommonInfo::AT_MayAlias; // "gnu::may_alias"
case 'i': // 1 string to match.
if (memcmp(Name.data()+7, "cromips", 7) != 0)
break;
return AttributeCommonInfo::AT_MicroMips; // "gnu::micromips"
case 's': // 1 string to match.
if (memcmp(Name.data()+7, "_struct", 7) != 0)
break;
return AttributeCommonInfo::AT_MSStruct; // "gnu::ms_struct"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "electany", 8) != 0)
break;
return AttributeCommonInfo::AT_SelectAny; // "gnu::selectany"
case 't': // 1 string to match.
if (memcmp(Name.data()+6, "ls_model", 8) != 0)
break;
return AttributeCommonInfo::AT_TLSModel; // "gnu::tls_model"
}
break;
}
break;
case 15: // 15 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 6 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'N': // 1 string to match.
if (memcmp(Name.data()+8, "SObject", 7) != 0)
break;
return AttributeCommonInfo::AT_ObjCNSObject; // "clang::NSObject"
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "nnotate", 7) != 0)
break;
return AttributeCommonInfo::AT_Annotate; // "clang::annotate"
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "allback", 7) != 0)
break;
return AttributeCommonInfo::AT_Callback; // "clang::callback"
case 'i': // 2 strings to match.
if (Name[8] != 'b')
break;
switch (Name[9]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+10, "ction", 5) != 0)
break;
return AttributeCommonInfo::AT_IBAction; // "clang::ibaction"
case 'o': // 1 string to match.
if (memcmp(Name.data()+10, "utlet", 5) != 0)
break;
return AttributeCommonInfo::AT_IBOutlet; // "clang::iboutlet"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "oescape", 7) != 0)
break;
return AttributeCommonInfo::AT_NoEscape; // "clang::noescape"
}
break;
case 'g': // 9 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+7, "loc_size", 8) != 0)
break;
return AttributeCommonInfo::AT_AllocSize; // "gnu::alloc_size"
case 'r': // 1 string to match.
if (memcmp(Name.data()+7, "tificial", 8) != 0)
break;
return AttributeCommonInfo::AT_Artificial; // "gnu::artificial"
}
break;
case 'd': // 2 strings to match.
if (Name[6] != 'e')
break;
switch (Name[7]) {
default: break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "recated", 7) != 0)
break;
return AttributeCommonInfo::AT_Deprecated; // "gnu::deprecated"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "tructor", 7) != 0)
break;
return AttributeCommonInfo::AT_Destructor; // "gnu::destructor"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "ormat_arg", 9) != 0)
break;
return AttributeCommonInfo::AT_FormatArg; // "gnu::format_arg"
case 'g': // 1 string to match.
if (memcmp(Name.data()+6, "nu_inline", 9) != 0)
break;
return AttributeCommonInfo::AT_GNUInline; // "gnu::gnu_inline"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "ocf_check", 9) != 0)
break;
return AttributeCommonInfo::AT_AnyX86NoCfCheck; // "gnu::nocf_check"
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "hort_call", 9) != 0)
break;
return AttributeCommonInfo::AT_MipsShortCall; // "gnu::short_call"
case 'v': // 1 string to match.
if (memcmp(Name.data()+6, "isibility", 9) != 0)
break;
return AttributeCommonInfo::AT_Visibility; // "gnu::visibility"
}
break;
}
break;
case 16: // 9 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 3 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+8, "lag_enum", 8) != 0)
break;
return AttributeCommonInfo::AT_FlagEnum; // "clang::flag_enum"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "wiftcall", 8) != 0)
break;
return AttributeCommonInfo::AT_SwiftCall; // "clang::swiftcall"
case 'v': // 1 string to match.
if (memcmp(Name.data()+8, "ecreturn", 8) != 0)
break;
return AttributeCommonInfo::AT_VecReturn; // "clang::vecreturn"
}
break;
case 'g': // 6 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "lloc_align", 10) != 0)
break;
return AttributeCommonInfo::AT_AllocAlign; // "gnu::alloc_align"
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "onstructor", 10) != 0)
break;
return AttributeCommonInfo::AT_Constructor; // "gnu::constructor"
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "allthrough", 10) != 0)
break;
return AttributeCommonInfo::AT_FallThrough; // "gnu::fallthrough"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "omicromips", 10) != 0)
break;
return AttributeCommonInfo::AT_NoMicroMips; // "gnu::nomicromips"
case 'v': // 1 string to match.
if (memcmp(Name.data()+6, "ector_size", 10) != 0)
break;
return AttributeCommonInfo::AT_VectorSize; // "gnu::vector_size"
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "arn_unused", 10) != 0)
break;
return AttributeCommonInfo::AT_WarnUnused; // "gnu::warn_unused"
}
break;
}
break;
case 17: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+9, "pability", 8) != 0)
break;
return AttributeCommonInfo::AT_Capability; // "clang::capability"
case 'o': // 2 strings to match.
if (Name[9] != 'n')
break;
switch (Name[10]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+11, "umable", 6) != 0)
break;
return AttributeCommonInfo::AT_Consumable; // "clang::consumable"
case 'v': // 1 string to match.
if (memcmp(Name.data()+11, "ergent", 6) != 0)
break;
return AttributeCommonInfo::AT_Convergent; // "clang::convergent"
}
break;
}
break;
case 'n': // 2 strings to match.
if (memcmp(Name.data()+8, "o_", 2) != 0)
break;
switch (Name[10]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+11, "uiltin", 6) != 0)
break;
return AttributeCommonInfo::AT_NoBuiltin; // "clang::no_builtin"
case 'd': // 1 string to match.
if (memcmp(Name.data()+11, "estroy", 6) != 0)
break;
return AttributeCommonInfo::AT_NoDestroy; // "clang::no_destroy"
}
break;
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "se_handle", 9) != 0)
break;
return AttributeCommonInfo::AT_UseHandle; // "clang::use_handle"
case 'v': // 1 string to match.
if (memcmp(Name.data()+8, "ectorcall", 9) != 0)
break;
return AttributeCommonInfo::AT_VectorCall; // "clang::vectorcall"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "o_unique_address", 16) != 0)
break;
return AttributeCommonInfo::AT_NoUniqueAddress; // "no_unique_address"
}
break;
case 18: // 23 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 20 strings to match.
switch (Name[1]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+2, "rries_dependency", 16) != 0)
break;
return AttributeCommonInfo::AT_CarriesDependency; // "carries_dependency"
case 'l': // 19 strings to match.
if (memcmp(Name.data()+2, "ang::", 5) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+9, "lled_once", 9) != 0)
break;
return AttributeCommonInfo::AT_CalledOnce; // "clang::called_once"
case 'f': // 1 string to match.
if (memcmp(Name.data()+9, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_CFConsumed; // "clang::cf_consumed"
}
break;
case 'e': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+9, "force_tcb", 9) != 0)
break;
return AttributeCommonInfo::AT_EnforceTCB; // "clang::enforce_tcb"
case 'x': // 1 string to match.
if (memcmp(Name.data()+9, "port_name", 9) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyExportName; // "clang::export_name"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+8, "allthrough", 10) != 0)
break;
return AttributeCommonInfo::AT_FallThrough; // "clang::fallthrough"
case 'g': // 1 string to match.
if (memcmp(Name.data()+8, "uarded_var", 10) != 0)
break;
return AttributeCommonInfo::AT_GuardedVar; // "clang::guarded_var"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "mport_name", 10) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyImportName; // "clang::import_name"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "atrix_type", 10) != 0)
break;
return AttributeCommonInfo::AT_MatrixType; // "clang::matrix_type"
case 'n': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'o': // 2 strings to match.
switch (Name[9]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+10, "sanitize", 8) != 0)
break;
return AttributeCommonInfo::AT_NoSanitize; // "clang::no_sanitize"
case 'd': // 1 string to match.
if (memcmp(Name.data()+10, "uplicate", 8) != 0)
break;
return AttributeCommonInfo::AT_NoDuplicate; // "clang::noduplicate"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_NSConsumed; // "clang::ns_consumed"
}
break;
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+13, "ridge", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridge; // "clang::objc_bridge"
case 'd': // 1 string to match.
if (memcmp(Name.data()+13, "irect", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCDirect; // "clang::objc_direct"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_OSConsumed; // "clang::os_consumed"
}
break;
case 's': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'w': // 1 string to match.
if (memcmp(Name.data()+9, "ift_async", 9) != 0)
break;
return AttributeCommonInfo::AT_SwiftAsync; // "clang::swift_async"
case 'y': // 1 string to match.
if (memcmp(Name.data()+9, "cl_kernel", 9) != 0)
break;
return AttributeCommonInfo::AT_SYCLKernel; // "clang::sycl_kernel"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "rivial_abi", 10) != 0)
break;
return AttributeCommonInfo::AT_TrivialABI; // "clang::trivial_abi"
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "navailable", 10) != 0)
break;
return AttributeCommonInfo::AT_Unavailable; // "clang::unavailable"
case 'w': // 1 string to match.
if (memcmp(Name.data()+8, "eak_import", 10) != 0)
break;
return AttributeCommonInfo::AT_WeakImport; // "clang::weak_import"
}
break;
}
break;
case 'g': // 3 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "lways_inline", 12) != 0)
break;
return AttributeCommonInfo::AT_AlwaysInline; // "gnu::always_inline"
case 'i': // 1 string to match.
if (memcmp(Name.data()+6, "nit_priority", 12) != 0)
break;
return AttributeCommonInfo::AT_InitPriority; // "gnu::init_priority"
case 'r': // 1 string to match.
if (memcmp(Name.data()+6, "eturns_twice", 12) != 0)
break;
return AttributeCommonInfo::AT_ReturnsTwice; // "gnu::returns_twice"
}
break;
}
break;
case 19: // 9 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "vailability", 11) != 0)
break;
return AttributeCommonInfo::AT_Availability; // "clang::availability"
case 'c': // 2 strings to match.
if (memcmp(Name.data()+8, "pu_", 3) != 0)
break;
switch (Name[11]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+12, "ispatch", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUDispatch; // "clang::cpu_dispatch"
case 's': // 1 string to match.
if (memcmp(Name.data()+12, "pecific", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUSpecific; // "clang::cpu_specific"
}
break;
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_boxable", 10) != 0)
break;
return AttributeCommonInfo::AT_ObjCBoxable; // "clang::objc_boxable"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_local", 10) != 0)
break;
return AttributeCommonInfo::AT_OpenCLLocalAddressSpace; // "clang::opencl_local"
case 'v': // 1 string to match.
if (memcmp(Name.data()+9, "erloadable", 10) != 0)
break;
return AttributeCommonInfo::AT_Overloadable; // "clang::overloadable"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "reserve_all", 11) != 0)
break;
return AttributeCommonInfo::AT_PreserveAll; // "clang::preserve_all"
}
break;
case 'g': // 2 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "ssume_aligned", 13) != 0)
break;
return AttributeCommonInfo::AT_AssumeAligned; // "gnu::assume_aligned"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "o_split_stack", 13) != 0)
break;
return AttributeCommonInfo::AT_NoSplitStack; // "gnu::no_split_stack"
}
break;
}
break;
case 20: // 12 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 11 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "ddress_space", 12) != 0)
break;
return AttributeCommonInfo::AT_AddressSpace; // "clang::address_space"
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "allable_when", 12) != 0)
break;
return AttributeCommonInfo::AT_CallableWhen; // "clang::callable_when"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "mport_module", 12) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyImportModule; // "clang::import_module"
case 'l': // 1 string to match.
if (memcmp(Name.data()+8, "ifetimebound", 12) != 0)
break;
return AttributeCommonInfo::AT_LifetimeBound; // "clang::lifetimebound"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "pencl_global", 12) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalAddressSpace; // "clang::opencl_global"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "reserve_most", 12) != 0)
break;
return AttributeCommonInfo::AT_PreserveMost; // "clang::preserve_most"
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "einitializes", 12) != 0)
break;
return AttributeCommonInfo::AT_Reinitializes; // "clang::reinitializes"
case 's': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+9, "t_typestate", 11) != 0)
break;
return AttributeCommonInfo::AT_SetTypestate; // "clang::set_typestate"
case 'w': // 1 string to match.
if (memcmp(Name.data()+9, "ift_context", 11) != 0)
break;
return AttributeCommonInfo::AT_SwiftContext; // "clang::swift_context"
}
break;
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "ninitialized", 12) != 0)
break;
return AttributeCommonInfo::AT_Uninitialized; // "clang::uninitialized"
case 'x': // 1 string to match.
if (memcmp(Name.data()+8, "ray_log_args", 12) != 0)
break;
return AttributeCommonInfo::AT_XRayLogArgs; // "clang::xray_log_args"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::returns_nonnull", 19) != 0)
break;
return AttributeCommonInfo::AT_ReturnsNonNull; // "gnu::returns_nonnull"
}
break;
case 21: // 11 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+9, "quire_handle", 12) != 0)
break;
return AttributeCommonInfo::AT_AcquireHandle; // "clang::acquire_handle"
case 'l': // 1 string to match.
if (memcmp(Name.data()+9, "ways_destroy", 12) != 0)
break;
return AttributeCommonInfo::AT_AlwaysDestroy; // "clang::always_destroy"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "ntel_ocl_bicc", 13) != 0)
break;
return AttributeCommonInfo::AT_IntelOclBicc; // "clang::intel_ocl_bicc"
case 'o': // 4 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+13, "xception", 8) != 0)
break;
return AttributeCommonInfo::AT_ObjCException; // "clang::objc_exception"
case 'o': // 1 string to match.
if (memcmp(Name.data()+13, "wnership", 8) != 0)
break;
return AttributeCommonInfo::AT_ObjCOwnership; // "clang::objc_ownership"
}
break;
case 'p': // 2 strings to match.
if (memcmp(Name.data()+9, "encl_", 5) != 0)
break;
switch (Name[14]) {
default: break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+15, "eneric", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGenericAddressSpace; // "clang::opencl_generic"
case 'p': // 1 string to match.
if (memcmp(Name.data()+15, "rivate", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLPrivateAddressSpace; // "clang::opencl_private"
}
break;
}
break;
case 'p': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+9, "eferred_name", 12) != 0)
break;
return AttributeCommonInfo::AT_PreferredName; // "clang::preferred_name"
case 't': // 1 string to match.
if (memcmp(Name.data()+9, "_guarded_var", 12) != 0)
break;
return AttributeCommonInfo::AT_PtGuardedVar; // "clang::pt_guarded_var"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "elease_handle", 13) != 0)
break;
return AttributeCommonInfo::AT_ReleaseHandle; // "clang::release_handle"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "est_typestate", 13) != 0)
break;
return AttributeCommonInfo::AT_TestTypestate; // "clang::test_typestate"
}
break;
case 22: // 13 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 12 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 2 strings to match.
if (memcmp(Name.data()+8, "mdgpu_num_", 10) != 0)
break;
switch (Name[18]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+19, "gpr", 3) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUNumSGPR; // "clang::amdgpu_num_sgpr"
case 'v': // 1 string to match.
if (memcmp(Name.data()+19, "gpr", 3) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUNumVGPR; // "clang::amdgpu_num_vgpr"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "ot_tail_called", 14) != 0)
break;
return AttributeCommonInfo::AT_NotTailCalled; // "clang::not_tail_called"
case 'o': // 5 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+13, "lass_stub", 9) != 0)
break;
return AttributeCommonInfo::AT_ObjCClassStub; // "clang::objc_class_stub"
case 'r': // 1 string to match.
if (memcmp(Name.data()+13, "oot_class", 9) != 0)
break;
return AttributeCommonInfo::AT_ObjCRootClass; // "clang::objc_root_class"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_constant", 13) != 0)
break;
return AttributeCommonInfo::AT_OpenCLConstantAddressSpace; // "clang::opencl_constant"
case 'w': // 2 strings to match.
if (memcmp(Name.data()+9, "nership_", 8) != 0)
break;
switch (Name[17]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+18, "olds", 4) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "clang::ownership_holds"
case 't': // 1 string to match.
if (memcmp(Name.data()+18, "akes", 4) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "clang::ownership_takes"
}
break;
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "aram_typestate", 14) != 0)
break;
return AttributeCommonInfo::AT_ParamTypestate; // "clang::param_typestate"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "coped_lockable", 14) != 0)
break;
return AttributeCommonInfo::AT_ScopedLockable; // "clang::scoped_lockable"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "ype_visibility", 14) != 0)
break;
return AttributeCommonInfo::AT_TypeVisibility; // "clang::type_visibility"
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "nlock_function", 14) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "clang::unlock_function"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::transparent_union", 21) != 0)
break;
return AttributeCommonInfo::AT_TransparentUnion; // "gnu::transparent_union"
}
break;
case 23: // 10 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 8 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "nforce_tcb_leaf", 15) != 0)
break;
return AttributeCommonInfo::AT_EnforceTCBLeaf; // "clang::enforce_tcb_leaf"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "nternal_linkage", 15) != 0)
break;
return AttributeCommonInfo::AT_InternalLinkage; // "clang::internal_linkage"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "in_vector_width", 15) != 0)
break;
return AttributeCommonInfo::AT_MinVectorWidth; // "clang::min_vector_width"
case 'n': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+9, "on_vector_type", 14) != 0)
break;
return AttributeCommonInfo::AT_NeonVectorType; // "clang::neon_vector_type"
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_consumes_self", 14) != 0)
break;
return AttributeCommonInfo::AT_NSConsumesSelf; // "clang::ns_consumes_self"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "s_consumes_this", 15) != 0)
break;
return AttributeCommonInfo::AT_OSConsumesThis; // "clang::os_consumes_this"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "ass_object_size", 15) != 0)
break;
return AttributeCommonInfo::AT_PassObjectSize; // "clang::pass_object_size"
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "eturn_typestate", 15) != 0)
break;
return AttributeCommonInfo::AT_ReturnTypestate; // "clang::return_typestate"
}
break;
case 'g': // 2 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "o_sanitize_thread", 17) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "gnu::no_sanitize_thread"
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "arn_unused_result", 17) != 0)
break;
return AttributeCommonInfo::AT_WarnUnusedResult; // "gnu::warn_unused_result"
}
break;
}
break;
case 24: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "ssert_capability", 16) != 0)
break;
return AttributeCommonInfo::AT_AssertCapability; // "clang::assert_capability"
case 'o': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_runtime_name", 15) != 0)
break;
return AttributeCommonInfo::AT_ObjCRuntimeName; // "clang::objc_runtime_name"
case 'w': // 1 string to match.
if (memcmp(Name.data()+9, "nership_returns", 15) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "clang::ownership_returns"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "hared_capability", 16) != 0)
break;
return AttributeCommonInfo::AT_Capability; // "clang::shared_capability"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_sanitize_address", 23) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "gnu::no_sanitize_address"
}
break;
case 25: // 14 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+9, "rch64_vector_pcs", 16) != 0)
break;
return AttributeCommonInfo::AT_AArch64VectorPcs; // "clang::aarch64_vector_pcs"
case 'c': // 1 string to match.
if (memcmp(Name.data()+9, "quire_capability", 16) != 0)
break;
return AttributeCommonInfo::AT_AcquireCapability; // "clang::acquire_capability"
}
break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+8, "isable_tail_calls", 17) != 0)
break;
return AttributeCommonInfo::AT_DisableTailCalls; // "clang::disable_tail_calls"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "num_extensibility", 17) != 0)
break;
return AttributeCommonInfo::AT_EnumExtensibility; // "clang::enum_extensibility"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "boutletcollection", 17) != 0)
break;
return AttributeCommonInfo::AT_IBOutletCollection; // "clang::iboutletcollection"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "ig_server_routine", 17) != 0)
break;
return AttributeCommonInfo::AT_MIGServerRoutine; // "clang::mig_server_routine"
case 'n': // 2 strings to match.
if (memcmp(Name.data()+8, "o_s", 3) != 0)
break;
switch (Name[11]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+12, "nitize_memory", 13) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "clang::no_sanitize_memory"
case 't': // 1 string to match.
if (memcmp(Name.data()+12, "ack_protector", 13) != 0)
break;
return AttributeCommonInfo::AT_NoStackProtector; // "clang::no_stack_protector"
}
break;
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+13, "ethod_family", 12) != 0)
break;
return AttributeCommonInfo::AT_ObjCMethodFamily; // "clang::objc_method_family"
case 'n': // 1 string to match.
if (memcmp(Name.data()+13, "onlazy_class", 12) != 0)
break;
return AttributeCommonInfo::AT_ObjCNonLazyClass; // "clang::objc_nonlazy_class"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_global_host", 16) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalHostAddressSpace; // "clang::opencl_global_host"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "elease_capability", 17) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "clang::release_capability"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "wift_error_result", 17) != 0)
break;
return AttributeCommonInfo::AT_SwiftErrorResult; // "clang::swift_error_result"
case 'w': // 1 string to match.
if (memcmp(Name.data()+8, "arn_unused_result", 17) != 0)
break;
return AttributeCommonInfo::AT_WarnUnusedResult; // "clang::warn_unused_result"
}
break;
case 26: // 11 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "mdgpu_waves_per_eu", 18) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUWavesPerEU; // "clang::amdgpu_waves_per_eu"
case 'c': // 3 strings to match.
if (memcmp(Name.data()+8, "f_", 2) != 0)
break;
switch (Name[10]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+11, "udited_transfer", 15) != 0)
break;
return AttributeCommonInfo::AT_CFAuditedTransfer; // "clang::cf_audited_transfer"
case 'r': // 1 string to match.
if (memcmp(Name.data()+11, "eturns_retained", 15) != 0)
break;
return AttributeCommonInfo::AT_CFReturnsRetained; // "clang::cf_returns_retained"
case 'u': // 1 string to match.
if (memcmp(Name.data()+11, "nknown_transfer", 15) != 0)
break;
return AttributeCommonInfo::AT_CFUnknownTransfer; // "clang::cf_unknown_transfer"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "s_returns_retained", 18) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsRetained; // "clang::ns_returns_retained"
case 'o': // 5 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 4 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+13, "ridge_", 6) != 0)
break;
switch (Name[19]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+20, "utable", 6) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridgeMutable; // "clang::objc_bridge_mutable"
case 'r': // 1 string to match.
if (memcmp(Name.data()+20, "elated", 6) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridgeRelated; // "clang::objc_bridge_related"
}
break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+13, "irect_members", 13) != 0)
break;
return AttributeCommonInfo::AT_ObjCDirectMembers; // "clang::objc_direct_members"
case 'r': // 1 string to match.
if (memcmp(Name.data()+13, "equires_super", 13) != 0)
break;
return AttributeCommonInfo::AT_ObjCRequiresSuper; // "clang::objc_requires_super"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_returns_retained", 17) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetained; // "clang::os_returns_retained"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "equires_capability", 18) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "clang::requires_capability"
}
break;
case 27: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+8, "oader_uninitialized", 19) != 0)
break;
return AttributeCommonInfo::AT_LoaderUninitialized; // "clang::loader_uninitialized"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "eon_polyvector_type", 19) != 0)
break;
return AttributeCommonInfo::AT_NeonPolyVectorType; // "clang::neon_polyvector_type"
case 'o': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_runtime_visible", 18) != 0)
break;
return AttributeCommonInfo::AT_ObjCRuntimeVisible; // "clang::objc_runtime_visible"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_global_device", 18) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalDeviceAddressSpace; // "clang::opencl_global_device"
}
break;
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_instrument_function", 26) != 0)
break;
return AttributeCommonInfo::AT_NoInstrumentFunction; // "gnu::no_instrument_function"
}
break;
case 28: // 9 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 8 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+8, "to_visibility_public", 20) != 0)
break;
return AttributeCommonInfo::AT_LTOVisibilityPublic; // "clang::lto_visibility_public"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_precise_lifetime", 20) != 0)
break;
return AttributeCommonInfo::AT_ObjCPreciseLifetime; // "clang::objc_precise_lifetime"
case 'p': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+9, "inter_with_type_tag", 19) != 0)
break;
return AttributeCommonInfo::AT_ArgumentWithTypeTag; // "clang::pointer_with_type_tag"
case 'r': // 1 string to match.
if (memcmp(Name.data()+9, "eserve_access_index", 19) != 0)
break;
return AttributeCommonInfo::AT_BPFPreserveAccessIndex; // "clang::preserve_access_index"
}
break;
case 's': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+9, "ared_locks_required", 19) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "clang::shared_locks_required"
case 'w': // 1 string to match.
if (memcmp(Name.data()+9, "ift_indirect_result", 19) != 0)
break;
return AttributeCommonInfo::AT_SwiftIndirectResult; // "clang::swift_indirect_result"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "ype_tag_for_datatype", 20) != 0)
break;
return AttributeCommonInfo::AT_TypeTagForDatatype; // "clang::type_tag_for_datatype"
case 'x': // 1 string to match.
if (memcmp(Name.data()+8, "ray_never_instrument", 20) != 0)
break;
return AttributeCommonInfo::AT_XRayInstrument; // "clang::xray_never_instrument"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::force_align_arg_pointer", 27) != 0)
break;
return AttributeCommonInfo::AT_X86ForceAlignArgPointer; // "gnu::force_align_arg_pointer"
}
break;
case 29: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 5 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "rgument_with_type_tag", 21) != 0)
break;
return AttributeCommonInfo::AT_ArgumentWithTypeTag; // "clang::argument_with_type_tag"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "xternal_source_symbol", 21) != 0)
break;
return AttributeCommonInfo::AT_ExternalSourceSymbol; // "clang::external_source_symbol"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_independent_class", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCIndependentClass; // "clang::objc_independent_class"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "ry_acquire_capability", 21) != 0)
break;
return AttributeCommonInfo::AT_TryAcquireCapability; // "clang::try_acquire_capability"
case 'x': // 1 string to match.
if (memcmp(Name.data()+8, "ray_always_instrument", 21) != 0)
break;
return AttributeCommonInfo::AT_XRayInstrument; // "clang::xray_always_instrument"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::patchable_function_entry", 28) != 0)
break;
return AttributeCommonInfo::AT_PatchableFunctionEntry; // "gnu::patchable_function_entry"
}
break;
case 30: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "f_returns_not_retained", 22) != 0)
break;
return AttributeCommonInfo::AT_CFReturnsNotRetained; // "clang::cf_returns_not_retained"
case 'n': // 2 strings to match.
if (memcmp(Name.data()+8, "s_returns_", 10) != 0)
break;
switch (Name[18]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+19, "utoreleased", 11) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsAutoreleased; // "clang::ns_returns_autoreleased"
case 'n': // 1 string to match.
if (memcmp(Name.data()+19, "ot_retained", 11) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsNotRetained; // "clang::ns_returns_not_retained"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "s_returns_not_retained", 22) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsNotRetained; // "clang::os_returns_not_retained"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_caller_saved_registers", 29) != 0)
break;
return AttributeCommonInfo::AT_AnyX86NoCallerSavedRegisters; // "gnu::no_caller_saved_registers"
}
break;
case 31: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 5 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "ssert_shared_capability", 23) != 0)
break;
return AttributeCommonInfo::AT_AssertCapability; // "clang::assert_shared_capability"
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "fi_canonical_jump_table", 23) != 0)
break;
return AttributeCommonInfo::AT_CFICanonicalJumpTable; // "clang::cfi_canonical_jump_table"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "xclusive_locks_required", 23) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "clang::exclusive_locks_required"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_externally_retained", 23) != 0)
break;
return AttributeCommonInfo::AT_ObjCExternallyRetained; // "clang::objc_externally_retained"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "ass_dynamic_object_size", 23) != 0)
break;
return AttributeCommonInfo::AT_PassObjectSize; // "clang::pass_dynamic_object_size"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_address_safety_analysis", 30) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "gnu::no_address_safety_analysis"
}
break;
case 32: // 5 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+8, "_clang_arm_builtin_alias", 24) != 0)
break;
return AttributeCommonInfo::AT_ArmBuiltinAlias; // "clang::__clang_arm_builtin_alias"
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "cquire_shared_capability", 24) != 0)
break;
return AttributeCommonInfo::AT_AcquireCapability; // "clang::acquire_shared_capability"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "o_thread_safety_analysis", 24) != 0)
break;
return AttributeCommonInfo::AT_NoThreadSafetyAnalysis; // "clang::no_thread_safety_analysis"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_non_runtime_protocol", 24) != 0)
break;
return AttributeCommonInfo::AT_ObjCNonRuntimeProtocol; // "clang::objc_non_runtime_protocol"
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "elease_shared_capability", 24) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "clang::release_shared_capability"
}
break;
case 33: // 5 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "onsumable_auto_cast_state", 25) != 0)
break;
return AttributeCommonInfo::AT_ConsumableAutoCast; // "clang::consumable_auto_cast_state"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_returns_inner_pointer", 25) != 0)
break;
return AttributeCommonInfo::AT_ObjCReturnsInnerPointer; // "clang::objc_returns_inner_pointer"
case 'r': // 2 strings to match.
if (Name[8] != 'e')
break;
switch (Name[9]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+10, "ease_generic_capability", 23) != 0)
break;
return AttributeCommonInfo::AT_ReleaseCapability; // "clang::release_generic_capability"
case 'q': // 1 string to match.
if (memcmp(Name.data()+10, "uires_shared_capability", 23) != 0)
break;
return AttributeCommonInfo::AT_RequiresCapability; // "clang::requires_shared_capability"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "peculative_load_hardening", 25) != 0)
break;
return AttributeCommonInfo::AT_SpeculativeLoadHardening; // "clang::speculative_load_hardening"
}
break;
case 34: // 4 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "mdgpu_flat_work_group_size", 26) != 0)
break;
return AttributeCommonInfo::AT_AMDGPUFlatWorkGroupSize; // "clang::amdgpu_flat_work_group_size"
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+13, "esignated_initializer", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCDesignatedInitializer; // "clang::objc_designated_initializer"
case 's': // 1 string to match.
if (memcmp(Name.data()+13, "ubclassing_restricted", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCSubclassingRestricted; // "clang::objc_subclassing_restricted"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_returns_retained_on_zero", 25) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetainedOnZero; // "clang::os_returns_retained_on_zero"
}
break;
}
break;
case 35: // 1 string to match.
if (memcmp(Name.data()+0, "clang::consumable_set_state_on_read", 35) != 0)
break;
return AttributeCommonInfo::AT_ConsumableSetOnRead; // "clang::consumable_set_state_on_read"
case 36: // 2 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "o_speculative_load_hardening", 28) != 0)
break;
return AttributeCommonInfo::AT_NoSpeculativeLoadHardening; // "clang::no_speculative_load_hardening"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "ry_acquire_shared_capability", 28) != 0)
break;
return AttributeCommonInfo::AT_TryAcquireCapability; // "clang::try_acquire_shared_capability"
}
break;
case 38: // 2 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "s_returns_retained_on_non_zero", 30) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetainedOnNonZero; // "clang::os_returns_retained_on_non_zero"
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "equire_constant_initialization", 30) != 0)
break;
return AttributeCommonInfo::AT_ConstInit; // "clang::require_constant_initialization"
}
break;
case 41: // 1 string to match.
if (memcmp(Name.data()+0, "clang::objc_requires_property_definitions", 41) != 0)
break;
return AttributeCommonInfo::AT_ObjCRequiresPropertyDefs; // "clang::objc_requires_property_definitions"
case 42: // 3 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+8, "_clang_arm_mve_strict_polymorphism", 34) != 0)
break;
return AttributeCommonInfo::AT_ArmMveStrictPolymorphism; // "clang::__clang_arm_mve_strict_polymorphism"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "xclude_from_explicit_instantiation", 34) != 0)
break;
return AttributeCommonInfo::AT_ExcludeFromExplicitInstantiation; // "clang::exclude_from_explicit_instantiation"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_arc_weak_reference_unavailable", 34) != 0)
break;
return AttributeCommonInfo::AT_ArcWeakrefUnavailable; // "clang::objc_arc_weak_reference_unavailable"
}
break;
case 53: // 1 string to match.
if (memcmp(Name.data()+0, "clang::objc_protocol_requires_explicit_implementation", 53) != 0)
break;
return AttributeCommonInfo::AT_ObjCExplicitProtocolImpl; // "clang::objc_protocol_requires_explicit_implementation"
}
} else if (AttributeCommonInfo::AS_C2x == Syntax) {
switch (Name.size()) {
default: break;
case 8: // 3 strings to match.
if (memcmp(Name.data()+0, "gnu::", 5) != 0)
break;
switch (Name[5]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "ar", 2) != 0)
break;
return AttributeCommonInfo::AT_MipsLongCall; // "gnu::far"
case 'h': // 1 string to match.
if (memcmp(Name.data()+6, "ot", 2) != 0)
break;
return AttributeCommonInfo::AT_Hot; // "gnu::hot"
case 'p': // 1 string to match.
if (memcmp(Name.data()+6, "cs", 2) != 0)
break;
return AttributeCommonInfo::AT_Pcs; // "gnu::pcs"
}
break;
case 9: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'g': // 7 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "old", 3) != 0)
break;
return AttributeCommonInfo::AT_Cold; // "gnu::cold"
case 'l': // 1 string to match.
if (memcmp(Name.data()+6, "eaf", 3) != 0)
break;
return AttributeCommonInfo::AT_Leaf; // "gnu::leaf"
case 'm': // 1 string to match.
if (memcmp(Name.data()+6, "ode", 3) != 0)
break;
return AttributeCommonInfo::AT_Mode; // "gnu::mode"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "ear", 3) != 0)
break;
return AttributeCommonInfo::AT_MipsShortCall; // "gnu::near"
case 'p': // 1 string to match.
if (memcmp(Name.data()+6, "ure", 3) != 0)
break;
return AttributeCommonInfo::AT_Pure; // "gnu::pure"
case 'u': // 1 string to match.
if (memcmp(Name.data()+6, "sed", 3) != 0)
break;
return AttributeCommonInfo::AT_Used; // "gnu::used"
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "eak", 3) != 0)
break;
return AttributeCommonInfo::AT_Weak; // "gnu::weak"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+1, "odiscard", 8) != 0)
break;
return AttributeCommonInfo::AT_WarnUnusedResult; // "nodiscard"
}
break;
case 10: // 6 strings to match.
switch (Name[0]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+1, "eprecated", 9) != 0)
break;
return AttributeCommonInfo::AT_Deprecated; // "deprecated"
case 'g': // 5 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "lias", 4) != 0)
break;
return AttributeCommonInfo::AT_Alias; // "gnu::alias"
case 'c': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+7, "ecl", 3) != 0)
break;
return AttributeCommonInfo::AT_CDecl; // "gnu::cdecl"
case 'o': // 1 string to match.
if (memcmp(Name.data()+7, "nst", 3) != 0)
break;
return AttributeCommonInfo::AT_Const; // "gnu::const"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+6, "func", 4) != 0)
break;
return AttributeCommonInfo::AT_IFunc; // "gnu::ifunc"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "aked", 4) != 0)
break;
return AttributeCommonInfo::AT_Naked; // "gnu::naked"
}
break;
}
break;
case 11: // 10 strings to match.
switch (Name[0]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+1, "allthrough", 10) != 0)
break;
return AttributeCommonInfo::AT_FallThrough; // "fallthrough"
case 'g': // 9 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "ommon", 5) != 0)
break;
return AttributeCommonInfo::AT_Common; // "gnu::common"
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "ormat", 5) != 0)
break;
return AttributeCommonInfo::AT_Format; // "gnu::format"
case 'm': // 3 strings to match.
switch (Name[6]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+7, "lloc", 4) != 0)
break;
return AttributeCommonInfo::AT_Restrict; // "gnu::malloc"
case 'i': // 1 string to match.
if (memcmp(Name.data()+7, "ps16", 4) != 0)
break;
return AttributeCommonInfo::AT_Mips16; // "gnu::mips16"
case 's': // 1 string to match.
if (memcmp(Name.data()+7, "_abi", 4) != 0)
break;
return AttributeCommonInfo::AT_MSABI; // "gnu::ms_abi"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+6, "acked", 5) != 0)
break;
return AttributeCommonInfo::AT_Packed; // "gnu::packed"
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "ignal", 5) != 0)
break;
return AttributeCommonInfo::AT_AVRSignal; // "gnu::signal"
case 't': // 1 string to match.
if (memcmp(Name.data()+6, "arget", 5) != 0)
break;
return AttributeCommonInfo::AT_Target; // "gnu::target"
case 'u': // 1 string to match.
if (memcmp(Name.data()+6, "nused", 5) != 0)
break;
return AttributeCommonInfo::AT_Unused; // "gnu::unused"
}
break;
}
break;
case 12: // 13 strings to match.
switch (Name[0]) {
default: break;
case 'g': // 12 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+6, "_const", 6) != 0)
break;
return AttributeCommonInfo::AT_Const; // "gnu::__const"
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "ligned", 6) != 0)
break;
return AttributeCommonInfo::AT_Aligned; // "gnu::aligned"
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "leanup", 6) != 0)
break;
return AttributeCommonInfo::AT_Cleanup; // "gnu::cleanup"
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "latten", 6) != 0)
break;
return AttributeCommonInfo::AT_Flatten; // "gnu::flatten"
case 'n': // 3 strings to match.
if (Name[6] != 'o')
break;
switch (Name[7]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+8, "ebug", 4) != 0)
break;
return AttributeCommonInfo::AT_NoDebug; // "gnu::nodebug"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "null", 4) != 0)
break;
return AttributeCommonInfo::AT_NonNull; // "gnu::nonnull"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "hrow", 4) != 0)
break;
return AttributeCommonInfo::AT_NoThrow; // "gnu::nothrow"
}
break;
case 'r': // 2 strings to match.
if (memcmp(Name.data()+6, "eg", 2) != 0)
break;
switch (Name[8]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+9, "all", 3) != 0)
break;
return AttributeCommonInfo::AT_RegCall; // "gnu::regcall"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "arm", 3) != 0)
break;
return AttributeCommonInfo::AT_Regparm; // "gnu::regparm"
}
break;
case 's': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+7, "ction", 5) != 0)
break;
return AttributeCommonInfo::AT_Section; // "gnu::section"
case 't': // 1 string to match.
if (memcmp(Name.data()+7, "dcall", 5) != 0)
break;
return AttributeCommonInfo::AT_StdCall; // "gnu::stdcall"
}
break;
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "eakref", 6) != 0)
break;
return AttributeCommonInfo::AT_WeakRef; // "gnu::weakref"
}
break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+1, "aybe_unused", 11) != 0)
break;
return AttributeCommonInfo::AT_Unused; // "maybe_unused"
}
break;
case 13: // 12 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "ssume", 5) != 0)
break;
return AttributeCommonInfo::AT_Assumption; // "clang::assume"
case 'b': // 1 string to match.
if (memcmp(Name.data()+8, "locks", 5) != 0)
break;
return AttributeCommonInfo::AT_Blocks; // "clang::blocks"
case 'l': // 1 string to match.
if (memcmp(Name.data()+8, "ikely", 5) != 0)
break;
return AttributeCommonInfo::AT_Likely; // "clang::likely"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "ascal", 5) != 0)
break;
return AttributeCommonInfo::AT_Pascal; // "clang::pascal"
}
break;
case 'g': // 8 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "astcall", 7) != 0)
break;
return AttributeCommonInfo::AT_FastCall; // "gnu::fastcall"
case 'n': // 4 strings to match.
if (Name[6] != 'o')
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "ommon", 5) != 0)
break;
return AttributeCommonInfo::AT_NoCommon; // "gnu::nocommon"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "nline", 5) != 0)
break;
return AttributeCommonInfo::AT_NoInline; // "gnu::noinline"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "ips16", 5) != 0)
break;
return AttributeCommonInfo::AT_NoMips16; // "gnu::nomips16"
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "eturn", 5) != 0)
break;
return AttributeCommonInfo::AT_NoReturn; // "gnu::noreturn"
}
break;
case 's': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+7, "ntinel", 6) != 0)
break;
return AttributeCommonInfo::AT_Sentinel; // "gnu::sentinel"
case 'y': // 1 string to match.
if (memcmp(Name.data()+7, "sv_abi", 6) != 0)
break;
return AttributeCommonInfo::AT_SysVABI; // "gnu::sysv_abi"
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+6, "hiscall", 7) != 0)
break;
return AttributeCommonInfo::AT_ThisCall; // "gnu::thiscall"
}
break;
}
break;
case 14: // 14 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 5 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "insize", 6) != 0)
break;
return AttributeCommonInfo::AT_MinSize; // "clang::minsize"
case 'n': // 2 strings to match.
if (Name[8] != 'o')
break;
switch (Name[9]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+10, "eref", 4) != 0)
break;
return AttributeCommonInfo::AT_NoDeref; // "clang::noderef"
case 'm': // 1 string to match.
if (memcmp(Name.data()+10, "erge", 4) != 0)
break;
return AttributeCommonInfo::AT_NoMerge; // "clang::nomerge"
}
break;
case 'o': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_gc", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCGC; // "clang::objc_gc"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "tnone", 5) != 0)
break;
return AttributeCommonInfo::AT_OptimizeNone; // "clang::optnone"
}
break;
}
break;
case 'g': // 9 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'd': // 2 strings to match.
if (memcmp(Name.data()+6, "ll", 2) != 0)
break;
switch (Name[8]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+9, "xport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLExport; // "gnu::dllexport"
case 'i': // 1 string to match.
if (memcmp(Name.data()+9, "mport", 5) != 0)
break;
return AttributeCommonInfo::AT_DLLImport; // "gnu::dllimport"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+6, "nterrupt", 8) != 0)
break;
return AttributeCommonInfo::AT_Interrupt; // "gnu::interrupt"
case 'l': // 1 string to match.
if (memcmp(Name.data()+6, "ong_call", 8) != 0)
break;
return AttributeCommonInfo::AT_MipsLongCall; // "gnu::long_call"
case 'm': // 3 strings to match.
switch (Name[6]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+7, "y_alias", 7) != 0)
break;
return AttributeCommonInfo::AT_MayAlias; // "gnu::may_alias"
case 'i': // 1 string to match.
if (memcmp(Name.data()+7, "cromips", 7) != 0)
break;
return AttributeCommonInfo::AT_MicroMips; // "gnu::micromips"
case 's': // 1 string to match.
if (memcmp(Name.data()+7, "_struct", 7) != 0)
break;
return AttributeCommonInfo::AT_MSStruct; // "gnu::ms_struct"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "electany", 8) != 0)
break;
return AttributeCommonInfo::AT_SelectAny; // "gnu::selectany"
case 't': // 1 string to match.
if (memcmp(Name.data()+6, "ls_model", 8) != 0)
break;
return AttributeCommonInfo::AT_TLSModel; // "gnu::tls_model"
}
break;
}
break;
case 15: // 16 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'N': // 1 string to match.
if (memcmp(Name.data()+8, "SObject", 7) != 0)
break;
return AttributeCommonInfo::AT_ObjCNSObject; // "clang::NSObject"
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "nnotate", 7) != 0)
break;
return AttributeCommonInfo::AT_Annotate; // "clang::annotate"
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "allback", 7) != 0)
break;
return AttributeCommonInfo::AT_Callback; // "clang::callback"
case 'i': // 2 strings to match.
if (Name[8] != 'b')
break;
switch (Name[9]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+10, "ction", 5) != 0)
break;
return AttributeCommonInfo::AT_IBAction; // "clang::ibaction"
case 'o': // 1 string to match.
if (memcmp(Name.data()+10, "utlet", 5) != 0)
break;
return AttributeCommonInfo::AT_IBOutlet; // "clang::iboutlet"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "oescape", 7) != 0)
break;
return AttributeCommonInfo::AT_NoEscape; // "clang::noescape"
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "nlikely", 7) != 0)
break;
return AttributeCommonInfo::AT_Unlikely; // "clang::unlikely"
}
break;
case 'g': // 9 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 2 strings to match.
switch (Name[6]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+7, "loc_size", 8) != 0)
break;
return AttributeCommonInfo::AT_AllocSize; // "gnu::alloc_size"
case 'r': // 1 string to match.
if (memcmp(Name.data()+7, "tificial", 8) != 0)
break;
return AttributeCommonInfo::AT_Artificial; // "gnu::artificial"
}
break;
case 'd': // 2 strings to match.
if (Name[6] != 'e')
break;
switch (Name[7]) {
default: break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "recated", 7) != 0)
break;
return AttributeCommonInfo::AT_Deprecated; // "gnu::deprecated"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "tructor", 7) != 0)
break;
return AttributeCommonInfo::AT_Destructor; // "gnu::destructor"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "ormat_arg", 9) != 0)
break;
return AttributeCommonInfo::AT_FormatArg; // "gnu::format_arg"
case 'g': // 1 string to match.
if (memcmp(Name.data()+6, "nu_inline", 9) != 0)
break;
return AttributeCommonInfo::AT_GNUInline; // "gnu::gnu_inline"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "ocf_check", 9) != 0)
break;
return AttributeCommonInfo::AT_AnyX86NoCfCheck; // "gnu::nocf_check"
case 's': // 1 string to match.
if (memcmp(Name.data()+6, "hort_call", 9) != 0)
break;
return AttributeCommonInfo::AT_MipsShortCall; // "gnu::short_call"
case 'v': // 1 string to match.
if (memcmp(Name.data()+6, "isibility", 9) != 0)
break;
return AttributeCommonInfo::AT_Visibility; // "gnu::visibility"
}
break;
}
break;
case 16: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 2 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+8, "lag_enum", 8) != 0)
break;
return AttributeCommonInfo::AT_FlagEnum; // "clang::flag_enum"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "wiftcall", 8) != 0)
break;
return AttributeCommonInfo::AT_SwiftCall; // "clang::swiftcall"
}
break;
case 'g': // 6 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "lloc_align", 10) != 0)
break;
return AttributeCommonInfo::AT_AllocAlign; // "gnu::alloc_align"
case 'c': // 1 string to match.
if (memcmp(Name.data()+6, "onstructor", 10) != 0)
break;
return AttributeCommonInfo::AT_Constructor; // "gnu::constructor"
case 'f': // 1 string to match.
if (memcmp(Name.data()+6, "allthrough", 10) != 0)
break;
return AttributeCommonInfo::AT_FallThrough; // "gnu::fallthrough"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "omicromips", 10) != 0)
break;
return AttributeCommonInfo::AT_NoMicroMips; // "gnu::nomicromips"
case 'v': // 1 string to match.
if (memcmp(Name.data()+6, "ector_size", 10) != 0)
break;
return AttributeCommonInfo::AT_VectorSize; // "gnu::vector_size"
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "arn_unused", 10) != 0)
break;
return AttributeCommonInfo::AT_WarnUnused; // "gnu::warn_unused"
}
break;
}
break;
case 17: // 4 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "onvergent", 9) != 0)
break;
return AttributeCommonInfo::AT_Convergent; // "clang::convergent"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "o_builtin", 9) != 0)
break;
return AttributeCommonInfo::AT_NoBuiltin; // "clang::no_builtin"
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "se_handle", 9) != 0)
break;
return AttributeCommonInfo::AT_UseHandle; // "clang::use_handle"
case 'v': // 1 string to match.
if (memcmp(Name.data()+8, "ectorcall", 9) != 0)
break;
return AttributeCommonInfo::AT_VectorCall; // "clang::vectorcall"
}
break;
case 18: // 18 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 16 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+9, "lled_once", 9) != 0)
break;
return AttributeCommonInfo::AT_CalledOnce; // "clang::called_once"
case 'f': // 1 string to match.
if (memcmp(Name.data()+9, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_CFConsumed; // "clang::cf_consumed"
}
break;
case 'e': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+9, "force_tcb", 9) != 0)
break;
return AttributeCommonInfo::AT_EnforceTCB; // "clang::enforce_tcb"
case 'x': // 1 string to match.
if (memcmp(Name.data()+9, "port_name", 9) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyExportName; // "clang::export_name"
}
break;
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "mport_name", 10) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyImportName; // "clang::import_name"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "atrix_type", 10) != 0)
break;
return AttributeCommonInfo::AT_MatrixType; // "clang::matrix_type"
case 'n': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'o': // 2 strings to match.
switch (Name[9]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+10, "sanitize", 8) != 0)
break;
return AttributeCommonInfo::AT_NoSanitize; // "clang::no_sanitize"
case 'd': // 1 string to match.
if (memcmp(Name.data()+10, "uplicate", 8) != 0)
break;
return AttributeCommonInfo::AT_NoDuplicate; // "clang::noduplicate"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_NSConsumed; // "clang::ns_consumed"
}
break;
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+13, "ridge", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridge; // "clang::objc_bridge"
case 'd': // 1 string to match.
if (memcmp(Name.data()+13, "irect", 5) != 0)
break;
return AttributeCommonInfo::AT_ObjCDirect; // "clang::objc_direct"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_consumed", 9) != 0)
break;
return AttributeCommonInfo::AT_OSConsumed; // "clang::os_consumed"
}
break;
case 's': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'w': // 1 string to match.
if (memcmp(Name.data()+9, "ift_async", 9) != 0)
break;
return AttributeCommonInfo::AT_SwiftAsync; // "clang::swift_async"
case 'y': // 1 string to match.
if (memcmp(Name.data()+9, "cl_kernel", 9) != 0)
break;
return AttributeCommonInfo::AT_SYCLKernel; // "clang::sycl_kernel"
}
break;
case 'u': // 1 string to match.
if (memcmp(Name.data()+8, "navailable", 10) != 0)
break;
return AttributeCommonInfo::AT_Unavailable; // "clang::unavailable"
case 'w': // 1 string to match.
if (memcmp(Name.data()+8, "eak_import", 10) != 0)
break;
return AttributeCommonInfo::AT_WeakImport; // "clang::weak_import"
}
break;
case 'g': // 2 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "lways_inline", 12) != 0)
break;
return AttributeCommonInfo::AT_AlwaysInline; // "gnu::always_inline"
case 'r': // 1 string to match.
if (memcmp(Name.data()+6, "eturns_twice", 12) != 0)
break;
return AttributeCommonInfo::AT_ReturnsTwice; // "gnu::returns_twice"
}
break;
}
break;
case 19: // 9 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "vailability", 11) != 0)
break;
return AttributeCommonInfo::AT_Availability; // "clang::availability"
case 'c': // 2 strings to match.
if (memcmp(Name.data()+8, "pu_", 3) != 0)
break;
switch (Name[11]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+12, "ispatch", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUDispatch; // "clang::cpu_dispatch"
case 's': // 1 string to match.
if (memcmp(Name.data()+12, "pecific", 7) != 0)
break;
return AttributeCommonInfo::AT_CPUSpecific; // "clang::cpu_specific"
}
break;
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_boxable", 10) != 0)
break;
return AttributeCommonInfo::AT_ObjCBoxable; // "clang::objc_boxable"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_local", 10) != 0)
break;
return AttributeCommonInfo::AT_OpenCLLocalAddressSpace; // "clang::opencl_local"
case 'v': // 1 string to match.
if (memcmp(Name.data()+9, "erloadable", 10) != 0)
break;
return AttributeCommonInfo::AT_Overloadable; // "clang::overloadable"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "reserve_all", 11) != 0)
break;
return AttributeCommonInfo::AT_PreserveAll; // "clang::preserve_all"
}
break;
case 'g': // 2 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+6, "ssume_aligned", 13) != 0)
break;
return AttributeCommonInfo::AT_AssumeAligned; // "gnu::assume_aligned"
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "o_split_stack", 13) != 0)
break;
return AttributeCommonInfo::AT_NoSplitStack; // "gnu::no_split_stack"
}
break;
}
break;
case 20: // 7 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 6 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "ddress_space", 12) != 0)
break;
return AttributeCommonInfo::AT_AddressSpace; // "clang::address_space"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "mport_module", 12) != 0)
break;
return AttributeCommonInfo::AT_WebAssemblyImportModule; // "clang::import_module"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "pencl_global", 12) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalAddressSpace; // "clang::opencl_global"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "reserve_most", 12) != 0)
break;
return AttributeCommonInfo::AT_PreserveMost; // "clang::preserve_most"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "wift_context", 12) != 0)
break;
return AttributeCommonInfo::AT_SwiftContext; // "clang::swift_context"
case 'x': // 1 string to match.
if (memcmp(Name.data()+8, "ray_log_args", 12) != 0)
break;
return AttributeCommonInfo::AT_XRayLogArgs; // "clang::xray_log_args"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::returns_nonnull", 19) != 0)
break;
return AttributeCommonInfo::AT_ReturnsNonNull; // "gnu::returns_nonnull"
}
break;
case 21: // 6 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "cquire_handle", 13) != 0)
break;
return AttributeCommonInfo::AT_AcquireHandle; // "clang::acquire_handle"
case 'o': // 4 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+13, "xception", 8) != 0)
break;
return AttributeCommonInfo::AT_ObjCException; // "clang::objc_exception"
case 'o': // 1 string to match.
if (memcmp(Name.data()+13, "wnership", 8) != 0)
break;
return AttributeCommonInfo::AT_ObjCOwnership; // "clang::objc_ownership"
}
break;
case 'p': // 2 strings to match.
if (memcmp(Name.data()+9, "encl_", 5) != 0)
break;
switch (Name[14]) {
default: break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+15, "eneric", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGenericAddressSpace; // "clang::opencl_generic"
case 'p': // 1 string to match.
if (memcmp(Name.data()+15, "rivate", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLPrivateAddressSpace; // "clang::opencl_private"
}
break;
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+8, "elease_handle", 13) != 0)
break;
return AttributeCommonInfo::AT_ReleaseHandle; // "clang::release_handle"
}
break;
case 22: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "ot_tail_called", 14) != 0)
break;
return AttributeCommonInfo::AT_NotTailCalled; // "clang::not_tail_called"
case 'o': // 5 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+13, "lass_stub", 9) != 0)
break;
return AttributeCommonInfo::AT_ObjCClassStub; // "clang::objc_class_stub"
case 'r': // 1 string to match.
if (memcmp(Name.data()+13, "oot_class", 9) != 0)
break;
return AttributeCommonInfo::AT_ObjCRootClass; // "clang::objc_root_class"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_constant", 13) != 0)
break;
return AttributeCommonInfo::AT_OpenCLConstantAddressSpace; // "clang::opencl_constant"
case 'w': // 2 strings to match.
if (memcmp(Name.data()+9, "nership_", 8) != 0)
break;
switch (Name[17]) {
default: break;
case 'h': // 1 string to match.
if (memcmp(Name.data()+18, "olds", 4) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "clang::ownership_holds"
case 't': // 1 string to match.
if (memcmp(Name.data()+18, "akes", 4) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "clang::ownership_takes"
}
break;
}
break;
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "ype_visibility", 14) != 0)
break;
return AttributeCommonInfo::AT_TypeVisibility; // "clang::type_visibility"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::transparent_union", 21) != 0)
break;
return AttributeCommonInfo::AT_TransparentUnion; // "gnu::transparent_union"
}
break;
case 23: // 9 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "nforce_tcb_leaf", 15) != 0)
break;
return AttributeCommonInfo::AT_EnforceTCBLeaf; // "clang::enforce_tcb_leaf"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "nternal_linkage", 15) != 0)
break;
return AttributeCommonInfo::AT_InternalLinkage; // "clang::internal_linkage"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "in_vector_width", 15) != 0)
break;
return AttributeCommonInfo::AT_MinVectorWidth; // "clang::min_vector_width"
case 'n': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+9, "on_vector_type", 14) != 0)
break;
return AttributeCommonInfo::AT_NeonVectorType; // "clang::neon_vector_type"
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_consumes_self", 14) != 0)
break;
return AttributeCommonInfo::AT_NSConsumesSelf; // "clang::ns_consumes_self"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "s_consumes_this", 15) != 0)
break;
return AttributeCommonInfo::AT_OSConsumesThis; // "clang::os_consumes_this"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "ass_object_size", 15) != 0)
break;
return AttributeCommonInfo::AT_PassObjectSize; // "clang::pass_object_size"
}
break;
case 'g': // 2 strings to match.
if (memcmp(Name.data()+1, "nu::", 4) != 0)
break;
switch (Name[5]) {
default: break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+6, "o_sanitize_thread", 17) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "gnu::no_sanitize_thread"
case 'w': // 1 string to match.
if (memcmp(Name.data()+6, "arn_unused_result", 17) != 0)
break;
return AttributeCommonInfo::AT_WarnUnusedResult; // "gnu::warn_unused_result"
}
break;
}
break;
case 24: // 3 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 2 strings to match.
if (memcmp(Name.data()+1, "lang::o", 7) != 0)
break;
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_runtime_name", 15) != 0)
break;
return AttributeCommonInfo::AT_ObjCRuntimeName; // "clang::objc_runtime_name"
case 'w': // 1 string to match.
if (memcmp(Name.data()+9, "nership_returns", 15) != 0)
break;
return AttributeCommonInfo::AT_Ownership; // "clang::ownership_returns"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_sanitize_address", 23) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "gnu::no_sanitize_address"
}
break;
case 25: // 11 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "arch64_vector_pcs", 17) != 0)
break;
return AttributeCommonInfo::AT_AArch64VectorPcs; // "clang::aarch64_vector_pcs"
case 'd': // 1 string to match.
if (memcmp(Name.data()+8, "isable_tail_calls", 17) != 0)
break;
return AttributeCommonInfo::AT_DisableTailCalls; // "clang::disable_tail_calls"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "num_extensibility", 17) != 0)
break;
return AttributeCommonInfo::AT_EnumExtensibility; // "clang::enum_extensibility"
case 'i': // 1 string to match.
if (memcmp(Name.data()+8, "boutletcollection", 17) != 0)
break;
return AttributeCommonInfo::AT_IBOutletCollection; // "clang::iboutletcollection"
case 'm': // 1 string to match.
if (memcmp(Name.data()+8, "ig_server_routine", 17) != 0)
break;
return AttributeCommonInfo::AT_MIGServerRoutine; // "clang::mig_server_routine"
case 'n': // 2 strings to match.
if (memcmp(Name.data()+8, "o_s", 3) != 0)
break;
switch (Name[11]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+12, "nitize_memory", 13) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "clang::no_sanitize_memory"
case 't': // 1 string to match.
if (memcmp(Name.data()+12, "ack_protector", 13) != 0)
break;
return AttributeCommonInfo::AT_NoStackProtector; // "clang::no_stack_protector"
}
break;
case 'o': // 3 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+13, "ethod_family", 12) != 0)
break;
return AttributeCommonInfo::AT_ObjCMethodFamily; // "clang::objc_method_family"
case 'n': // 1 string to match.
if (memcmp(Name.data()+13, "onlazy_class", 12) != 0)
break;
return AttributeCommonInfo::AT_ObjCNonLazyClass; // "clang::objc_nonlazy_class"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_global_host", 16) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalHostAddressSpace; // "clang::opencl_global_host"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "wift_error_result", 17) != 0)
break;
return AttributeCommonInfo::AT_SwiftErrorResult; // "clang::swift_error_result"
}
break;
case 26: // 9 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 3 strings to match.
if (memcmp(Name.data()+8, "f_", 2) != 0)
break;
switch (Name[10]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+11, "udited_transfer", 15) != 0)
break;
return AttributeCommonInfo::AT_CFAuditedTransfer; // "clang::cf_audited_transfer"
case 'r': // 1 string to match.
if (memcmp(Name.data()+11, "eturns_retained", 15) != 0)
break;
return AttributeCommonInfo::AT_CFReturnsRetained; // "clang::cf_returns_retained"
case 'u': // 1 string to match.
if (memcmp(Name.data()+11, "nknown_transfer", 15) != 0)
break;
return AttributeCommonInfo::AT_CFUnknownTransfer; // "clang::cf_unknown_transfer"
}
break;
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "s_returns_retained", 18) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsRetained; // "clang::ns_returns_retained"
case 'o': // 5 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 4 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+13, "ridge_", 6) != 0)
break;
switch (Name[19]) {
default: break;
case 'm': // 1 string to match.
if (memcmp(Name.data()+20, "utable", 6) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridgeMutable; // "clang::objc_bridge_mutable"
case 'r': // 1 string to match.
if (memcmp(Name.data()+20, "elated", 6) != 0)
break;
return AttributeCommonInfo::AT_ObjCBridgeRelated; // "clang::objc_bridge_related"
}
break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+13, "irect_members", 13) != 0)
break;
return AttributeCommonInfo::AT_ObjCDirectMembers; // "clang::objc_direct_members"
case 'r': // 1 string to match.
if (memcmp(Name.data()+13, "equires_super", 13) != 0)
break;
return AttributeCommonInfo::AT_ObjCRequiresSuper; // "clang::objc_requires_super"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_returns_retained", 17) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetained; // "clang::os_returns_retained"
}
break;
}
break;
case 27: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+8, "oader_uninitialized", 19) != 0)
break;
return AttributeCommonInfo::AT_LoaderUninitialized; // "clang::loader_uninitialized"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "eon_polyvector_type", 19) != 0)
break;
return AttributeCommonInfo::AT_NeonPolyVectorType; // "clang::neon_polyvector_type"
case 'o': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'b': // 1 string to match.
if (memcmp(Name.data()+9, "jc_runtime_visible", 18) != 0)
break;
return AttributeCommonInfo::AT_ObjCRuntimeVisible; // "clang::objc_runtime_visible"
case 'p': // 1 string to match.
if (memcmp(Name.data()+9, "encl_global_device", 18) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalDeviceAddressSpace; // "clang::opencl_global_device"
}
break;
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_instrument_function", 26) != 0)
break;
return AttributeCommonInfo::AT_NoInstrumentFunction; // "gnu::no_instrument_function"
}
break;
case 28: // 8 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 7 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'l': // 1 string to match.
if (memcmp(Name.data()+8, "to_visibility_public", 20) != 0)
break;
return AttributeCommonInfo::AT_LTOVisibilityPublic; // "clang::lto_visibility_public"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_precise_lifetime", 20) != 0)
break;
return AttributeCommonInfo::AT_ObjCPreciseLifetime; // "clang::objc_precise_lifetime"
case 'p': // 2 strings to match.
switch (Name[8]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+9, "inter_with_type_tag", 19) != 0)
break;
return AttributeCommonInfo::AT_ArgumentWithTypeTag; // "clang::pointer_with_type_tag"
case 'r': // 1 string to match.
if (memcmp(Name.data()+9, "eserve_access_index", 19) != 0)
break;
return AttributeCommonInfo::AT_BPFPreserveAccessIndex; // "clang::preserve_access_index"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "wift_indirect_result", 20) != 0)
break;
return AttributeCommonInfo::AT_SwiftIndirectResult; // "clang::swift_indirect_result"
case 't': // 1 string to match.
if (memcmp(Name.data()+8, "ype_tag_for_datatype", 20) != 0)
break;
return AttributeCommonInfo::AT_TypeTagForDatatype; // "clang::type_tag_for_datatype"
case 'x': // 1 string to match.
if (memcmp(Name.data()+8, "ray_never_instrument", 20) != 0)
break;
return AttributeCommonInfo::AT_XRayInstrument; // "clang::xray_never_instrument"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::force_align_arg_pointer", 27) != 0)
break;
return AttributeCommonInfo::AT_X86ForceAlignArgPointer; // "gnu::force_align_arg_pointer"
}
break;
case 29: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+8, "rgument_with_type_tag", 21) != 0)
break;
return AttributeCommonInfo::AT_ArgumentWithTypeTag; // "clang::argument_with_type_tag"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "xternal_source_symbol", 21) != 0)
break;
return AttributeCommonInfo::AT_ExternalSourceSymbol; // "clang::external_source_symbol"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_independent_class", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCIndependentClass; // "clang::objc_independent_class"
case 'x': // 1 string to match.
if (memcmp(Name.data()+8, "ray_always_instrument", 21) != 0)
break;
return AttributeCommonInfo::AT_XRayInstrument; // "clang::xray_always_instrument"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::patchable_function_entry", 28) != 0)
break;
return AttributeCommonInfo::AT_PatchableFunctionEntry; // "gnu::patchable_function_entry"
}
break;
case 30: // 5 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 4 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "f_returns_not_retained", 22) != 0)
break;
return AttributeCommonInfo::AT_CFReturnsNotRetained; // "clang::cf_returns_not_retained"
case 'n': // 2 strings to match.
if (memcmp(Name.data()+8, "s_returns_", 10) != 0)
break;
switch (Name[18]) {
default: break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+19, "utoreleased", 11) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsAutoreleased; // "clang::ns_returns_autoreleased"
case 'n': // 1 string to match.
if (memcmp(Name.data()+19, "ot_retained", 11) != 0)
break;
return AttributeCommonInfo::AT_NSReturnsNotRetained; // "clang::ns_returns_not_retained"
}
break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "s_returns_not_retained", 22) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsNotRetained; // "clang::os_returns_not_retained"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_caller_saved_registers", 29) != 0)
break;
return AttributeCommonInfo::AT_AnyX86NoCallerSavedRegisters; // "gnu::no_caller_saved_registers"
}
break;
case 31: // 4 strings to match.
switch (Name[0]) {
default: break;
case 'c': // 3 strings to match.
if (memcmp(Name.data()+1, "lang::", 6) != 0)
break;
switch (Name[7]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+8, "fi_canonical_jump_table", 23) != 0)
break;
return AttributeCommonInfo::AT_CFICanonicalJumpTable; // "clang::cfi_canonical_jump_table"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_externally_retained", 23) != 0)
break;
return AttributeCommonInfo::AT_ObjCExternallyRetained; // "clang::objc_externally_retained"
case 'p': // 1 string to match.
if (memcmp(Name.data()+8, "ass_dynamic_object_size", 23) != 0)
break;
return AttributeCommonInfo::AT_PassObjectSize; // "clang::pass_dynamic_object_size"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "nu::no_address_safety_analysis", 30) != 0)
break;
return AttributeCommonInfo::AT_NoSanitizeSpecific; // "gnu::no_address_safety_analysis"
}
break;
case 32: // 3 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+8, "_clang_arm_builtin_alias", 24) != 0)
break;
return AttributeCommonInfo::AT_ArmBuiltinAlias; // "clang::__clang_arm_builtin_alias"
case 'n': // 1 string to match.
if (memcmp(Name.data()+8, "o_thread_safety_analysis", 24) != 0)
break;
return AttributeCommonInfo::AT_NoThreadSafetyAnalysis; // "clang::no_thread_safety_analysis"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_non_runtime_protocol", 24) != 0)
break;
return AttributeCommonInfo::AT_ObjCNonRuntimeProtocol; // "clang::objc_non_runtime_protocol"
}
break;
case 33: // 2 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_returns_inner_pointer", 25) != 0)
break;
return AttributeCommonInfo::AT_ObjCReturnsInnerPointer; // "clang::objc_returns_inner_pointer"
case 's': // 1 string to match.
if (memcmp(Name.data()+8, "peculative_load_hardening", 25) != 0)
break;
return AttributeCommonInfo::AT_SpeculativeLoadHardening; // "clang::speculative_load_hardening"
}
break;
case 34: // 3 strings to match.
if (memcmp(Name.data()+0, "clang::o", 8) != 0)
break;
switch (Name[8]) {
default: break;
case 'b': // 2 strings to match.
if (memcmp(Name.data()+9, "jc_", 3) != 0)
break;
switch (Name[12]) {
default: break;
case 'd': // 1 string to match.
if (memcmp(Name.data()+13, "esignated_initializer", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCDesignatedInitializer; // "clang::objc_designated_initializer"
case 's': // 1 string to match.
if (memcmp(Name.data()+13, "ubclassing_restricted", 21) != 0)
break;
return AttributeCommonInfo::AT_ObjCSubclassingRestricted; // "clang::objc_subclassing_restricted"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+9, "_returns_retained_on_zero", 25) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetainedOnZero; // "clang::os_returns_retained_on_zero"
}
break;
case 36: // 1 string to match.
if (memcmp(Name.data()+0, "clang::no_speculative_load_hardening", 36) != 0)
break;
return AttributeCommonInfo::AT_NoSpeculativeLoadHardening; // "clang::no_speculative_load_hardening"
case 38: // 1 string to match.
if (memcmp(Name.data()+0, "clang::os_returns_retained_on_non_zero", 38) != 0)
break;
return AttributeCommonInfo::AT_OSReturnsRetainedOnNonZero; // "clang::os_returns_retained_on_non_zero"
case 41: // 1 string to match.
if (memcmp(Name.data()+0, "clang::objc_requires_property_definitions", 41) != 0)
break;
return AttributeCommonInfo::AT_ObjCRequiresPropertyDefs; // "clang::objc_requires_property_definitions"
case 42: // 3 strings to match.
if (memcmp(Name.data()+0, "clang::", 7) != 0)
break;
switch (Name[7]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+8, "_clang_arm_mve_strict_polymorphism", 34) != 0)
break;
return AttributeCommonInfo::AT_ArmMveStrictPolymorphism; // "clang::__clang_arm_mve_strict_polymorphism"
case 'e': // 1 string to match.
if (memcmp(Name.data()+8, "xclude_from_explicit_instantiation", 34) != 0)
break;
return AttributeCommonInfo::AT_ExcludeFromExplicitInstantiation; // "clang::exclude_from_explicit_instantiation"
case 'o': // 1 string to match.
if (memcmp(Name.data()+8, "bjc_arc_weak_reference_unavailable", 34) != 0)
break;
return AttributeCommonInfo::AT_ArcWeakrefUnavailable; // "clang::objc_arc_weak_reference_unavailable"
}
break;
case 53: // 1 string to match.
if (memcmp(Name.data()+0, "clang::objc_protocol_requires_explicit_implementation", 53) != 0)
break;
return AttributeCommonInfo::AT_ObjCExplicitProtocolImpl; // "clang::objc_protocol_requires_explicit_implementation"
}
} else if (AttributeCommonInfo::AS_Keyword == Syntax || AttributeCommonInfo::AS_ContextSensitiveKeyword == Syntax) {
switch (Name.size()) {
default: break;
case 5: // 2 strings to match.
switch (Name[0]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+1, "_w64", 4) != 0)
break;
return AttributeCommonInfo::IgnoredAttribute; // "__w64"
case 'l': // 1 string to match.
if (memcmp(Name.data()+1, "ocal", 4) != 0)
break;
return AttributeCommonInfo::AT_OpenCLLocalAddressSpace; // "local"
}
break;
case 6: // 5 strings to match.
switch (Name[0]) {
default: break;
case '_': // 3 strings to match.
switch (Name[1]) {
default: break;
case '_': // 2 strings to match.
switch (Name[2]) {
default: break;
case 's': // 1 string to match.
if (memcmp(Name.data()+3, "ptr", 3) != 0)
break;
return AttributeCommonInfo::AT_SPtr; // "__sptr"
case 'u': // 1 string to match.
if (memcmp(Name.data()+3, "ptr", 3) != 0)
break;
return AttributeCommonInfo::AT_UPtr; // "__uptr"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+2, "decl", 4) != 0)
break;
return AttributeCommonInfo::AT_CDecl; // "_cdecl"
}
break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "lobal", 5) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalAddressSpace; // "global"
case 'k': // 1 string to match.
if (memcmp(Name.data()+1, "ernel", 5) != 0)
break;
return AttributeCommonInfo::AT_OpenCLKernel; // "kernel"
}
break;
case 7: // 8 strings to match.
switch (Name[0]) {
default: break;
case '_': // 5 strings to match.
switch (Name[1]) {
default: break;
case '_': // 4 strings to match.
switch (Name[2]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+3, "decl", 4) != 0)
break;
return AttributeCommonInfo::AT_CDecl; // "__cdecl"
case 'l': // 1 string to match.
if (memcmp(Name.data()+3, "ocal", 4) != 0)
break;
return AttributeCommonInfo::AT_OpenCLLocalAddressSpace; // "__local"
case 'p': // 2 strings to match.
if (memcmp(Name.data()+3, "tr", 2) != 0)
break;
switch (Name[5]) {
default: break;
case '3': // 1 string to match.
if (Name[6] != '2')
break;
return AttributeCommonInfo::AT_Ptr32; // "__ptr32"
case '6': // 1 string to match.
if (Name[6] != '4')
break;
return AttributeCommonInfo::AT_Ptr64; // "__ptr64"
}
break;
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+2, "ascal", 5) != 0)
break;
return AttributeCommonInfo::AT_Pascal; // "_pascal"
}
break;
case 'a': // 1 string to match.
if (memcmp(Name.data()+1, "lignas", 6) != 0)
break;
return AttributeCommonInfo::AT_Aligned; // "alignas"
case 'g': // 1 string to match.
if (memcmp(Name.data()+1, "eneric", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGenericAddressSpace; // "generic"
case 'p': // 1 string to match.
if (memcmp(Name.data()+1, "rivate", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLPrivateAddressSpace; // "private"
}
break;
case 8: // 8 strings to match.
switch (Name[0]) {
default: break;
case '_': // 7 strings to match.
switch (Name[1]) {
default: break;
case 'A': // 1 string to match.
if (memcmp(Name.data()+2, "lignas", 6) != 0)
break;
return AttributeCommonInfo::AT_Aligned; // "_Alignas"
case 'N': // 1 string to match.
if (memcmp(Name.data()+2, "onnull", 6) != 0)
break;
return AttributeCommonInfo::AT_TypeNonNull; // "_Nonnull"
case '_': // 4 strings to match.
switch (Name[2]) {
default: break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+3, "lobal", 5) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGlobalAddressSpace; // "__global"
case 'k': // 2 strings to match.
switch (Name[3]) {
default: break;
case 'e': // 1 string to match.
if (memcmp(Name.data()+4, "rnel", 4) != 0)
break;
return AttributeCommonInfo::AT_OpenCLKernel; // "__kernel"
case 'i': // 1 string to match.
if (memcmp(Name.data()+4, "ndof", 4) != 0)
break;
return AttributeCommonInfo::AT_ObjCKindOf; // "__kindof"
}
break;
case 'p': // 1 string to match.
if (memcmp(Name.data()+3, "ascal", 5) != 0)
break;
return AttributeCommonInfo::AT_Pascal; // "__pascal"
}
break;
case 's': // 1 string to match.
if (memcmp(Name.data()+2, "tdcall", 6) != 0)
break;
return AttributeCommonInfo::AT_StdCall; // "_stdcall"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "onstant", 7) != 0)
break;
return AttributeCommonInfo::AT_OpenCLConstantAddressSpace; // "constant"
}
break;
case 9: // 9 strings to match.
switch (Name[0]) {
default: break;
case '_': // 7 strings to match.
switch (Name[1]) {
default: break;
case 'N': // 1 string to match.
if (memcmp(Name.data()+2, "ullable", 7) != 0)
break;
return AttributeCommonInfo::AT_TypeNullable; // "_Nullable"
case '_': // 4 strings to match.
switch (Name[2]) {
default: break;
case 'g': // 1 string to match.
if (memcmp(Name.data()+3, "eneric", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLGenericAddressSpace; // "__generic"
case 'p': // 1 string to match.
if (memcmp(Name.data()+3, "rivate", 6) != 0)
break;
return AttributeCommonInfo::AT_OpenCLPrivateAddressSpace; // "__private"
case 'r': // 1 string to match.
if (memcmp(Name.data()+3, "egcall", 6) != 0)
break;
return AttributeCommonInfo::AT_RegCall; // "__regcall"
case 's': // 1 string to match.
if (memcmp(Name.data()+3, "tdcall", 6) != 0)
break;
return AttributeCommonInfo::AT_StdCall; // "__stdcall"
}
break;
case 'f': // 1 string to match.
if (memcmp(Name.data()+2, "astcall", 7) != 0)
break;
return AttributeCommonInfo::AT_FastCall; // "_fastcall"
case 't': // 1 string to match.
if (memcmp(Name.data()+2, "hiscall", 7) != 0)
break;
return AttributeCommonInfo::AT_ThisCall; // "_thiscall"
}
break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+1, "onstinit", 8) != 0)
break;
return AttributeCommonInfo::AT_ConstInit; // "constinit"
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "ead_only", 8) != 0)
break;
return AttributeCommonInfo::AT_OpenCLAccess; // "read_only"
}
break;
case 10: // 5 strings to match.
switch (Name[0]) {
default: break;
case '_': // 3 strings to match.
if (Name[1] != '_')
break;
switch (Name[2]) {
default: break;
case 'c': // 1 string to match.
if (memcmp(Name.data()+3, "onstant", 7) != 0)
break;
return AttributeCommonInfo::AT_OpenCLConstantAddressSpace; // "__constant"
case 'f': // 1 string to match.
if (memcmp(Name.data()+3, "astcall", 7) != 0)
break;
return AttributeCommonInfo::AT_FastCall; // "__fastcall"
case 't': // 1 string to match.
if (memcmp(Name.data()+3, "hiscall", 7) != 0)
break;
return AttributeCommonInfo::AT_ThisCall; // "__thiscall"
}
break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+1, "ead_write", 9) != 0)
break;
return AttributeCommonInfo::AT_OpenCLAccess; // "read_write"
case 'w': // 1 string to match.
if (memcmp(Name.data()+1, "rite_only", 9) != 0)
break;
return AttributeCommonInfo::AT_OpenCLAccess; // "write_only"
}
break;
case 11: // 2 strings to match.
if (Name[0] != '_')
break;
switch (Name[1]) {
default: break;
case '_': // 1 string to match.
if (memcmp(Name.data()+2, "read_only", 9) != 0)
break;
return AttributeCommonInfo::AT_OpenCLAccess; // "__read_only"
case 'v': // 1 string to match.
if (memcmp(Name.data()+2, "ectorcall", 9) != 0)
break;
return AttributeCommonInfo::AT_VectorCall; // "_vectorcall"
}
break;
case 12: // 3 strings to match.
if (memcmp(Name.data()+0, "__", 2) != 0)
break;
switch (Name[2]) {
default: break;
case 'r': // 1 string to match.
if (memcmp(Name.data()+3, "ead_write", 9) != 0)
break;
return AttributeCommonInfo::AT_OpenCLAccess; // "__read_write"
case 'v': // 1 string to match.
if (memcmp(Name.data()+3, "ectorcall", 9) != 0)
break;
return AttributeCommonInfo::AT_VectorCall; // "__vectorcall"
case 'w': // 1 string to match.
if (memcmp(Name.data()+3, "rite_only", 9) != 0)
break;
return AttributeCommonInfo::AT_OpenCLAccess; // "__write_only"
}
break;
case 13: // 1 string to match.
if (memcmp(Name.data()+0, "__forceinline", 13) != 0)
break;
return AttributeCommonInfo::AT_AlwaysInline; // "__forceinline"
case 16: // 1 string to match.
if (memcmp(Name.data()+0, "_Nullable_result", 16) != 0)
break;
return AttributeCommonInfo::AT_TypeNullableResult; // "_Nullable_result"
case 17: // 1 string to match.
if (memcmp(Name.data()+0, "_Null_unspecified", 17) != 0)
break;
return AttributeCommonInfo::AT_TypeNullUnspecified; // "_Null_unspecified"
case 19: // 1 string to match.
if (memcmp(Name.data()+0, "__unsafe_unretained", 19) != 0)
break;
return AttributeCommonInfo::AT_ObjCInertUnsafeUnretained; // "__unsafe_unretained"
case 20: // 1 string to match.
if (memcmp(Name.data()+0, "__single_inheritance", 20) != 0)
break;
return AttributeCommonInfo::AT_MSInheritance; // "__single_inheritance"
case 21: // 1 string to match.
if (memcmp(Name.data()+0, "__virtual_inheritance", 21) != 0)
break;
return AttributeCommonInfo::AT_MSInheritance; // "__virtual_inheritance"
case 22: // 1 string to match.
if (memcmp(Name.data()+0, "__multiple_inheritance", 22) != 0)
break;
return AttributeCommonInfo::AT_MSInheritance; // "__multiple_inheritance"
case 25: // 1 string to match.
if (memcmp(Name.data()+0, "__unspecified_inheritance", 25) != 0)
break;
return AttributeCommonInfo::AT_MSInheritance; // "__unspecified_inheritance"
}
} else if (AttributeCommonInfo::AS_Pragma == Syntax) {
switch (Name.size()) {
default: break;
case 4: // 1 string to match.
if (memcmp(Name.data()+0, "loop", 4) != 0)
break;
return AttributeCommonInfo::AT_LoopHint; // "loop"
case 6: // 1 string to match.
if (memcmp(Name.data()+0, "unroll", 6) != 0)
break;
return AttributeCommonInfo::AT_LoopHint; // "unroll"
case 8: // 1 string to match.
if (memcmp(Name.data()+0, "nounroll", 8) != 0)
break;
return AttributeCommonInfo::AT_LoopHint; // "nounroll"
case 14: // 1 string to match.
if (memcmp(Name.data()+0, "unroll_and_jam", 14) != 0)
break;
return AttributeCommonInfo::AT_LoopHint; // "unroll_and_jam"
case 16: // 1 string to match.
if (memcmp(Name.data()+0, "nounroll_and_jam", 16) != 0)
break;
return AttributeCommonInfo::AT_LoopHint; // "nounroll_and_jam"
}
}
return AttributeCommonInfo::UnknownAttribute;
}