summaryrefslogtreecommitdiff
path: root/debug.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-06-06 03:45:02 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-06-06 03:45:02 +0000
commit4529948edd67b88722ca39edbceb7da9042a0869 (patch)
treebb0dd7035f385e633be1943f56097724083688b7 /debug.c
parentdf05ad53fbc0ab1802367e5c410b39542ac57bc2 (diff)
debug.c: parse locale and filesystem codepages
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59022 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'debug.c')
-rw-r--r--debug.c25
1 files changed, 18 insertions, 7 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;
}