// For a quick way to extend the default keywords: // #define FCPP_LEXER_EXTRA_KEYWORDS "my_keywords.h" // And in the file "my_keywords.h", list the keywords you want. // For a quick way to extend the default preprocessor // directives do the same thing with the macro: // #define FCPP_LEXER_EXTRA_PREPROPS // TOP #if !defined(FCPP_DEFAULT_KEYWORDS_H) #define FCPP_DEFAULT_KEYWORDS_H #define make_stafl(s,f) (s), sizeof(s)-1, f struct String_And_Flag{ char *str; u32_4tech length; u32_4tech flags; }; static String_And_Flag default_preprops[] = { {make_stafl("include" , CPP_PP_INCLUDE )} , {make_stafl("INCLUDE" , CPP_PP_INCLUDE )} , {make_stafl("version" , CPP_PP_VERSION )} , {make_stafl("VERSION" , CPP_PP_VERSION )} , {make_stafl("ifndef" , CPP_PP_IFNDEF )} , {make_stafl("IFNDEF" , CPP_PP_IFNDEF )} , {make_stafl("define" , CPP_PP_DEFINE )} , {make_stafl("DEFINE" , CPP_PP_DEFINE )} , {make_stafl("import" , CPP_PP_IMPORT )} , {make_stafl("IMPORT" , CPP_PP_IMPORT )} , {make_stafl("pragma" , CPP_PP_PRAGMA )} , {make_stafl("PRAGMA" , CPP_PP_PRAGMA )} , {make_stafl("undef" , CPP_PP_UNDEF )} , {make_stafl("UNDEF" , CPP_PP_UNDEF )} , {make_stafl("endif" , CPP_PP_ENDIF )} , {make_stafl("ENDIF" , CPP_PP_ENDIF )} , {make_stafl("error" , CPP_PP_ERROR )} , {make_stafl("ERROR" , CPP_PP_ERROR )} , {make_stafl("ifdef" , CPP_PP_IFDEF )} , {make_stafl("IFDEF" , CPP_PP_IFDEF )} , {make_stafl("using" , CPP_PP_USING )} , {make_stafl("USING" , CPP_PP_USING )} , {make_stafl("else" , CPP_PP_ELSE )} , {make_stafl("ELSE" , CPP_PP_ELSE )} , {make_stafl("elif" , CPP_PP_ELIF )} , {make_stafl("ELIF" , CPP_PP_ELIF )} , {make_stafl("line" , CPP_PP_LINE )} , {make_stafl("LINE" , CPP_PP_LINE )} , {make_stafl("if" , CPP_PP_IF )} , {make_stafl("IF" , CPP_PP_IF )} , #if defined(FCPP_LEXER_EXTRA_PREPROPS) #include FCPP_LEXER_EXTRA_PREPROPS #endif }; static i32_4tech default_preprops_count = sizeof(default_preprops)/sizeof(default_preprops[0]); static String_And_Flag default_keywords[] = { {make_stafl("true" , CPP_TOKEN_BOOLEAN_CONSTANT)}, {make_stafl("false" , CPP_TOKEN_BOOLEAN_CONSTANT)}, {make_stafl("and" , CPP_TOKEN_AND)}, {make_stafl("and_eq" , CPP_TOKEN_ANDEQ)}, {make_stafl("bitand" , CPP_TOKEN_BIT_AND)}, {make_stafl("bitor" , CPP_TOKEN_BIT_OR)}, {make_stafl("or" , CPP_TOKEN_OR)}, {make_stafl("or_eq" , CPP_TOKEN_OREQ)}, {make_stafl("sizeof" , CPP_TOKEN_SIZEOF)}, {make_stafl("alignof" , CPP_TOKEN_ALIGNOF)}, {make_stafl("decltype" , CPP_TOKEN_DECLTYPE)}, {make_stafl("throw" , CPP_TOKEN_THROW)}, {make_stafl("new" , CPP_TOKEN_NEW)}, {make_stafl("delete" , CPP_TOKEN_DELETE)}, {make_stafl("xor" , CPP_TOKEN_BIT_XOR)}, {make_stafl("xor_eq" , CPP_TOKEN_XOREQ)}, {make_stafl("not" , CPP_TOKEN_NOT)}, {make_stafl("not_eq" , CPP_TOKEN_NOTEQ)}, {make_stafl("typeid" , CPP_TOKEN_TYPEID)}, {make_stafl("compl" , CPP_TOKEN_BIT_NOT)}, {make_stafl("void" , CPP_TOKEN_KEY_TYPE)}, {make_stafl("bool" , CPP_TOKEN_KEY_TYPE)}, {make_stafl("char" , CPP_TOKEN_KEY_TYPE)}, {make_stafl("int" , CPP_TOKEN_KEY_TYPE)}, {make_stafl("float" , CPP_TOKEN_KEY_TYPE)}, {make_stafl("double" , CPP_TOKEN_KEY_TYPE)}, {make_stafl("long" , CPP_TOKEN_KEY_MODIFIER)}, {make_stafl("short" , CPP_TOKEN_KEY_MODIFIER)}, {make_stafl("unsigned" , CPP_TOKEN_KEY_MODIFIER)}, {make_stafl("const" , CPP_TOKEN_KEY_QUALIFIER)}, {make_stafl("volatile" , CPP_TOKEN_KEY_QUALIFIER)}, {make_stafl("asm" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("break" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("case" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("catch" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("continue" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("default" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("do" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("else" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("for" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("goto" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("if" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("return" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("switch" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("try" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("while" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("static_assert" , CPP_TOKEN_KEY_CONTROL_FLOW)}, {make_stafl("const_cast" , CPP_TOKEN_KEY_CAST)}, {make_stafl("dynamic_cast" , CPP_TOKEN_KEY_CAST)}, {make_stafl("reinterpret_cast" , CPP_TOKEN_KEY_CAST)}, {make_stafl("static_cast" , CPP_TOKEN_KEY_CAST)}, {make_stafl("class" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("enum" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("struct" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("typedef" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("union" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("template" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("typename" , CPP_TOKEN_KEY_TYPE_DECLARATION)}, {make_stafl("friend" , CPP_TOKEN_KEY_ACCESS)}, {make_stafl("namespace" , CPP_TOKEN_KEY_ACCESS)}, {make_stafl("private" , CPP_TOKEN_KEY_ACCESS)}, {make_stafl("protected" , CPP_TOKEN_KEY_ACCESS)}, {make_stafl("public" , CPP_TOKEN_KEY_ACCESS)}, {make_stafl("using" , CPP_TOKEN_KEY_ACCESS)}, {make_stafl("extern" , CPP_TOKEN_KEY_LINKAGE)}, {make_stafl("export" , CPP_TOKEN_KEY_LINKAGE)}, {make_stafl("inline" , CPP_TOKEN_KEY_LINKAGE)}, {make_stafl("static" , CPP_TOKEN_KEY_LINKAGE)}, {make_stafl("virtual" , CPP_TOKEN_KEY_LINKAGE)}, {make_stafl("alignas" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("explicit" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("noexcept" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("nullptr" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("operator" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("register" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("this" , CPP_TOKEN_KEY_OTHER)}, {make_stafl("thread_local" , CPP_TOKEN_KEY_OTHER)}, #if defined(FCPP_LEXER_EXTRA_KEYWORDS) #include FCPP_LEXER_EXTRA_KEYWORDS #endif }; static i32_4tech default_keywords_count = sizeof(default_keywords)/sizeof(default_keywords[0]); #endif // BOTTOM