Skip to content

Commit

Permalink
debug.c: parse locale and filesystem codepages
Browse files Browse the repository at this point in the history
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59022 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
nobu committed Jun 6, 2017
1 parent df05ad5 commit 4529948
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 10 deletions.
25 changes: 18 additions & 7 deletions debug.c
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand All @@ -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))
Expand All @@ -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;
}
Expand Down
6 changes: 3 additions & 3 deletions localeinit.c
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand All @@ -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);
Expand Down Expand Up @@ -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);
Expand Down

0 comments on commit 4529948

Please sign in to comment.