From: bugrabarin@... Date: 2014-04-03T20:50:31+00:00 Subject: [ruby-core:61845] [ruby-trunk - Bug #9699] [Open] Cannot require .so file on Windows if the file path is unicode (Includes patch) Issue #9699 has been reported by Bugra Barin. ---------------------------------------- Bug #9699: Cannot require .so file on Windows if the file path is unicode (Includes patch) https://bugs.ruby-lang.org/issues/9699 * Author: Bugra Barin * Status: Open * 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: UNKNOWN, 2.1: UNKNOWN ---------------------------------------- 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/