From a9832463f3a6ba16c4fe4b5272e03e9dc7fa8b2a Mon Sep 17 00:00:00 2001 From: Robert Winkler Date: Mon, 9 Mar 2020 00:39:03 -0700 Subject: [PATCH] Make symbols array static global --- demo/style_configurator.c | 122 ++++++-------------------------------- 1 file changed, 19 insertions(+), 103 deletions(-) diff --git a/demo/style_configurator.c b/demo/style_configurator.c index e1bb670f1..f150f9c04 100644 --- a/demo/style_configurator.c +++ b/demo/style_configurator.c @@ -4,6 +4,23 @@ // use the duplicate array method, or just let the user // manually set those after calling the function by accessing ctx->style->*? +static const char* symbols[NK_SYMBOL_MAX] = +{ + "NONE", + "X", + "UNDERSCORE", + "CIRCLE_SOLID", + "CIRCLE_OUTLINE", + "RECT_SOLID", + "RECT_OUTLINE", + "TRIANGLE_UP", + "TRIANGLE_DOWN", + "TRIANGLE_LEFT", + "TRIANGLE_RIGHT", + "PLUS", + "MINUS" +}; + static void @@ -336,23 +353,6 @@ style_slider(struct nk_context* ctx, struct nk_style_slider* out_style) nk_property_float(ctx, "#Bar Height:", -100.0f, &slider.bar_height, 100.0f, 1,0.5f); nk_property_float(ctx, "#Rounding:", -100.0f, &slider.rounding, 100.0f, 1,0.5f); - const char* symbols[NK_SYMBOL_MAX] = -{ - "NONE", - "X", - "UNDERSCORE", - "CIRCLE_SOLID", - "CIRCLE_OUTLINE", - "RECT_SOLID", - "RECT_OUTLINE", - "TRIANGLE_UP", - "TRIANGLE_DOWN", - "TRIANGLE_LEFT", - "TRIANGLE_RIGHT", - "PLUS", - "MINUS" -}; - nk_layout_row_dynamic(ctx, 30, 1); nk_checkbox_label(ctx, "Show Buttons", &slider.show_buttons); @@ -470,24 +470,6 @@ style_scrollbars(struct nk_context* ctx, struct nk_style_scrollbar* out_style, s nk_property_float(ctx, "#Cursor Border:", -100.0f, &scroll.border_cursor, 100.0f, 1,0.5f); nk_property_float(ctx, "#Cursor Rounding:", -100.0f, &scroll.rounding_cursor, 100.0f, 1,0.5f); - - const char* symbols[NK_SYMBOL_MAX] = -{ - "NONE", - "X", - "UNDERSCORE", - "CIRCLE_SOLID", - "CIRCLE_OUTLINE", - "RECT_SOLID", - "RECT_OUTLINE", - "TRIANGLE_UP", - "TRIANGLE_DOWN", - "TRIANGLE_LEFT", - "TRIANGLE_RIGHT", - "PLUS", - "MINUS" -}; - // TODO what is wrong with scrollbar buttons? Also look into controlling the total width (and height) of scrollbars nk_layout_row_dynamic(ctx, 30, 1); nk_checkbox_label(ctx, "Show Buttons", &scroll.show_buttons); @@ -623,22 +605,6 @@ style_property(struct nk_context* ctx, struct nk_style_property* out_style) nk_property_float(ctx, "#Rounding:", -100.0f, &property.rounding, 100.0f, 1,0.5f); // there is no property.show_buttons, they're always there - const char* symbols[NK_SYMBOL_MAX] = -{ - "NONE", - "X", - "UNDERSCORE", - "CIRCLE_SOLID", - "CIRCLE_OUTLINE", - "RECT_SOLID", - "RECT_OUTLINE", - "TRIANGLE_UP", - "TRIANGLE_DOWN", - "TRIANGLE_LEFT", - "TRIANGLE_RIGHT", - "PLUS", - "MINUS" -}; nk_label(ctx, "Left Symbol:", NK_TEXT_LEFT); property.sym_left = nk_combo(ctx, symbols, NK_SYMBOL_MAX, property.sym_left, 25, nk_vec2(200,200)); @@ -720,23 +686,6 @@ style_combo(struct nk_context* ctx, struct nk_style_combo* out_style) style_rgb(ctx, "Label Hover:", &combo.label_hover); style_rgb(ctx, "Label Active:", &combo.label_active); - const char* symbols[NK_SYMBOL_MAX] = -{ - "NONE", - "X", - "UNDERSCORE", - "CIRCLE_SOLID", - "CIRCLE_OUTLINE", - "RECT_SOLID", - "RECT_OUTLINE", - "TRIANGLE_UP", - "TRIANGLE_DOWN", - "TRIANGLE_LEFT", - "TRIANGLE_RIGHT", - "PLUS", - "MINUS" -}; - nk_label(ctx, "Normal Symbol:", NK_TEXT_LEFT); combo.sym_normal = nk_combo(ctx, symbols, NK_SYMBOL_MAX, combo.sym_normal, 25, nk_vec2(200,200)); nk_label(ctx, "Hover Symbol:", NK_TEXT_LEFT); @@ -777,24 +726,8 @@ style_tab(struct nk_context* ctx, struct nk_style_tab* out_style) style_rgb(ctx, "Border:", &tab.border_color); style_rgb(ctx, "Text:", &tab.text); - // putting these in matching order instead of at bottom because we have an odd number of float properties - const char* symbols[NK_SYMBOL_MAX] = -{ - "NONE", - "X", - "UNDERSCORE", - "CIRCLE_SOLID", - "CIRCLE_OUTLINE", - "RECT_SOLID", - "RECT_OUTLINE", - "TRIANGLE_UP", - "TRIANGLE_DOWN", - "TRIANGLE_LEFT", - "TRIANGLE_RIGHT", - "PLUS", - "MINUS" -}; - + // FTR, I feel these fields are misnamed and should be sym_minimized and sym_maximized since they are + // what show in that state, not the button to push to get to that state nk_label(ctx, "Minimize Symbol:", NK_TEXT_LEFT); tab.sym_minimize = nk_combo(ctx, symbols, NK_SYMBOL_MAX, tab.sym_minimize, 25, nk_vec2(200,200)); nk_label(ctx, "Maxmize Symbol:", NK_TEXT_LEFT); @@ -844,23 +777,6 @@ style_window_header(struct nk_context* ctx, struct nk_style_window_header* out_s style_vec2(ctx, "Padding:", &header.padding); style_vec2(ctx, "Spacing:", &header.spacing); - const char* symbols[NK_SYMBOL_MAX] = -{ - "NONE", - "X", - "UNDERSCORE", - "CIRCLE_SOLID", - "CIRCLE_OUTLINE", - "RECT_SOLID", - "RECT_OUTLINE", - "TRIANGLE_UP", - "TRIANGLE_DOWN", - "TRIANGLE_LEFT", - "TRIANGLE_RIGHT", - "PLUS", - "MINUS" -}; - #define NUM_ALIGNS 2 const char* alignments[NUM_ALIGNS] = { "LEFT", "RIGHT" };