Token coloring in immediate mode; C++

This commit is contained in:
Allen Webster 2019-09-28 16:56:34 -07:00
parent 9ad2de95c2
commit 7c495a160d
1 changed files with 24 additions and 5 deletions

View File

@ -328,7 +328,7 @@ GET_VIEW_BUFFER_REGION_SIG(default_view_buffer_region){
} }
internal int_color internal int_color
get_token_color(Token token){ get_token_color_cpp(Token token){
int_color result = Stag_Default; int_color result = Stag_Default;
if (HasFlag(token.flags, TokenBaseFlag_PreprocessorBody)){ if (HasFlag(token.flags, TokenBaseFlag_PreprocessorBody)){
result = Stag_Preproc; result = Stag_Preproc;
@ -337,7 +337,6 @@ get_token_color(Token token){
switch (token.kind){ switch (token.kind){
case TokenBaseKind_Keyword: case TokenBaseKind_Keyword:
{ {
// TODO(allen): beta: Stag_Bool_Constant
result = Stag_Keyword; result = Stag_Keyword;
}break; }break;
case TokenBaseKind_Comment: case TokenBaseKind_Comment:
@ -347,8 +346,6 @@ get_token_color(Token token){
case TokenBaseKind_LiteralString: case TokenBaseKind_LiteralString:
{ {
result = Stag_Str_Constant; result = Stag_Str_Constant;
// TODO(allen): beta: Stag_Char_Constant
// TODO(allen): beta: Stag_Include
}break; }break;
case TokenBaseKind_LiteralInteger: case TokenBaseKind_LiteralInteger:
{ {
@ -358,6 +355,28 @@ get_token_color(Token token){
{ {
result = Stag_Float_Constant; result = Stag_Float_Constant;
}break; }break;
default:
{
switch (token.sub_kind){
case TokenCppKind_LiteralTrue:
case TokenCppKind_LiteralFalse:
{
result = Stag_Bool_Constant;
}break;
case TokenCppKind_LiteralCharacter:
case TokenCppKind_LiteralCharacterWide:
case TokenCppKind_LiteralCharacterUTF8:
case TokenCppKind_LiteralCharacterUTF16:
case TokenCppKind_LiteralCharacterUTF32:
{
result = Stag_Char_Constant;
}break;
case TokenCppKind_PPIncludeFile:
{
result = Stag_Include;
}break;
}
}break;
} }
} }
return(result); return(result);
@ -399,7 +418,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
break; break;
} }
int_color color = get_token_color(*token); int_color color = get_token_color_cpp(*token);
paint_text_color(app, text_layout_id, Ii64(token->pos, token->pos + token->size), color); paint_text_color(app, text_layout_id, Ii64(token->pos, token->pos + token->size), color);
if (!token_it_inc_non_whitespace(&it)){ if (!token_it_inc_non_whitespace(&it)){