blob: 524e2d3c43f4501ca09212b5bef2164572352b38 [file] [log] [blame]
/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the QtXmlPatterns module of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:LGPL$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 3 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL3 included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 3 requirements
** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 2.0 or (at your option) the GNU General
** Public license version 3 or any later version approved by the KDE Free
** Qt Foundation. The licenses are as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-2.0.html and
** https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/
/* C++ code produced by gperf version 3.1 */
/* Command-line: gperf TokenLookup.gperf */
/* Computed positions: -k'1,3,$' */
#if !((' ' == 32) && ('!' == 33) && ('"' == 34) && ('#' == 35) \
&& ('%' == 37) && ('&' == 38) && ('\'' == 39) && ('(' == 40) \
&& (')' == 41) && ('*' == 42) && ('+' == 43) && (',' == 44) \
&& ('-' == 45) && ('.' == 46) && ('/' == 47) && ('0' == 48) \
&& ('1' == 49) && ('2' == 50) && ('3' == 51) && ('4' == 52) \
&& ('5' == 53) && ('6' == 54) && ('7' == 55) && ('8' == 56) \
&& ('9' == 57) && (':' == 58) && (';' == 59) && ('<' == 60) \
&& ('=' == 61) && ('>' == 62) && ('?' == 63) && ('A' == 65) \
&& ('B' == 66) && ('C' == 67) && ('D' == 68) && ('E' == 69) \
&& ('F' == 70) && ('G' == 71) && ('H' == 72) && ('I' == 73) \
&& ('J' == 74) && ('K' == 75) && ('L' == 76) && ('M' == 77) \
&& ('N' == 78) && ('O' == 79) && ('P' == 80) && ('Q' == 81) \
&& ('R' == 82) && ('S' == 83) && ('T' == 84) && ('U' == 85) \
&& ('V' == 86) && ('W' == 87) && ('X' == 88) && ('Y' == 89) \
&& ('Z' == 90) && ('[' == 91) && ('\\' == 92) && (']' == 93) \
&& ('^' == 94) && ('_' == 95) && ('a' == 97) && ('b' == 98) \
&& ('c' == 99) && ('d' == 100) && ('e' == 101) && ('f' == 102) \
&& ('g' == 103) && ('h' == 104) && ('i' == 105) && ('j' == 106) \
&& ('k' == 107) && ('l' == 108) && ('m' == 109) && ('n' == 110) \
&& ('o' == 111) && ('p' == 112) && ('q' == 113) && ('r' == 114) \
&& ('s' == 115) && ('t' == 116) && ('u' == 117) && ('v' == 118) \
&& ('w' == 119) && ('x' == 120) && ('y' == 121) && ('z' == 122) \
&& ('{' == 123) && ('|' == 124) && ('}' == 125) && ('~' == 126))
/* The character set is not based on ISO-646. */
#error "gperf generated tables don't work with this execution character set. Please report a bug to <bug-gperf@gnu.org>."
#endif
#line 105 "TokenLookup.gperf"
QT_BEGIN_NAMESPACE
namespace QPatternist
{
#line 99 "TokenLookup.gperf"
struct TokenMap
{
const char *name;
const Tokenizer::TokenType token;
}
/* The strings below are in UTF-16 encoding. Subsequently, each ASCII
* character is stored as the ASCII character, followed by a null byte.
* Sorted alphabetically. */;
/* maximum key range = 228, duplicates = 0 */
class TokenLookup
{
private:
static inline unsigned int hash (const char *str, unsigned int len);
public:
static const struct TokenMap *value (const char *str, unsigned int len);
};
inline unsigned int
TokenLookup::hash (const char *str, unsigned int len)
{
static const unsigned char asso_values[] =
{
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 25, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 0, 2, 5,
25, 0, 20, 20, 35, 85, 230, 230, 40, 110,
25, 65, 80, 0, 60, 5, 10, 0, 55, 5,
20, 0, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
230, 230, 230, 230, 230, 230
};
unsigned int hval = len;
switch (hval)
{
default:
hval += asso_values[static_cast<unsigned char>(str[2])];
Q_FALLTHROUGH();
case 2:
case 1:
hval += asso_values[static_cast<unsigned char>(str[0])];
break;
}
return hval + asso_values[static_cast<unsigned char>(str[len - 1])];
}
const struct TokenMap *
TokenLookup::value (const char *str, unsigned int len)
{
enum
{
TOTAL_KEYWORDS = 99,
MIN_WORD_LENGTH = 2,
MAX_WORD_LENGTH = 22,
MIN_HASH_VALUE = 2,
MAX_HASH_VALUE = 229
};
static const struct TokenMap wordlist[] =
{
{"",T_ERROR}, {"",T_ERROR},
#line 150 "TokenLookup.gperf"
{"eq", T_EQ},
{"",T_ERROR},
#line 128 "TokenLookup.gperf"
{"by", T_BY},
#line 151 "TokenLookup.gperf"
{"every", T_EVERY},
{"",T_ERROR},
#line 121 "TokenLookup.gperf"
{"as", T_AS},
{"",T_ERROR},
#line 146 "TokenLookup.gperf"
{"else", T_ELSE},
#line 215 "TokenLookup.gperf"
{"where", T_WHERE},
#line 202 "TokenLookup.gperf"
{"stable", T_STABLE},
#line 124 "TokenLookup.gperf"
{"at", T_AT},
{"",T_ERROR},
#line 129 "TokenLookup.gperf"
{"case", T_CASE},
{"",T_ERROR},
#line 127 "TokenLookup.gperf"
{"boundary-space", T_BOUNDARY_SPACE},
#line 145 "TokenLookup.gperf"
{"element", T_ELEMENT},
#line 130 "TokenLookup.gperf"
{"castable", T_CASTABLE},
#line 125 "TokenLookup.gperf"
{"attribute", T_ATTRIBUTE},
{"",T_ERROR},
#line 152 "TokenLookup.gperf"
{"except", T_EXCEPT},
#line 159 "TokenLookup.gperf"
{"ge", T_GE},
{"",T_ERROR},
#line 131 "TokenLookup.gperf"
{"cast", T_CAST},
#line 208 "TokenLookup.gperf"
{"treat", T_TREAT},
#line 216 "TokenLookup.gperf"
{"xquery", T_XQUERY},
#line 179 "TokenLookup.gperf"
{"ne", T_NE},
{"",T_ERROR},
#line 196 "TokenLookup.gperf"
{"satisfies", T_SATISFIES},
{"",T_ERROR}, {"",T_ERROR},
#line 161 "TokenLookup.gperf"
{"gt", T_GT},
#line 149 "TokenLookup.gperf"
{"encoding", T_ENCODING},
#line 122 "TokenLookup.gperf"
{"ascending", T_ASCENDING},
{"",T_ERROR},
#line 123 "TokenLookup.gperf"
{"assign", T_ASSIGN},
#line 137 "TokenLookup.gperf"
{"declare", T_DECLARE},
#line 160 "TokenLookup.gperf"
{"greatest", T_GREATEST},
#line 206 "TokenLookup.gperf"
{"then", T_THEN},
{"",T_ERROR},
#line 119 "TokenLookup.gperf"
{"ancestor-or-self", T_ANCESTOR_OR_SELF},
#line 173 "TokenLookup.gperf"
{"le", T_LE},
#line 144 "TokenLookup.gperf"
{"document-node", T_DOCUMENT_NODE},
#line 205 "TokenLookup.gperf"
{"text", T_TEXT},
{"",T_ERROR},
#line 199 "TokenLookup.gperf"
{"schema", T_SCHEMA},
{"",T_ERROR},
#line 143 "TokenLookup.gperf"
{"document", T_DOCUMENT},
{"",T_ERROR},
#line 139 "TokenLookup.gperf"
{"descendant", T_DESCENDANT},
{"",T_ERROR},
#line 175 "TokenLookup.gperf"
{"lt", T_LT},
#line 120 "TokenLookup.gperf"
{"and", T_AND},
#line 180 "TokenLookup.gperf"
{"node", T_NODE},
#line 172 "TokenLookup.gperf"
{"least", T_LEAST},
#line 197 "TokenLookup.gperf"
{"schema-attribute", T_SCHEMA_ATTRIBUTE},
{"",T_ERROR},
#line 153 "TokenLookup.gperf"
{"external", T_EXTERNAL},
{"",T_ERROR},
#line 141 "TokenLookup.gperf"
{"descending", T_DESCENDING},
#line 182 "TokenLookup.gperf"
{"no-preserve", T_NO_PRESERVE},
#line 138 "TokenLookup.gperf"
{"default", T_DEFAULT},
#line 174 "TokenLookup.gperf"
{"let", T_LET},
#line 198 "TokenLookup.gperf"
{"schema-element", T_SCHEMA_ELEMENT},
{"",T_ERROR}, {"",T_ERROR},
#line 135 "TokenLookup.gperf"
{"construction", T_CONSTRUCTION},
#line 140 "TokenLookup.gperf"
{"descendant-or-self", T_DESCENDANT_OR_SELF},
#line 200 "TokenLookup.gperf"
{"self", T_SELF},
#line 181 "TokenLookup.gperf"
{"no-inherit", T_NO_INHERIT},
{"",T_ERROR},
#line 156 "TokenLookup.gperf"
{"follows", T_FOLLOWS},
#line 118 "TokenLookup.gperf"
{"ancestor", T_ANCESTOR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
#line 207 "TokenLookup.gperf"
{"to", T_TO},
#line 158 "TokenLookup.gperf"
{"function", T_FUNCTION},
#line 133 "TokenLookup.gperf"
{"collation", T_COLLATION},
{"",T_ERROR},
#line 203 "TokenLookup.gperf"
{"strict", T_STRICT},
{"",T_ERROR},
#line 171 "TokenLookup.gperf"
{"lax", T_LAX},
{"",T_ERROR},
#line 147 "TokenLookup.gperf"
{"empty", T_EMPTY},
{"",T_ERROR},
#line 183 "TokenLookup.gperf"
{"of", T_OF},
#line 193 "TokenLookup.gperf"
{"preserve", T_PRESERVE},
#line 154 "TokenLookup.gperf"
{"following", T_FOLLOWING},
{"",T_ERROR}, {"",T_ERROR},
#line 169 "TokenLookup.gperf"
{"is", T_IS},
#line 190 "TokenLookup.gperf"
{"precedes", T_PRECEDES},
#line 148 "TokenLookup.gperf"
{"empty-sequence", T_EMPTY_SEQUENCE},
{"",T_ERROR}, {"",T_ERROR},
#line 155 "TokenLookup.gperf"
{"following-sibling", T_FOLLOWING_SIBLING},
#line 167 "TokenLookup.gperf"
{"instance", T_INSTANCE},
#line 211 "TokenLookup.gperf"
{"unordered", T_UNORDERED},
#line 126 "TokenLookup.gperf"
{"base-uri", T_BASEURI},
#line 195 "TokenLookup.gperf"
{"return", T_RETURN},
{"",T_ERROR},
#line 212 "TokenLookup.gperf"
{"validate", T_VALIDATE},
{"",T_ERROR},
#line 136 "TokenLookup.gperf"
{"copy-namespaces", T_COPY_NAMESPACES},
#line 184 "TokenLookup.gperf"
{"option", T_OPTION},
#line 163 "TokenLookup.gperf"
{"if", T_IF},
{"",T_ERROR},
#line 191 "TokenLookup.gperf"
{"preceding", T_PRECEDING},
{"",T_ERROR}, {"",T_ERROR},
#line 166 "TokenLookup.gperf"
{"in", T_IN},
{"",T_ERROR},
#line 168 "TokenLookup.gperf"
{"intersect", T_INTERSECT},
#line 210 "TokenLookup.gperf"
{"union", T_UNION},
{"",T_ERROR},
#line 192 "TokenLookup.gperf"
{"preceding-sibling", T_PRECEDING_SIBLING},
#line 186 "TokenLookup.gperf"
{"ordering", T_ORDERING},
#line 201 "TokenLookup.gperf"
{"some", T_SOME},
#line 132 "TokenLookup.gperf"
{"child", T_CHILD},
{"",T_ERROR},
#line 185 "TokenLookup.gperf"
{"ordered", T_ORDERED},
#line 213 "TokenLookup.gperf"
{"variable", T_VARIABLE},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
#line 188 "TokenLookup.gperf"
{"or", T_OR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
#line 134 "TokenLookup.gperf"
{"comment", T_COMMENT},
{"",T_ERROR}, {"",T_ERROR},
#line 209 "TokenLookup.gperf"
{"typeswitch", T_TYPESWITCH},
{"",T_ERROR},
#line 165 "TokenLookup.gperf"
{"inherit", T_INHERIT},
#line 142 "TokenLookup.gperf"
{"div", T_DIV},
{"",T_ERROR}, {"",T_ERROR},
#line 177 "TokenLookup.gperf"
{"module", T_MODULE},
{"",T_ERROR},
#line 157 "TokenLookup.gperf"
{"for", T_FOR},
#line 178 "TokenLookup.gperf"
{"namespace", T_NAMESPACE},
{"",T_ERROR}, {"",T_ERROR},
#line 214 "TokenLookup.gperf"
{"version", T_VERSION},
{"",T_ERROR}, {"",T_ERROR},
#line 204 "TokenLookup.gperf"
{"strip", T_STRIP},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
#line 187 "TokenLookup.gperf"
{"order", T_ORDER},
#line 189 "TokenLookup.gperf"
{"parent", T_PARENT},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR},
#line 176 "TokenLookup.gperf"
{"mod", T_MOD},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR},
#line 164 "TokenLookup.gperf"
{"import", T_IMPORT},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR},
#line 194 "TokenLookup.gperf"
{"processing-instruction", T_PROCESSING_INSTRUCTION},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR},
#line 170 "TokenLookup.gperf"
{"item", T_ITEM},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR}, {"",T_ERROR},
{"",T_ERROR},
#line 162 "TokenLookup.gperf"
{"idiv", T_IDIV}
};
if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
{
unsigned int key = hash (str, len);
if (key <= MAX_HASH_VALUE)
{
const char *s = wordlist[key].name;
if (*str == *s && !strcmp (str + 1, s + 1))
return &wordlist[key];
}
}
return 0;
}
#line 217 "TokenLookup.gperf"
} /* Close the QPatternist namespace. */
QT_END_NAMESPACE