remove non-utf8 hacks from mapper.

correclty refresh map window after listboxes close.
This commit is contained in:
Enno Rehling 2021-02-21 22:32:40 +01:00
parent 979f2f7b6e
commit df4317f9f1
4 changed files with 8 additions and 56 deletions

View file

@ -188,7 +188,7 @@ static void lua_paint_info(struct window *wnd, const struct state *st)
int size = getmaxx(win) - 2; int size = getmaxx(win) - 2;
int line = 0, maxline = getmaxy(win) - 2; int line = 0, maxline = getmaxy(win) - 2;
const char *str = result; const char *str = result;
wxborder(win); box(win, 0, 0);
while (*str && line < maxline) { while (*str && line < maxline) {
const char *end = strchr(str, '\n'); const char *end = strchr(str, '\n');

View file

@ -4,7 +4,6 @@
#endif #endif
#endif #endif
#include <curses.h> #include <curses.h>
#define CURSES_UTF8
#include "gmtool.h" #include "gmtool.h"
#include "direction.h" #include "direction.h"
@ -59,32 +58,6 @@ state *current_state = NULL;
#define IFL_BUILDINGS (1<<3) #define IFL_BUILDINGS (1<<3)
static WINDOW *hstatus; static WINDOW *hstatus;
static int gm_utf8 = 1; /* does our curses support utf-8? */
static void unicode_remove_diacritics(const char *rp, char *wp) {
while (*rp) {
if (*rp & 0x80) {
size_t sz = 0;
unsigned char ch;
unicode_utf8_to_ascii(&ch, rp, &sz);
rp += sz;
*wp++ = (char)ch;
}
else {
*wp++ = *rp++;
}
}
*wp = 0;
}
static void simplify(const char* rp, char* wp) {
if (!gm_utf8) {
unicode_remove_diacritics(rp, wp);
}
else if (rp != wp) {
strcpy(wp, rp);
}
}
int umvwprintw(WINDOW *win, int y, int x, const char *format, ...) { int umvwprintw(WINDOW *win, int y, int x, const char *format, ...) {
char buffer[128]; char buffer[128];
@ -95,23 +68,15 @@ int umvwprintw(WINDOW *win, int y, int x, const char *format, ...) {
vsnprintf(buffer, sizeof(buffer) - 1, format, args); vsnprintf(buffer, sizeof(buffer) - 1, format, args);
va_end(args); va_end(args);
simplify(buffer, buffer);
return mvwaddstr(win, y, x, buffer); return mvwaddstr(win, y, x, buffer);
} }
int umvwaddnstr(WINDOW *w, int y, int x, const char * str, int len) { int umvwaddnstr(WINDOW *w, int y, int x, const char * str, int len) {
char buffer[128]; return mvwaddnstr(w, y, x, str, len);
simplify(str, buffer);
return mvwaddnstr(w, y, x, buffer, len);
} }
static void init_curses(void) static void init_curses(void)
{ {
#ifdef CURSES_UTF8
/* PDCurses from vcpkg is compiled with UTF8 (and WIDE) support */
gm_utf8 = 1;
#endif
initscr(); initscr();
if (has_colors() || force_color) { if (has_colors() || force_color) {
@ -119,13 +84,11 @@ static void init_curses(void)
short bcol = COLOR_BLACK; short bcol = COLOR_BLACK;
short hcol = COLOR_MAGENTA; short hcol = COLOR_MAGENTA;
start_color(); start_color();
#ifdef CURSES_UTF8
/* looks crap on putty with TERM=linux */ /* looks crap on putty with TERM=linux */
if (can_change_color()) { if (can_change_color()) {
init_color(COLOR_YELLOW, 1000, 1000, 0); init_color(COLOR_YELLOW, 1000, 1000, 0);
init_color(COLOR_CYAN, 0, 1000, 1000); init_color(COLOR_CYAN, 0, 1000, 1000);
} }
#endif
for (fg = 0; fg != 8; ++fg) { for (fg = 0; fg != 8; ++fg) {
for (bg = 0; bg != 2; ++bg) { for (bg = 0; bg != 2; ++bg) {
init_pair((short)(fg + 8 * bg), (short)fg, (short)(bg ? hcol : bcol)); init_pair((short)(fg + 8 * bg), (short)fg, (short)(bg ? hcol : bcol));
@ -397,15 +360,6 @@ static bool handle_info_region(window * wnd, state * st, int c)
return false; return false;
} }
int wxborder(WINDOW *win)
{
#ifdef CURSES_UTF8
return box(win, 0, 0);
#else
return wborder(win, '|', '|', '-', '-', '+', '+', '+', '+');
#endif
}
static void paint_info_region(window * wnd, const state * st) static void paint_info_region(window * wnd, const state * st)
{ {
WINDOW *win = wnd->handle; WINDOW *win = wnd->handle;
@ -415,7 +369,7 @@ static void paint_info_region(window * wnd, const state * st)
UNUSED_ARG(st); UNUSED_ARG(st);
werase(win); werase(win);
wxborder(win); box(win, 0, 0);
if (mr && mr->r) { if (mr && mr->r) {
int line = 0; int line = 0;
const region *r = mr->r; const region *r = mr->r;
@ -753,7 +707,7 @@ static faction *select_faction(state * st)
} }
selected = do_selection(ilist, "Select Faction", NULL, NULL); selected = do_selection(ilist, "Select Faction", NULL, NULL);
st->wnd_info->update |= 1; st->wnd_info->update |= 1;
st->wnd_map->update |= 1; st->wnd_map->update |= 3;
st->wnd_status->update |= 1; st->wnd_status->update |= 1;
if (selected == NULL) if (selected == NULL)
@ -778,7 +732,7 @@ static const terrain_type *select_terrain(state * st,
} }
selected = do_selection(ilist, "Terrain", NULL, NULL); selected = do_selection(ilist, "Terrain", NULL, NULL);
st->wnd_info->update |= 1; st->wnd_info->update |= 1;
st->wnd_map->update |= 1; st->wnd_map->update |= 3;
st->wnd_status->update |= 1; st->wnd_status->update |= 1;
if (selected == NULL) if (selected == NULL)
@ -1293,7 +1247,7 @@ static void handlekey(state * st, int c)
st->modified = 1; st->modified = 1;
st->wnd_info->update |= 1; st->wnd_info->update |= 1;
st->wnd_status->update |= 1; st->wnd_status->update |= 1;
st->wnd_map->update |= 1; st->wnd_map->update |= 3;
break; break;
case 'I': case 'I':
statusline(st->wnd_status->handle, "info-"); statusline(st->wnd_status->handle, "info-");
@ -1346,7 +1300,7 @@ static void handlekey(state * st, int c)
clear(); clear();
st->wnd_info->update |= 1; st->wnd_info->update |= 1;
st->wnd_status->update |= 1; st->wnd_status->update |= 1;
st->wnd_map->update |= 1; st->wnd_map->update |= 3;
} }
break; break;
case 12: /* Ctrl-L */ case 12: /* Ctrl-L */

View file

@ -80,8 +80,6 @@ extern "C" {
#define TWIDTH 2 /* width of tile */ #define TWIDTH 2 /* width of tile */
#define THEIGHT 1 /* height of tile */ #define THEIGHT 1 /* height of tile */
int wxborder(WINDOW *win);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View file

@ -101,7 +101,7 @@ list_selection *do_selection(list_selection * sel, const char *title,
wclrtoeol(wn); wclrtoeol(wn);
} }
wclrtobot(wn); wclrtobot(wn);
wxborder(wn); box(wn, 0, 0);
mvwprintw(wn, 0, 2, "[ %s ]", title); mvwprintw(wn, 0, 2, "[ %s ]", title);
update = false; update = false;
} }