aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--debug.c25
-rw-r--r--localeinit.c6
2 files changed, 21 insertions, 10 deletions
diff --git a/debug.c b/debug.c
index 296646cd53..392070a501 100644
--- a/debug.c
+++ b/debug.c
@@ -117,7 +117,7 @@ extern int ruby_w32_rtc_error;
#endif
#if defined _WIN32 || defined __CYGWIN__
#include <windows.h>
-UINT ruby_w32_codepage;
+UINT ruby_w32_codepage[2];
#endif
static void
@@ -131,7 +131,7 @@ set_debug_option(const char *str, int len, void *arg)
} \
} while (0)
#define NAME_MATCH_VALUE(name) \
- ((size_t)len > sizeof(name) && \
+ ((size_t)len >= sizeof(name) && \
strncmp(str, (name), sizeof(name)-1) == 0 && \
str[sizeof(name)-1] == '=' && \
(str += sizeof(name), len -= sizeof(name), 1))
@@ -144,14 +144,25 @@ set_debug_option(const char *str, int len, void *arg)
# endif
#endif
#if defined _WIN32 || defined __CYGWIN__
- {
+ if (NAME_MATCH_VALUE("codepage")) {
+ int i;
int ov;
size_t retlen;
unsigned long n;
- if (NAME_MATCH_VALUE("codepage") &&
- (n = ruby_scan_digits(str, len, 10, &retlen, &ov),
- (size_t)len == retlen && !ov)) {
- ruby_w32_codepage = (UINT)n;
+ for (i = 0; i < numberof(ruby_w32_codepage); ++i) {
+ n = ruby_scan_digits(str, len, 10, &retlen, &ov);
+ if (!ov && retlen) {
+ ruby_w32_codepage[i] = (UINT)n;
+ }
+ if ((size_t)len <= retlen) break;
+ str += retlen;
+ len -= retlen;
+ if (*str != ':') break;
+ ++str;
+ --len;
+ }
+ if (len > 0) {
+ fprintf(stderr, "ignored codepage option: `%.*s'\n", len, str);
}
return;
}
diff --git a/localeinit.c b/localeinit.c
index 544402b534..dc48d42561 100644
--- a/localeinit.c
+++ b/localeinit.c
@@ -22,7 +22,7 @@
#define SIZEOF_CP_NAME ((sizeof(UINT) * 8 / 3) + 4)
#define CP_FORMAT(buf, codepage) snprintf(buf, sizeof(buf), "CP%u", (codepage))
-extern UINT ruby_w32_codepage;
+extern UINT ruby_w32_codepage[2];
#endif
#ifndef NO_LOCALE_CHARMAP
@@ -45,7 +45,7 @@ locale_charmap(VALUE (*conv)(const char *))
codeset = nl_langinfo_codeset();
# endif
if (!codeset) {
- UINT codepage = ruby_w32_codepage;
+ UINT codepage = ruby_w32_codepage[0];
if (!codepage) codepage = GetConsoleCP();
if (!codepage) codepage = GetACP();
CP_FORMAT(cp, codepage);
@@ -122,7 +122,7 @@ Init_enc_set_filesystem_encoding(void)
idx = ENCINDEX_US_ASCII;
#elif defined _WIN32
char cp[SIZEOF_CP_NAME];
- const UINT codepage = ruby_w32_codepage ? ruby_w32_codepage :
+ const UINT codepage = ruby_w32_codepage[1] ? ruby_w32_codepage[1] :
AreFileApisANSI() ? GetACP() : GetOEMCP();
CP_FORMAT(cp, codepage);
idx = rb_enc_find_index(cp);