[#34556] /(.)(.)/.match("ab").select {|v| true } is empty — Tanaka Akira <akr@...>
以下のように、MatchData#select でブロックが常に真なのに結果
[#34567] write to broken pipe on Linux — Nobuyoshi Nakada <nobu@...>
なかだです。
まつもと ゆきひろです
なかだです。
[#34571] Re: [ruby-cvs:23495] Ruby:r16255 (ruby_1_8, trunk): * range.c (range_step): allow float step bigger than zero but less — Tanaka Akira <akr@...>
In article <200805011435.m41EZFBL003014@ci.ruby-lang.org>,
[#34605] Array#mapがEnumeratorを返さない — rubikitch@...
るびきちです。
[#34623] Marshal.load( Marshal.dump( Float ) )の不一致@1.8 — "H.Holon" <holon@...>
H.Holonです。
[#34646] break in lambda — Tanaka Akira <akr@...>
lambda 直下に break があったとき、なにごともなかったかのよう
[#34647] fork 不可能な環境での test_argv0_noarg — wanabe <s.wanabe@...>
ワナベと申します。
まつもと ゆきひろです
こんにちは、なかむら(う)です。
まつもと ゆきひろです
こんにちは、なかむら(う)です。
須藤です。
[#34648] Bignum のメソッドからの bigzero_p — wanabe <s.wanabe@...>
ワナベと申します。
[#34676] removing Array#nitems {} — "Akinori MUSHA" <knu@...>
Array#nitems はnilでない要素を数えるメソッドですが、ブロックを
[#34691] ext/openssl and newer OpenSSL — Takahiro Kambe <taca@...>
こんにちは。
[#34692] [ruby1.9] fork と thread — Hidetoshi NAGAI <nagai@...>
永井@知能.九工大です.
[#34726] memory leak by Array#sort! — Tanaka Akira <akr@...>
以下のように、Array#sort! の中で配列を変更するとメモりリークします。
[#34739] net/imap uses Thread#raise — Tanaka Akira <akr@...>
net/imap が原因だと思うのですが、
前田です。
In article <704d5db90805210204o7aa80c00lfeb13a34230c2c03@mail.gmail.com>,
なかだです。
[#34741] Date.parse("##-##-##") — "Akinori MUSHA" <knu@...>
Date.parse("##.##.##") の ruby_1_8 における挙動が trunk とも
> Date.parse("##.##.##") の ruby_1_8 における挙動が trunk とも
[#34742] Ruby 1.8.7-preview3 has been released — "Akinori MUSHA" <knu@...>
Ruby 1.8.7-preview3 をリリースしました。
お疲れ様です。
At Mon, 19 May 2008 11:28:10 +0900,
In message <86k5hrow30.knu@iDaemons.org>
もう一つ追加です。
At Mon, 19 May 2008 18:55:42 +0900,
[#34751] benchmark result of reverse_complement — SASADA Koichi <ko1@...>
ささだです.
[#34758] Re: [ruby-cvs:23717] Ruby:r16477 (trunk): * regparse.c (PINC): use optimized enclen() instead of — SASADA Koichi <ko1@...>
ささだです.
遠藤と申します。
[#34768] Improvement of lazy sweep patch — authorNari <authornari@...>
authorNariです。
まつもと ゆきひろです
[#34775] (1..5).step(SimpleDelegator.new(1.5)) {|x| p x} differ from (1..5).step(1.5) {|x| p x} — Tanaka Akira <akr@...>
以下のように (1..5).step(1.5) {|x| p x} と
[#34800] Windows2000上でtrunkがビルドできない — KIMURA Koichi <kimura.koichi@...>
木村です。
こんにちは、なかむら(う)です。
木村です。
木村です。
こんにちは、なかむら(う)です。
木村です。
こんにちは、なかむら(う)です。
[#34810] -Wall — SASADA Koichi <ko1@...>
ささだです.
[#34830] return value of pp — "Yusuke ENDOH" <mame@...>
遠藤です。
[#34877] [Ruby 1.9 - Bug #11] prelude.c compilation problem on mswin32 — redmine@...
Issue #11 has been updated by Usaku NAKAMURA.
[#34883] [#19002] RUBY_* constants — Kazuhiro NISHIYAMA <zn@...>
西山和広です。
[#34889] Ruby 1.8.7-preview4 test-all failed in OpenSSL::TestSSL — Nobuhiro IMAI <nov@...>
いまいです。
Nobuhiro IMAI さんは書きました:
At Sat, 31 May 2008 21:06:47 +0900,
この話題についていろいろ試していて気付いたのですが
[ruby-dev:34836] Dir.entriesのエンコーディング
成瀬です。 [ruby-list:44877] から ruby-dev に移動します。 やっと以前出た仕様の案を一通り実装できました。 こんな感じでどうでしょう。 * Dir.open, Dir.foreach, Dir.entries にオプションのハッシュを渡せるようになった。 * :external_encoding でファイルシステムのエンコーディングを指定する。 デフォルトは rb_locale_encoding()。 * :internal_encoding で受け取るリストのエンコーディングを指定する。 デフォルトは dirname のエンコーディング。 但し、dirname のエンコーディングが US-ASCII または ASCII-8BIT の場合は変換しない -- NARUSE, Yui <naruse@airemix.jp>
Attachments (1)
--- dir.c (revision 16562)
+++ dir.c (working copy)
@@ -12,6 +12,7 @@
**********************************************************************/
#include "ruby/ruby.h"
+#include "ruby/encoding.h"
#include <sys/types.h>
#include <sys/stat.h>
@@ -342,6 +343,8 @@ VALUE rb_cDir;
struct dir_data {
DIR *dir;
char *path;
+ rb_encoding *intenc;
+ rb_encoding *extenc;
};
static void
@@ -364,6 +367,8 @@ dir_s_alloc(VALUE klass)
dirp->dir = NULL;
dirp->path = NULL;
+ dirp->intenc = NULL;
+ dirp->extenc = NULL;
return obj;
}
@@ -375,16 +380,52 @@ dir_s_alloc(VALUE klass)
* Returns a new directory object for the named directory.
*/
static VALUE
-dir_initialize(VALUE dir, VALUE dirname)
+dir_initialize(int argc, VALUE *argv, VALUE dir)
{
struct dir_data *dp;
-
+ static rb_encoding *fs_enc;
+ rb_encoding *dirname_enc, *intenc, *extenc;
+ VALUE dirname, opt;
+ static VALUE sym_intenc, sym_extenc;
+
+ if (!sym_intenc) {
+ sym_intenc = ID2SYM(rb_intern("internal_encoding"));
+ sym_extenc = ID2SYM(rb_intern("external_encoding"));
+ fs_enc = rb_locale_encoding();
+ }
+
+ intenc = NULL;
+ extenc = fs_enc;
+ rb_scan_args(argc, argv, "11", &dirname, &opt);
+ if (!NIL_P(opt)) {
+ VALUE v;
+ opt = rb_check_convert_type(opt, T_HASH, "Hash", "to_hash");
+ v = rb_hash_aref(opt, sym_intenc);
+ if (!NIL_P(v)) intenc = rb_to_encoding(v);
+ v = rb_hash_aref(opt, sym_extenc);
+ if (!NIL_P(v)) extenc = rb_to_encoding(v);
+ }
+
+ dirname_enc = rb_enc_get(dirname);
+ if (intenc);
+ else if (rb_usascii_encoding() == dirname_enc
+ || rb_ascii8bit_encoding() == dirname_enc
+ || extenc == dirname_enc) {
+ intenc = NULL;
+ }
+ else {
+ intenc = dirname_enc;
+ dirname = rb_str_transcode(dirname, rb_enc_from_encoding(extenc));
+ }
FilePathValue(dirname);
+
Data_Get_Struct(dir, struct dir_data, dp);
if (dp->dir) closedir(dp->dir);
if (dp->path) free(dp->path);
dp->dir = NULL;
dp->path = NULL;
+ dp->intenc = intenc;
+ dp->extenc = extenc;
dp->dir = opendir(RSTRING_PTR(dirname));
if (dp->dir == NULL) {
if (errno == EMFILE || errno == ENFILE) {
@@ -412,12 +453,12 @@ dir_initialize(VALUE dir, VALUE dirname)
* block.
*/
static VALUE
-dir_s_open(VALUE klass, VALUE dirname)
+dir_s_open(int argc, VALUE *argv, VALUE klass)
{
struct dir_data *dp;
VALUE dir = Data_Make_Struct(klass, struct dir_data, 0, free_dir, dp);
- dir_initialize(dir, dirname);
+ dir_initialize(argc, argv, dir);
if (rb_block_given_p()) {
return rb_ensure(rb_yield, dir, dir_close, dir);
}
@@ -445,6 +486,16 @@ dir_check(VALUE dir)
if (dirp->dir == NULL) dir_closed();\
} while (0)
+static VALUE
+dir_enc_str(VALUE str, struct dir_data *dirp)
+{
+ rb_enc_associate(str, dirp->extenc);
+ if (dirp->intenc) {
+ str = rb_str_transcode(str, rb_enc_from_encoding(dirp->intenc));
+ }
+ return str;
+}
+
/*
* call-seq:
* dir.inspect => string
@@ -483,7 +534,7 @@ dir_path(VALUE dir)
Data_Get_Struct(dir, struct dir_data, dirp);
if (!dirp->path) return Qnil;
- return rb_str_new2(dirp->path);
+ return dir_enc_str(rb_str_new2(dirp->path), dirp);
}
/*
@@ -508,7 +559,7 @@ dir_read(VALUE dir)
errno = 0;
dp = readdir(dirp->dir);
if (dp) {
- return rb_tainted_str_new(dp->d_name, NAMLEN(dp));
+ return dir_enc_str(rb_tainted_str_new(dp->d_name, NAMLEN(dp)), dirp);
}
else if (errno == 0) { /* end of stream */
return Qnil;
@@ -546,7 +597,7 @@ dir_each(VALUE dir)
GetDIR(dir, dirp);
rewinddir(dirp->dir);
for (dp = readdir(dirp->dir); dp != NULL; dp = readdir(dirp->dir)) {
- rb_yield(rb_tainted_str_new(dp->d_name, NAMLEN(dp)));
+ rb_yield(dir_enc_str(rb_tainted_str_new(dp->d_name, NAMLEN(dp)), dirp));
if (dirp->dir == NULL) dir_closed();
}
return dir;
@@ -1685,9 +1736,9 @@ dir_s_glob(int argc, VALUE *argv, VALUE
}
static VALUE
-dir_open_dir(VALUE path)
+dir_open_dir(int argc, VALUE *argv)
{
- VALUE dir = rb_funcall(rb_cDir, rb_intern("open"), 1, path);
+ VALUE dir = rb_funcall2(rb_cDir, rb_intern("open"), argc, argv);
if (TYPE(dir) != T_DATA ||
RDATA(dir)->dfree != (RUBY_DATA_FUNC)free_dir) {
@@ -1716,12 +1767,12 @@ dir_open_dir(VALUE path)
*
*/
static VALUE
-dir_foreach(VALUE io, VALUE dirname)
+dir_foreach(int argc, VALUE *argv, VALUE io)
{
VALUE dir;
- RETURN_ENUMERATOR(io, 1, &dirname);
- dir = dir_open_dir(dirname);
+ RETURN_ENUMERATOR(io, argc, argv);
+ dir = dir_open_dir(argc, argv);
rb_ensure(dir_each, dir, dir_close, dir);
return Qnil;
}
@@ -1738,11 +1789,11 @@ dir_foreach(VALUE io, VALUE dirname)
*
*/
static VALUE
-dir_entries(VALUE io, VALUE dirname)
+dir_entries(int argc, VALUE *argv, VALUE io)
{
VALUE dir;
- dir = dir_open_dir(dirname);
+ dir = dir_open_dir(argc, argv);
return rb_ensure(rb_Array, dir, dir_close, dir);
}
@@ -1867,11 +1918,11 @@ Init_Dir(void)
rb_include_module(rb_cDir, rb_mEnumerable);
rb_define_alloc_func(rb_cDir, dir_s_alloc);
- rb_define_singleton_method(rb_cDir, "open", dir_s_open, 1);
+ rb_define_singleton_method(rb_cDir, "open", dir_s_open, -1);
rb_define_singleton_method(rb_cDir, "foreach", dir_foreach, 1);
- rb_define_singleton_method(rb_cDir, "entries", dir_entries, 1);
+ rb_define_singleton_method(rb_cDir, "entries", dir_entries, -1);
- rb_define_method(rb_cDir,"initialize", dir_initialize, 1);
+ rb_define_method(rb_cDir,"initialize", dir_initialize, -1);
rb_define_method(rb_cDir,"path", dir_path, 0);
rb_define_method(rb_cDir,"inspect", dir_inspect, 0);
rb_define_method(rb_cDir,"read", dir_read, 0);