[#47033] [ruby-trunk - Bug #8749][Open] Readline.readline stops STDOUT? — "no6v (Nobuhiro IMAI)" <nov@...>
9 messages
2013/08/07
[#47036] Re: [ruby-trunk - Bug #8749][Open] Readline.readline stops STDOUT?
— Tanaka Akira <akr@...>
2013/08/07
2013/8/7 no6v (Nobuhiro IMAI) <[email protected]>:
[#47564] [ruby-trunk - Bug #8719][Open] r42096 make bm_app_factorial.rb slow — "authorNari (Narihiro Nakamura)" <authorNari@...>
4 messages
2013/08/02
[#47565] [ruby-trunk - Bug #8719] r42096 make bm_app_factorial.rb slow
— "authorNari (Narihiro Nakamura)" <authorNari@...>
2013/08/02
[#47569] [ruby-trunk - Feature #8726][Open] Class#source_location — "takiuchi (Genki Takiuchi)" <[email protected]>
14 messages
2013/08/03
[#47574] Re: [ruby-trunk - Feature #8726][Open] Class#source_location
— KOSAKI Motohiro <kosaki.motohiro@...>
2013/08/03
> Classオブジェクトが生成された場所を返す Class#source_location メソッドの実装を希望いたします。
[#47575] Re: [ruby-trunk - Feature #8726][Open] Class#source_location
— KOSAKI Motohiro <kosaki.motohiro@...>
2013/08/03
> なるせさん、わたし、あのバックトレースの整形処理がイマイチ理解できんのだが、
[#47609] Re: [ruby-cvs:49669] naruse:r42527 (trunk): refix r42525 set stdio_file only if stdio — Tanaka Akira <akr@...>
2013/8/12 <[email protected]>:
7 messages
2013/08/12
[#47610] Re: [ruby-cvs:49669] naruse:r42527 (trunk): refix r42525 set stdio_file only if stdio
— "NARUSE, Yui" <naruse@...>
2013/08/12
あぁ、[ruby-dev:47608]見てませんでした。
[#47611] Re: [ruby-cvs:49669] naruse:r42527 (trunk): refix r42525 set stdio_file only if stdio
— Tanaka Akira <akr@...>
2013/08/12
2013年8月12日 11:38 NARUSE, Yui <[email protected]>:
[#47614] Re: [ruby-cvs:49669] naruse:r42527 (trunk): refix r42525 set stdio_file only if stdio
— "NARUSE, Yui" <naruse@...>
2013/08/12
editline の問題は、editlineにはrl_getcがなく、かつreadline.cで、
[#47620] Ruby 2.1 開発者会議 2013-08-31 のお知らせ — "NARUSE, Yui" <naruse@...>
かなり暑いですが、こんにちは。
5 messages
2013/08/14
[#47649] Re: [ruby-changes:30564] akr:r42643 (trunk): * process.c (rb_proc_times): Use RB_GC_GUARD to guard objects from GC. — SASADA Koichi <ko1@...>
akr さん
4 messages
2013/08/21
[#47650] Re: [ruby-changes:30564] akr:r42643 (trunk): * process.c (rb_proc_times): Use RB_GC_GUARD to guard objects from GC.
— Tanaka Akira <akr@...>
2013/08/21
2013/8/21 SASADA Koichi <[email protected]>:
[#47663] Re: [ruby-core:56878] [ruby-trunk - misc #8835][Open] Introducing a semantic versioning scheme and branching policy — "Akinori MUSHA" <knu@...>
At Fri, 30 Aug 2013 21:49:34 +0900,
6 messages
2013/08/30
[#47664] Re: [ruby-core:56878] [ruby-trunk - misc #8835][Open] Introducing a semantic versioning scheme and branching policy
— KOSAKI Motohiro <kosaki.motohiro@...>
2013/08/30
2013/8/30 Akinori MUSHA <[email protected]>:
[ruby-dev:47655] Re: [ruby-trunk - Bug #8810][Open] SolarisでGDBM.open内で処理がブロックしたらTimeout.timeout が効かない
From:
KOSAKI Motohiro <kosaki.motohiro@...>
Date:
2013-08-23 23:24:29 UTC
List:
ruby-dev #47655
2013/8/22 ngoto (Naohisa Goto) <[email protected]>: > > Issue #8810 has been reported by ngoto (Naohisa Goto). > > ---------------------------------------- > Bug #8810: SolarisでGDBM.open内で処理がブロックしたらTimeout.timeout が効かない > https://bugs.ruby-lang.org/issues/8810 > > Author: ngoto (Naohisa Goto) > Status: Open > Priority: Normal > Assignee: > Category: ext > Target version: > ruby -v: - > Backport: 1.9.3: UNKNOWN, 2.0.0: UNKNOWN > > > GDBM.open内で処理がブロックした場合にTimeout.timeoutが効きません。 > > 再現方法は、Solarisにて、以下のようにGDBMをオープンしたままにして、 > > $ ruby -r gdbm -e 'db = GDBM.open("/var/tmp/tmpdb"); gets' > > 同一マシンで別のシェルで > > $ ruby -r gdbm -r timeout -e 'Timeout.timeout(5) { db = GDBM.open("/var/tmp/tmpdb") }' > > を実行しても、タイムアウトすることなく後者のGDBM.openがブロックし続けて終わりません。 > > Solarisだけでなく、Linux上にて、以下のように無理やりflockを使わないようconfigureしてmakeしたlibgdbm.soを使用した場合でも同様に再現しました。 ちらっと見たのですが、これはgdbmを直さないとどうしようもないような 以下コメント付きソースの抜粋。 int _gdbm_lock_file (GDBM_FILE dbf) { #if HAVE_FCNTL_LOCK struct flock fl; #endif int lock_val = -1; #if HAVE_FLOCK // 最初にflockを試す if (dbf->read_write == GDBM_READER) lock_val = flock (dbf->desc, LOCK_SH + LOCK_NB); // この時はLOCK_NB使う else lock_val = flock (dbf->desc, LOCK_EX + LOCK_NB); if ((lock_val == -1) && (errno == EWOULDBLOCK)) { dbf->lock_type = LOCKING_NONE; return lock_val; } else if (lock_val != -1) { dbf->lock_type = LOCKING_FLOCK; return lock_val; } #endif // 次に lockf ためす #if HAVE_LOCKF /* Mask doesn't matter for lockf. */ lock_val = lockf (dbf->desc, F_LOCK, (off_t)0L); // なぜか F_TLOCK つけない if ((lock_val == -1) && (errno == EDEADLK)) { dbf->lock_type = LOCKING_NONE; return lock_val; } else if (lock_val != -1) { dbf->lock_type = LOCKING_LOCKF; return lock_val; } #endif // 最後に fcntl ためす #if HAVE_FCNTL_LOCK /* If we're still here, try fcntl. */ if (dbf->read_write == GDBM_READER) fl.l_type = F_RDLCK; else fl.l_type = F_WRLCK; fl.l_whence = SEEK_SET; fl.l_start = fl.l_len = (off_t)0L; lock_val = fcntl (dbf->desc, F_SETLK, &fl); // こんどはF_SETLKなので待たない if (lock_val != -1) dbf->lock_type = LOCKING_FCNTL; #endif if (lock_val == -1) dbf->lock_type = LOCKING_NONE; return lock_val; }