Files
qt-creator/src/libs/3rdparty/cplusplus/Token.h
Volodymyr Zibarov df6d95c3e1 C++: Fix cplusplus-keywordgen to generate Keywords.cpp
Fix kewordgen to generate current Keywords.cpp with minimal diff,
but also to be compatible with old usage and kwgen files.

Add new parameters:
%no-namespace-for-tokens - not use namespace for tokens
%pre-check-argument - set type and name of additional variable to use
%function-name - name of a function ("classify" by default)
%pre-check - name of a variable to check for a keyword (i.e. cxxEnabled)
Now "%%" is also used to end and restart keywords parsing to be able to
generate additional keywords for classifyOperator()

Automatically add checks for LanguageFeatures to generated code
Pass input and output files with command line arguments, print usage

Update Keywords.kwgen to include all keywords currently used

Add missing aliases to Token.h

Change-Id: I6cc84e150e0d797277204032fc05ce9cfbd01f58
Reviewed-by: Nikolai Kosjar <nikolai.kosjar@qt.io>
2020-05-28 11:12:38 +00:00

453 lines
11 KiB
C++

// Copyright (c) 2008 Roberto Raggi <roberto.raggi@gmail.com>
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
#pragma once
#include "CPlusPlusForwardDeclarations.h"
namespace CPlusPlus {
enum Kind {
T_EOF_SYMBOL = 0,
T_ERROR,
T_CPP_COMMENT,
T_CPP_DOXY_COMMENT,
T_COMMENT,
T_DOXY_COMMENT,
T_IDENTIFIER,
T_FIRST_LITERAL,
T_NUMERIC_LITERAL = T_FIRST_LITERAL,
T_FIRST_CHAR_LITERAL,
T_CHAR_LITERAL = T_FIRST_CHAR_LITERAL,
T_WIDE_CHAR_LITERAL,
T_UTF16_CHAR_LITERAL,
T_UTF32_CHAR_LITERAL,
T_LAST_CHAR_LITERAL = T_UTF32_CHAR_LITERAL,
T_FIRST_STRING_LITERAL,
T_STRING_LITERAL = T_FIRST_STRING_LITERAL,
T_WIDE_STRING_LITERAL,
T_UTF8_STRING_LITERAL,
T_UTF16_STRING_LITERAL,
T_UTF32_STRING_LITERAL,
T_FIRST_RAW_STRING_LITERAL,
T_RAW_STRING_LITERAL = T_FIRST_RAW_STRING_LITERAL,
T_RAW_WIDE_STRING_LITERAL,
T_RAW_UTF8_STRING_LITERAL,
T_RAW_UTF16_STRING_LITERAL,
T_RAW_UTF32_STRING_LITERAL,
T_LAST_RAW_STRING_LITERAL = T_RAW_UTF32_STRING_LITERAL,
T_AT_STRING_LITERAL,
T_ANGLE_STRING_LITERAL,
T_LAST_STRING_LITERAL = T_ANGLE_STRING_LITERAL,
T_LAST_LITERAL = T_ANGLE_STRING_LITERAL,
T_FIRST_PUNCTUATION_OR_OPERATOR,
T_FIRST_PUNCTUATION = T_FIRST_PUNCTUATION_OR_OPERATOR,
T_COLON = T_FIRST_PUNCTUATION_OR_OPERATOR,
T_COLON_COLON,
T_COMMA,
T_GREATER,
T_LESS,
T_LBRACE,
T_LBRACKET,
T_LPAREN,
T_RBRACE,
T_RBRACKET,
T_RPAREN,
T_SEMICOLON,
T_LAST_PUNCTUATION = T_SEMICOLON,
T_FIRST_OPERATOR,
T_AMPER = T_FIRST_OPERATOR,
T_AMPER_AMPER,
T_AMPER_EQUAL,
T_ARROW,
T_ARROW_STAR,
T_CARET,
T_CARET_EQUAL,
T_SLASH,
T_SLASH_EQUAL,
T_DOT,
T_DOT_DOT_DOT,
T_DOT_STAR,
T_EQUAL,
T_EQUAL_EQUAL,
T_EXCLAIM,
T_EXCLAIM_EQUAL,
T_GREATER_EQUAL,
T_GREATER_GREATER,
T_GREATER_GREATER_EQUAL,
T_LESS_EQUAL,
T_LESS_LESS,
T_LESS_LESS_EQUAL,
T_MINUS,
T_MINUS_EQUAL,
T_MINUS_MINUS,
T_PERCENT,
T_PERCENT_EQUAL,
T_PIPE,
T_PIPE_EQUAL,
T_PIPE_PIPE,
T_PLUS,
T_PLUS_EQUAL,
T_PLUS_PLUS,
T_POUND,
T_POUND_POUND,
T_QUESTION,
T_STAR,
T_STAR_EQUAL,
T_TILDE,
T_TILDE_EQUAL,
T_LAST_OPERATOR = T_TILDE_EQUAL,
T_LAST_PUNCTUATION_OR_OPERATOR = T_LAST_OPERATOR,
T_FIRST_KEYWORD,
T_ALIGNAS = T_FIRST_KEYWORD,
T_ALIGNOF,
T_ASM,
T_AUTO,
T_BREAK,
T_CASE,
T_CATCH,
T_CLASS,
T_CONST,
T_CONST_CAST,
T_CONSTEXPR,
T_CONTINUE,
T_DECLTYPE,
T_DEFAULT,
T_DELETE,
T_DO,
T_DYNAMIC_CAST,
T_ELSE,
T_ENUM,
T_EXPLICIT,
T_EXPORT,
T_EXTERN,
T_FALSE,
T_FOR,
T_FRIEND,
T_GOTO,
T_IF,
T_INLINE,
T_MUTABLE,
T_NAMESPACE,
T_NEW,
T_NOEXCEPT,
T_NULLPTR,
T_OPERATOR,
T_PRIVATE,
T_PROTECTED,
T_PUBLIC,
T_REGISTER,
T_REINTERPRET_CAST,
T_RETURN,
T_SIZEOF,
T_STATIC,
T_STATIC_ASSERT,
T_STATIC_CAST,
T_STRUCT,
T_SWITCH,
T_TEMPLATE,
T_THIS,
T_THREAD_LOCAL,
T_THROW,
T_TRUE,
T_TRY,
T_TYPEDEF,
T_TYPEID,
T_TYPENAME,
T_UNION,
T_USING,
T_VIRTUAL,
T_VOLATILE,
T_WHILE,
T___ATTRIBUTE__,
T___THREAD,
T___TYPEOF__,
// obj c++ @ keywords
T_FIRST_OBJC_AT_KEYWORD,
T_AT_CATCH = T_FIRST_OBJC_AT_KEYWORD,
T_AT_CLASS,
T_AT_COMPATIBILITY_ALIAS,
T_AT_DEFS,
T_AT_DYNAMIC,
T_AT_ENCODE,
T_AT_END,
T_AT_FINALLY,
T_AT_IMPLEMENTATION,
T_AT_INTERFACE,
T_AT_NOT_KEYWORD,
T_AT_OPTIONAL,
T_AT_PACKAGE,
T_AT_PRIVATE,
T_AT_PROPERTY,
T_AT_PROTECTED,
T_AT_PROTOCOL,
T_AT_PUBLIC,
T_AT_REQUIRED,
T_AT_SELECTOR,
T_AT_SYNCHRONIZED,
T_AT_SYNTHESIZE,
T_AT_THROW,
T_AT_TRY,
T_LAST_OBJC_AT_KEYWORD = T_AT_TRY,
// Primitive types
T_FIRST_PRIMITIVE,
T_BOOL = T_FIRST_PRIMITIVE,
T_CHAR,
T_CHAR16_T,
T_CHAR32_T,
T_DOUBLE,
T_FLOAT,
T_INT,
T_LONG,
T_SHORT,
T_SIGNED,
T_UNSIGNED,
T_VOID,
T_WCHAR_T,
T_LAST_PRIMITIVE = T_WCHAR_T,
// Qt keywords
T_FIRST_QT_KEYWORD,
T_EMIT = T_FIRST_QT_KEYWORD,
T_SIGNAL,
T_SLOT,
T_Q_SIGNAL,
T_Q_SLOT,
T_Q_SIGNALS,
T_Q_SLOTS,
T_Q_FOREACH,
T_Q_D,
T_Q_Q,
T_Q_INVOKABLE,
T_Q_PROPERTY,
T_Q_PRIVATE_PROPERTY,
T_Q_INTERFACES,
T_Q_EMIT,
T_Q_ENUMS,
T_Q_FLAGS,
T_Q_PRIVATE_SLOT,
T_Q_DECLARE_INTERFACE,
T_Q_OBJECT,
T_Q_GADGET,
T_LAST_QT_KEYWORD = T_Q_GADGET,
T_LAST_KEYWORD = T_LAST_QT_KEYWORD,
T_LAST_TOKEN = T_LAST_KEYWORD, // keep this before the aliases below
// aliases
T_OR = T_PIPE_PIPE,
T_AND = T_AMPER_AMPER,
T_NOT = T_EXCLAIM,
T_XOR = T_CARET,
T_BITOR = T_PIPE,
T_COMPL = T_TILDE,
T_OR_EQ = T_PIPE_EQUAL,
T_AND_EQ = T_AMPER_EQUAL,
T_BITAND = T_AMPER,
T_NOT_EQ = T_EXCLAIM_EQUAL,
T_XOR_EQ = T_CARET_EQUAL,
T___ASM = T_ASM,
T___ASM__ = T_ASM,
T_TYPEOF = T___TYPEOF__,
T___TYPEOF = T___TYPEOF__,
T___DECLTYPE = T_DECLTYPE,
T___INLINE = T_INLINE,
T___INLINE__ = T_INLINE,
T___CONST = T_CONST,
T___CONST__ = T_CONST,
T___VOLATILE = T_VOLATILE,
T___VOLATILE__ = T_VOLATILE,
T___ATTRIBUTE = T___ATTRIBUTE__,
T___ALIGNOF__ = T_ALIGNOF,
T_SLOTS = T_Q_SLOTS,
T_FOREACH = T_Q_FOREACH,
T_SIGNALS = T_Q_SIGNALS,
T_Q_OVERRIDE = T_Q_PROPERTY,
};
class CPLUSPLUS_EXPORT Token
{
public:
Token() : flags(0), byteOffset(0), utf16charOffset(0), ptr(nullptr) {}
inline bool is(unsigned k) const { return f.kind == k; }
inline bool isNot(unsigned k) const { return f.kind != k; }
const char *spell() const;
void reset();
inline Kind kind() const { return static_cast<Kind>(f.kind); }
inline bool newline() const { return f.newline; }
inline bool whitespace() const { return f.whitespace; }
inline bool joined() const { return f.joined; }
inline bool expanded() const { return f.expanded; }
inline bool generated() const { return f.generated; }
inline bool userDefinedLiteral() const { return f.userDefinedLiteral; }
inline int bytes() const { return f.bytes; }
inline int bytesBegin() const { return byteOffset; }
inline int bytesEnd() const { return byteOffset + f.bytes; }
inline int utf16chars() const { return f.utf16chars; }
inline int utf16charsBegin() const { return utf16charOffset; }
inline int utf16charsEnd() const { return utf16charOffset + f.utf16chars; }
inline bool isLiteral() const
{ return f.kind >= T_FIRST_LITERAL && f.kind <= T_LAST_LITERAL; }
inline bool isCharLiteral() const
{ return f.kind >= T_FIRST_CHAR_LITERAL && f.kind <= T_LAST_CHAR_LITERAL; }
inline bool isStringLiteral() const
{ return f.kind >= T_FIRST_STRING_LITERAL && f.kind <= T_LAST_STRING_LITERAL; }
inline bool isOperator() const
{ return f.kind >= T_FIRST_OPERATOR && f.kind <= T_LAST_OPERATOR; }
inline bool isPunctuation() const
{ return f.kind >= T_FIRST_PUNCTUATION && f.kind <= T_LAST_PUNCTUATION; }
inline bool isPunctuationOrOperator() const
{ return f.kind >= T_FIRST_PUNCTUATION_OR_OPERATOR && f.kind <= T_LAST_PUNCTUATION_OR_OPERATOR; }
inline bool isKeyword() const
{ return f.kind >= T_FIRST_KEYWORD && f.kind < T_FIRST_PRIMITIVE; }
inline bool isPrimitiveType() const
{ return f.kind >= T_FIRST_PRIMITIVE && f.kind <= T_LAST_PRIMITIVE; }
inline bool isQtKeyword() const
{ return f.kind >= T_FIRST_QT_KEYWORD && f.kind <= T_LAST_QT_KEYWORD; }
inline bool isComment() const
{ return f.kind == T_COMMENT || f.kind == T_DOXY_COMMENT ||
f.kind == T_CPP_COMMENT || f.kind == T_CPP_DOXY_COMMENT; }
inline bool isObjCAtKeyword() const
{ return f.kind >= T_FIRST_OBJC_AT_KEYWORD && f.kind <= T_LAST_OBJC_AT_KEYWORD; }
static const char *name(int kind);
public:
struct Flags {
// The token kind.
unsigned kind : 8;
// The token starts a new line.
unsigned newline : 1;
// The token is preceeded by whitespace(s).
unsigned whitespace : 1;
// The token is joined with the previous one.
unsigned joined : 1;
// The token originates from a macro expansion.
unsigned expanded : 1;
// The token originates from a macro expansion and does not correspond to an
// argument that went through substitution. Notice the example:
//
// #define FOO(a, b) a + b;
// FOO(1, 2)
//
// After preprocessing we would expect the following tokens: 1 + 2;
// Tokens '1', '+', '2', and ';' are all expanded. However only tokens '+' and ';'
// are generated.
unsigned generated : 1;
// The token is C++11 user-defined literal such as:
// 12_km, 0.5_Pa, 'c'_X, "abd"_L, u16"xyz"_M
unsigned userDefinedLiteral : 1;
// Indicates the token is a trigraph
unsigned trigraph : 1;
// Unused...
unsigned pad : 1;
// The token length in bytes and UTF16 chars.
unsigned bytes : 16;
unsigned utf16chars : 16;
};
union {
unsigned long flags;
Flags f;
};
unsigned byteOffset;
unsigned utf16charOffset;
union {
void *ptr;
const Literal *literal;
const NumericLiteral *number;
const StringLiteral *string;
const Identifier *identifier;
unsigned close_brace;
int lineno;
};
};
struct LanguageFeatures
{
LanguageFeatures() : flags(0) {}
static LanguageFeatures defaultFeatures()
{
LanguageFeatures features;
features.flags = 0xffffffff; // Enable all flags
return features;
}
bool operator==(const LanguageFeatures &other) const
{
return flags == other.flags;
}
bool operator!=(const LanguageFeatures &other) const
{
return flags != other.flags;
}
union {
unsigned int flags;
struct {
unsigned int qtEnabled : 1; // If Qt is used.
unsigned int qtMocRunEnabled : 1;
unsigned int qtKeywordsEnabled : 1; // If Qt is used but QT_NO_KEYWORDS defined
unsigned int cxxEnabled : 1;
unsigned int cxx11Enabled : 1;
unsigned int cxx14Enabled : 1;
unsigned int objCEnabled : 1;
unsigned int c99Enabled : 1;
};
};
};
} // namespace CPlusPlus