diff options
author | suke <suke@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-10-08 12:05:18 +0000 |
---|---|---|
committer | suke <suke@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-10-08 12:05:18 +0000 |
commit | 264ea648faa4177fbdb25eb972dd2468bed96980 (patch) | |
tree | 18a2a3106c44caa5251391dff4bb965861d4c507 | |
parent | c8e3a3cf2c00beacd1e325a5fefd632f0e6e2261 (diff) | |
download | ruby-264ea648faa4177fbdb25eb972dd2468bed96980.tar.gz ruby-264ea648faa4177fbdb25eb972dd2468bed96980.tar.xz ruby-264ea648faa4177fbdb25eb972dd2468bed96980.zip |
* ext/win32ole/win32ole.c (ole_init_cp): initialize WIN32OLE.codepage
according to Encoding.default_internal and
Encoding.default_external.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@19717 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | ext/win32ole/win32ole.c | 16 |
2 files changed, 18 insertions, 4 deletions
@@ -1,3 +1,9 @@ +Wed Oct 8 20:59:52 2008 Masaki Suketa <masaki.suketa@nifty.ne.jp> + + * ext/win32ole/win32ole.c (ole_init_cp): initialize WIN32OLE.codepage + according to Encoding.default_internal and + Encoding.default_external. + Wed Oct 8 17:02:21 2008 NARUSE, Yui <naruse@ruby-lang.org> * ext/json/lib/json/pure/generator.rb (utf8_to_json): diff --git a/ext/win32ole/win32ole.c b/ext/win32ole/win32ole.c index 0f07844de..915ffb35e 100644 --- a/ext/win32ole/win32ole.c +++ b/ext/win32ole/win32ole.c @@ -118,7 +118,7 @@ #define WC2VSTR(x) ole_wc2vstr((x), TRUE) -#define WIN32OLE_VERSION "1.3.3" +#define WIN32OLE_VERSION "1.3.4" typedef HRESULT (STDAPICALLTYPE FNCOCREATEINSTANCEEX) (REFCLSID, IUnknown*, DWORD, COSERVERINFO*, DWORD, MULTI_QI*); @@ -961,7 +961,10 @@ ole_init_cp() { UINT cp; rb_encoding *encdef; - encdef = rb_default_external_encoding(); + encdef = rb_default_internal_encoding(); + if (!encdef) { + encdef = rb_default_external_encoding(); + } cp = ole_encoding2cp(encdef); if (code_page_installed(cp)) { cWIN32OLE_cp = cp; @@ -2908,9 +2911,14 @@ code_page_installed(UINT cp) * call-seq: * WIN32OLE.codepage = CP * - * Sets current codepage. + * Sets current codepage. + * The WIN32OLE.codepage is initialized according to + * Encoding.default_internal. + * If Encoding.default_internal is nil then WIN32OLE.codepage + * is initialized according to Encoding.default_external. + * * WIN32OLE.codepage = WIN32OLE::CP_UTF8 - * WIN32OLE.codepage = 20932 + * WIN32OLE.codepage = 65001 */ static VALUE fole_s_set_code_page(VALUE self, VALUE vcp) |