add customcolors option
customcolors (default) and !customcolors toggle whether the custom colors get applied to the glyphmap.
This commit is contained in:
@@ -752,6 +752,7 @@ struct instance_globals_o {
|
||||
boolean opt_need_redraw; /* for doset() */
|
||||
boolean opt_need_glyph_reset;
|
||||
boolean opt_need_promptstyle;
|
||||
boolean opt_reset_customizations;
|
||||
|
||||
/* pickup.c */
|
||||
int oldcap; /* last encumbrance */
|
||||
|
||||
@@ -1110,6 +1110,8 @@ extern void apply_customizations(enum graphics_sets which_set);
|
||||
extern void purge_custom_entries(enum graphics_sets which_set);
|
||||
extern void purge_all_custom_entries(void);
|
||||
extern void dump_glyphids(void);
|
||||
extern void clear_all_glyphmap_colors(void);
|
||||
extern void reset_customizations(void);
|
||||
|
||||
/* ### hack.c ### */
|
||||
|
||||
@@ -3031,7 +3033,6 @@ extern const struct symparse *match_sym(char *) NONNULLARG1;
|
||||
extern void savedsym_free(void);
|
||||
extern void savedsym_strbuf(strbuf_t *) NONNULLARG1;
|
||||
extern boolean parsesymbols(char *, int) NONNULLARG1;
|
||||
extern void clear_all_glyphmap_colors(void);
|
||||
|
||||
/* ### sys.c ### */
|
||||
|
||||
|
||||
@@ -375,6 +375,7 @@ struct instance_flags {
|
||||
boolean fireassist; /* autowield launcher when using fire-command */
|
||||
boolean wizweight; /* display weight of everything in wizard mode */
|
||||
boolean wizmgender; /* test gender info from core in window port */
|
||||
boolean customcolors; /* support customcolors defined in glyphmap */
|
||||
/*
|
||||
* Window capability support.
|
||||
*/
|
||||
|
||||
@@ -250,6 +250,9 @@ static int optfn_##a(int, int, boolean, char *, char *);
|
||||
No, Yes, No, No, NoAlias,
|
||||
"load curses display symbols into symset")
|
||||
#endif
|
||||
NHOPTB(customcolors, Map, 0, opt_out, set_in_game,
|
||||
On, Yes, No, No, "customcolours", &iflags.customcolors,
|
||||
Term_False, "use custom colors in map")
|
||||
NHOPTB(dark_room, Advanced, 0, opt_out, set_in_game,
|
||||
On, Yes, No, No, NoAlias, &flags.dark_room, Term_False,
|
||||
"show floor outside line of sight differently")
|
||||
|
||||
@@ -655,6 +655,7 @@ static const struct instance_globals_o g_init_o = {
|
||||
FALSE, /* opt_need_redraw */
|
||||
FALSE, /* opt_need_glyph_reset */
|
||||
FALSE, /* opt_need_promptstyle */
|
||||
FALSE, /* opt_reset_customizations */
|
||||
/* pickup.c */
|
||||
0, /* oldcap */
|
||||
/* restore.c */
|
||||
|
||||
29
src/glyphs.c
29
src/glyphs.c
@@ -474,10 +474,12 @@ apply_customizations(enum graphics_sets which_set)
|
||||
details->content.urep.u.utf8str);
|
||||
}
|
||||
#endif
|
||||
if (sc->custtype == custom_nhcolor) {
|
||||
gmap = &glyphmap[details->content.ccolor.glyphidx];
|
||||
(void) set_map_nhcolor(gmap,
|
||||
details->content.ccolor.nhcolor);
|
||||
if (iflags.customcolors) {
|
||||
if (sc->custtype == custom_nhcolor) {
|
||||
gmap = &glyphmap[details->content.ccolor.glyphidx];
|
||||
(void) set_map_nhcolor(gmap,
|
||||
details->content.ccolor.nhcolor);
|
||||
}
|
||||
}
|
||||
details = details->next;
|
||||
}
|
||||
@@ -1033,6 +1035,25 @@ parse_id(const char *id, struct find_struct *findwhat)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* extern glyph_map glyphmap[MAX_GLYPH]; */
|
||||
|
||||
void
|
||||
clear_all_glyphmap_colors(void)
|
||||
{
|
||||
int glyph;
|
||||
|
||||
for (glyph = 0; glyph < MAX_GLYPH; ++glyph) {
|
||||
if (glyphmap[glyph].customcolor)
|
||||
glyphmap[glyph].customcolor = 0;
|
||||
}
|
||||
}
|
||||
|
||||
void reset_customizations(void)
|
||||
{
|
||||
clear_all_glyphmap_colors();
|
||||
apply_customizations(gc.currentgraphics);
|
||||
}
|
||||
|
||||
/* not used yet */
|
||||
|
||||
#if 0
|
||||
|
||||
@@ -5229,6 +5229,9 @@ optfn_boolean(
|
||||
go.opt_need_redraw = TRUE;
|
||||
go.opt_need_glyph_reset = TRUE;
|
||||
break;
|
||||
case opt_customcolors:
|
||||
go.opt_reset_customizations = TRUE;
|
||||
break;
|
||||
case opt_menucolors:
|
||||
case opt_guicolor:
|
||||
update_inventory();
|
||||
@@ -8389,6 +8392,7 @@ doset_simple_menu(void)
|
||||
|
||||
go.opt_need_redraw = FALSE;
|
||||
go.opt_need_glyph_reset = FALSE;
|
||||
go.opt_reset_customizations = FALSE;
|
||||
pick_cnt = select_menu(tmpwin, PICK_ONE, &pick_list);
|
||||
/* note: without the complication of a preselected entry, a PICK_ONE
|
||||
menu returning pick_cnt > 0 implies exactly 1 */
|
||||
@@ -8479,7 +8483,11 @@ doset_simple(void)
|
||||
}
|
||||
if (go.opt_need_promptstyle)
|
||||
adjust_menu_promptstyle(WIN_INVEN, &iflags.menu_headings);
|
||||
/*
|
||||
if (go.opt_reset_customizations) {
|
||||
reset_customizations();
|
||||
docrt_flags(opt_crt_flags);
|
||||
}
|
||||
/*
|
||||
* I don't think the status window requires updating between
|
||||
* simplemenu iterations.
|
||||
if (disp.botl || disp.botlx) {
|
||||
@@ -8729,6 +8737,10 @@ doset(void) /* changing options via menu by Per Liboriussen */
|
||||
if (go.opt_need_glyph_reset) {
|
||||
reset_glyphmap(gm_optionchange);
|
||||
}
|
||||
if (go.opt_reset_customizations) {
|
||||
reset_customizations();
|
||||
docrt();
|
||||
}
|
||||
if (go.opt_need_redraw) {
|
||||
check_gold_symbol();
|
||||
reglyph_darkroom();
|
||||
|
||||
@@ -1094,19 +1094,6 @@ do_symset(boolean rogueflag)
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
extern glyph_map glyphmap[MAX_GLYPH];
|
||||
|
||||
void
|
||||
clear_all_glyphmap_colors(void)
|
||||
{
|
||||
int glyph;
|
||||
|
||||
for (glyph = 0; glyph < MAX_GLYPH; ++glyph) {
|
||||
if (glyphmap[glyph].customcolor)
|
||||
glyphmap[glyph].customcolor = 0;
|
||||
}
|
||||
}
|
||||
|
||||
RESTORE_WARNING_FORMAT_NONLITERAL
|
||||
|
||||
/*symbols.c*/
|
||||
|
||||
Reference in New Issue
Block a user