From 8a29497f7dac90344db8468abeb00f5d3d5b7af1 Mon Sep 17 00:00:00 2001 From: Stas Degteff Date: Sun, 4 Feb 2007 09:14:12 +0000 Subject: [PATCH] Use CP437 as default charset instead IBMPC and LATIN-1; use CP850 as DOS-charset for IBMPC --- goldlib/gall/gcharset.cpp | 12 +++++++++--- goldlib/gall/gcharset.h | 4 +++- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/goldlib/gall/gcharset.cpp b/goldlib/gall/gcharset.cpp index de6163d..40b73e9 100644 --- a/goldlib/gall/gcharset.cpp +++ b/goldlib/gall/gcharset.cpp @@ -42,6 +42,7 @@ #include #include #endif +#include static char charsetbuf[256]; @@ -51,7 +52,7 @@ const char *get_charset(void) int segment, selector; __dpmi_regs regs; - strcpy(charsetbuf, "IBMPC"); + strcpy(charsetbuf, DEFAULT_CHARSET); if ((segment = __dpmi_allocate_dos_memory(3, &selector)) != -1) { regs.h.ah = 0x65; regs.h.al = 0x01; @@ -73,20 +74,23 @@ const char *get_charset(void) ULONG CCP[8]; ULONG cb; - strcpy(charsetbuf, "IBMPC"); + strcpy(charsetbuf, DEFAULT_CHARSET); if(DosQueryCp(sizeof (CCP), CCP, &cb) == 0) sprintf(charsetbuf, "CP%i", CCP[0]); #else const char *cp; - strcpy(charsetbuf, "LATIN-1"); + strcpy(charsetbuf, DEFAULT_CHARSET); cp = setlocale(LC_CTYPE, ""); if((cp != NULL) and ((cp = strchr(cp, '.')) != NULL)) { cp++; +/* Commented on reason: Non-standard charset values isn't used in unix locale, may be in very old implementations? +// Check this. if(strieql(cp, "KOI8R") or strieql(cp, "KOI8")) cp = "KOI8-R"; if(strieql(cp, "KOI8U")) cp = "KOI8-U"; +*/ strxcpy(charsetbuf, cp, sizeof(charsetbuf)); } #endif @@ -97,11 +101,13 @@ const char *get_dos_charset(const char *cpfrom) { #if defined(__WIN32__) || defined(__MSDOS__) || defined(__OS2__) (void)cpfrom; // These platforms use DOS CP on console, so ignore request + // Another way is possible in Windows: get charset using GetANSICP() return ""; #else static const struct _cpmap { char *from, *to; } cpmap[] = { + { "IBMPC", "CP850" }, { "LATIN-1", "CP437" }, { "KOI8", "CP866" }, { "KOI8-R", "CP866" }, diff --git a/goldlib/gall/gcharset.h b/goldlib/gall/gcharset.h index f87da77..d36d220 100644 --- a/goldlib/gall/gcharset.h +++ b/goldlib/gall/gcharset.h @@ -27,7 +27,9 @@ #ifndef __gcharset_h #define __gcharset_h - +// ------------------------------------------------------------------ +// Charset is set to this value if charset can't be taken from OS +#define DEFAULT_CHARSET "CP437" // ------------------------------------------------------------------ const char *get_charset(void);