From: nagachika00@... Date: 2014-04-10T13:24:46+00:00 Subject: [ruby-core:61945] [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: UNKNOWN, 2.1: UNKNOWN to 2.0.0: REQUIRED, 2.1: REQUIRED [for branch maintainers] r45523 depends on a new function introduced at r45521. And test script was fixed at r45551. ---------------------------------------- Bug #9699: Cannot require .so file on Windows if the file path is unicode (Includes patch) https://bugs.ruby-lang.org/issues/9699#change-46143 * 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: REQUIRED ---------------------------------------- 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/