forked from github/server
Merge pull request #535 from ennorehling/gmtool-unicode
gmtool: clumsy codepage translation
This commit is contained in:
commit
f83770dca8
5 changed files with 90 additions and 17 deletions
71
src/gmtool.c
71
src/gmtool.c
|
@ -51,6 +51,7 @@
|
||||||
#include <items/itemtypes.h>
|
#include <items/itemtypes.h>
|
||||||
|
|
||||||
#include <util/log.h>
|
#include <util/log.h>
|
||||||
|
#include <util/unicode.h>
|
||||||
#include <util/lists.h>
|
#include <util/lists.h>
|
||||||
#include <util/rng.h>
|
#include <util/rng.h>
|
||||||
#include <util/base36.h>
|
#include <util/base36.h>
|
||||||
|
@ -77,6 +78,62 @@ state *current_state = NULL;
|
||||||
|
|
||||||
static WINDOW *hstatus;
|
static WINDOW *hstatus;
|
||||||
|
|
||||||
|
#ifdef STDIO_CP
|
||||||
|
int gm_codepage = STDIO_CP;
|
||||||
|
#else
|
||||||
|
int gm_codepage = -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void unicode_remove_diacritics(const char *rp, char *wp) {
|
||||||
|
while (*rp) {
|
||||||
|
if (gm_codepage >=0 && *rp & 0x80) {
|
||||||
|
size_t sz = 0;
|
||||||
|
char ch;
|
||||||
|
switch (gm_codepage) {
|
||||||
|
case 1252:
|
||||||
|
unicode_utf8_to_cp1252(&ch, rp, &sz);
|
||||||
|
break;
|
||||||
|
case 437:
|
||||||
|
unicode_utf8_to_cp437(&ch, rp, &sz);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
unicode_utf8_to_ascii(&ch, rp, &sz);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
rp += sz;
|
||||||
|
*wp++ = ch;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
*wp++ = *rp++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*wp = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void simplify(const char *rp, char *wp) {
|
||||||
|
unicode_remove_diacritics(rp, wp);
|
||||||
|
}
|
||||||
|
|
||||||
|
int umvwprintw(WINDOW *win, int y, int x, const char *format, ...) {
|
||||||
|
char buffer[128];
|
||||||
|
va_list args;
|
||||||
|
|
||||||
|
va_start(args, format);
|
||||||
|
memset(buffer, 0, sizeof(buffer));
|
||||||
|
vsnprintf(buffer, sizeof(buffer)-1, format, args);
|
||||||
|
va_end(args);
|
||||||
|
|
||||||
|
simplify(buffer, buffer);
|
||||||
|
|
||||||
|
return mvwaddstr(win, y, x, buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
int umvwaddnstr(WINDOW *w, int y, int x, const char * str, int len) {
|
||||||
|
char buffer[128];
|
||||||
|
simplify(str, buffer);
|
||||||
|
return mvwaddnstr(w, y, x, buffer, len);
|
||||||
|
}
|
||||||
|
|
||||||
static void init_curses(void)
|
static void init_curses(void)
|
||||||
{
|
{
|
||||||
int fg, bg;
|
int fg, bg;
|
||||||
|
@ -354,7 +411,7 @@ static void paint_status(window * wnd, const state * st)
|
||||||
terrain = mr->r->terrain->_name;
|
terrain = mr->r->terrain->_name;
|
||||||
}
|
}
|
||||||
cnormalize(&st->cursor, &nx, &ny);
|
cnormalize(&st->cursor, &nx, &ny);
|
||||||
mvwprintw(win, 0, 0, "%4d %4d | %.4s | %.20s (%d)", nx, ny, terrain, name,
|
umvwprintw(win, 0, 0, "%4d %4d | %.4s | %.20s (%d)", nx, ny, terrain, name,
|
||||||
uid);
|
uid);
|
||||||
wclrtoeol(win);
|
wclrtoeol(win);
|
||||||
}
|
}
|
||||||
|
@ -377,13 +434,13 @@ static void paint_info_region(window * wnd, const state * st)
|
||||||
if (mr && mr->r) {
|
if (mr && mr->r) {
|
||||||
const region *r = mr->r;
|
const region *r = mr->r;
|
||||||
if (r->land) {
|
if (r->land) {
|
||||||
mvwaddnstr(win, line++, 1, (char *)r->land->name, size);
|
umvwaddnstr(win, line++, 1, (char *)r->land->name, size);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
mvwaddnstr(win, line++, 1, r->terrain->_name, size);
|
umvwaddnstr(win, line++, 1, r->terrain->_name, size);
|
||||||
}
|
}
|
||||||
line++;
|
line++;
|
||||||
mvwprintw(win, line++, 1, "%s, age %d", r->terrain->_name, r->age);
|
umvwprintw(win, line++, 1, "%s, age %d", r->terrain->_name, r->age);
|
||||||
if (r->land) {
|
if (r->land) {
|
||||||
mvwprintw(win, line++, 1, "$:%6d P:%5d", rmoney(r), rpeasants(r));
|
mvwprintw(win, line++, 1, "$:%6d P:%5d", rmoney(r), rpeasants(r));
|
||||||
mvwprintw(win, line++, 1, "H:%6d %s:%5d", rhorses(r),
|
mvwprintw(win, line++, 1, "H:%6d %s:%5d", rhorses(r),
|
||||||
|
@ -398,7 +455,7 @@ static void paint_info_region(window * wnd, const state * st)
|
||||||
wattroff(win, A_BOLD | COLOR_PAIR(COLOR_YELLOW));
|
wattroff(win, A_BOLD | COLOR_PAIR(COLOR_YELLOW));
|
||||||
for (sh = r->ships; sh && line < maxline; sh = sh->next) {
|
for (sh = r->ships; sh && line < maxline; sh = sh->next) {
|
||||||
mvwprintw(win, line, 1, "%.4s ", itoa36(sh->no));
|
mvwprintw(win, line, 1, "%.4s ", itoa36(sh->no));
|
||||||
mvwaddnstr(win, line++, 6, (char *)sh->type->_name, size - 5);
|
umvwaddnstr(win, line++, 6, (char *)sh->type->_name, size - 5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (r->units && (st->info_flags & IFL_FACTIONS)) {
|
if (r->units && (st->info_flags & IFL_FACTIONS)) {
|
||||||
|
@ -409,7 +466,7 @@ static void paint_info_region(window * wnd, const state * st)
|
||||||
for (u = r->units; u && line < maxline; u = u->next) {
|
for (u = r->units; u && line < maxline; u = u->next) {
|
||||||
if (!fval(u->faction, FFL_MARK)) {
|
if (!fval(u->faction, FFL_MARK)) {
|
||||||
mvwprintw(win, line, 1, "%.4s ", itoa36(u->faction->no));
|
mvwprintw(win, line, 1, "%.4s ", itoa36(u->faction->no));
|
||||||
mvwaddnstr(win, line++, 6, (char *)u->faction->name, size - 5);
|
umvwaddnstr(win, line++, 6, (char *)u->faction->name, size - 5);
|
||||||
fset(u->faction, FFL_MARK);
|
fset(u->faction, FFL_MARK);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -424,7 +481,7 @@ static void paint_info_region(window * wnd, const state * st)
|
||||||
wattroff(win, A_BOLD | COLOR_PAIR(COLOR_YELLOW));
|
wattroff(win, A_BOLD | COLOR_PAIR(COLOR_YELLOW));
|
||||||
for (u = r->units; u && line < maxline; u = u->next) {
|
for (u = r->units; u && line < maxline; u = u->next) {
|
||||||
mvwprintw(win, line, 1, "%.4s ", itoa36(u->no));
|
mvwprintw(win, line, 1, "%.4s ", itoa36(u->no));
|
||||||
mvwaddnstr(win, line++, 6, unit_getname(u), size - 5);
|
umvwaddnstr(win, line++, 6, unit_getname(u), size - 5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,7 @@ extern "C" {
|
||||||
void run_mapper(void);
|
void run_mapper(void);
|
||||||
|
|
||||||
extern int force_color;
|
extern int force_color;
|
||||||
|
extern int gm_codepage;
|
||||||
|
|
||||||
struct state *state_open(void);
|
struct state *state_open(void);
|
||||||
void state_close(struct state *);
|
void state_close(struct state *);
|
||||||
|
|
|
@ -96,6 +96,7 @@ static void parse_config(const char *filename)
|
||||||
#ifdef USE_CURSES
|
#ifdef USE_CURSES
|
||||||
/* only one value in the [editor] section */
|
/* only one value in the [editor] section */
|
||||||
force_color = iniparser_getint(d, "editor:color", force_color);
|
force_color = iniparser_getint(d, "editor:color", force_color);
|
||||||
|
gm_codepage = iniparser_getint(d, "editor:codepage", gm_codepage);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -518,10 +518,22 @@ size_t * length)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Convert a UTF-8 encoded character to ASCII, with '?' replacements. */
|
||||||
|
int unicode_utf8_to_ascii(char *cp_character, const utf8_t * utf8_string,
|
||||||
|
size_t *length)
|
||||||
|
{
|
||||||
|
int result = unicode_utf8_to_cp437(cp_character, utf8_string, length);
|
||||||
|
if (result == 0) {
|
||||||
|
if (*length > 1) {
|
||||||
|
*cp_character = '?';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
/** Convert a UTF-8 encoded character to CP1252. */
|
/** Convert a UTF-8 encoded character to CP1252. */
|
||||||
int
|
int unicode_utf8_to_cp1252(char *cp_character, const utf8_t * utf8_string,
|
||||||
unicode_utf8_to_cp1252(char *cp_character, const utf8_t * utf8_string,
|
size_t * length)
|
||||||
size_t * length)
|
|
||||||
{
|
{
|
||||||
ucs4_t ucs4_character;
|
ucs4_t ucs4_character;
|
||||||
int result;
|
int result;
|
||||||
|
|
|
@ -28,18 +28,20 @@ extern "C" {
|
||||||
typedef unsigned long ucs4_t;
|
typedef unsigned long ucs4_t;
|
||||||
typedef char utf8_t;
|
typedef char utf8_t;
|
||||||
|
|
||||||
extern int unicode_utf8_to_cp437(char *result, const utf8_t * utf8_string,
|
int unicode_utf8_to_cp437(char *result, const utf8_t * utf8_string,
|
||||||
size_t * length);
|
size_t * length);
|
||||||
extern int unicode_utf8_to_cp1252(char *result, const utf8_t * utf8_string,
|
int unicode_utf8_to_cp1252(char *result, const utf8_t * utf8_string,
|
||||||
size_t * length);
|
size_t * length);
|
||||||
extern int unicode_utf8_to_ucs4(ucs4_t * result, const utf8_t * utf8_string,
|
int unicode_utf8_to_ucs4(ucs4_t * result, const utf8_t * utf8_string,
|
||||||
size_t * length);
|
size_t * length);
|
||||||
extern int unicode_ucs4_to_utf8(utf8_t * result, size_t * size,
|
int unicode_ucs4_to_utf8(utf8_t * result, size_t * size,
|
||||||
ucs4_t ucs4_character);
|
ucs4_t ucs4_character);
|
||||||
extern int unicode_utf8_strcasecmp(const utf8_t * a, const utf8_t * b);
|
int unicode_utf8_to_ascii(char *cp_character, const utf8_t * utf8_string,
|
||||||
extern int unicode_latin1_to_utf8(utf8_t * out, size_t * outlen,
|
size_t *length);
|
||||||
|
int unicode_utf8_strcasecmp(const utf8_t * a, const utf8_t * b);
|
||||||
|
int unicode_latin1_to_utf8(utf8_t * out, size_t * outlen,
|
||||||
const char *in, size_t * inlen);
|
const char *in, size_t * inlen);
|
||||||
extern int unicode_utf8_tolower(utf8_t * out, size_t outlen,
|
int unicode_utf8_tolower(utf8_t * out, size_t outlen,
|
||||||
const utf8_t * in);
|
const utf8_t * in);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
Loading…
Reference in a new issue