From: nagachika00@... Date: 2014-06-16T15:43:54+00:00 Subject: [ruby-core:63193] [ruby-trunk - Bug #9699] Cannot require .so file on Windows if the file path is unicode (Includes patch) Issue #9699 has been updated by Tomoyuki Chikanaga. Backport changed from 2.0.0: REQUIRED, 2.1: REQUIRED to 2.0.0: REQUIRED, 2.1: DONE r45521, r45523 and r45551 were backported into `ruby_2_1` at r46450. ---------------------------------------- Bug #9699: Cannot require .so file on Windows if the file path is unicode (Includes patch) https://bugs.ruby-lang.org/issues/9699#change-47244 * Author: Bugra Barin * Status: Closed * Priority: Normal * Assignee: cruby-windows * Category: platform/windows * Target version: current: 2.2.0 * ruby -v: 2.0.0 and later * Backport: 2.0.0: REQUIRED, 2.1: DONE ---------------------------------------- It doesn't seem possible to load a C extension that is inside a non-ascii path. To reproduce: - Extract the attached zip file (with a decent unzip program such as 7-zip, that preserves unicode paths) - cd to where you extracted - launch irb - require './foo.rb' (All this does is require a simple so file inside the folder '���������') - You'll see a failure The culprit is in function dln_load, it uses the ANSI version of LoadLibrary and passes in the char* path given to the function. My patch converts it to wide char and uses LoadLibraryW. I have assumed that the given path is UTF-8 encoded, which seems to work but I am not sure if this is a safe assumption. I hope the patch is in the right format, I wasn't sure. Thanks for your time! Bugra ---Files-------------------------------- require_so_bug_win32.zip (16.3 KB) dln_load.patch (1.41 KB) -- https://bugs.ruby-lang.org/