[#44036] [ruby-trunk - Feature #6242][Open] Ruby should support lists — "shugo (Shugo Maeda)" <redmine@...>

20 messages 2012/04/01

[#44084] [ruby-trunk - Bug #6246][Open] 1.9.3-p125 intermittent segfault — "jshow (Jodi Showers)" <jodi@...>

22 messages 2012/04/02

[#44156] [ruby-trunk - Feature #6265][Open] Remove 'useless' 'concatenation' syntax — "rosenfeld (Rodrigo Rosenfeld Rosas)" <rr.rosas@...>

45 messages 2012/04/06

[#44163] [ruby-trunk - Bug #6266][Open] encoding related exception with recent integrated psych — "jonforums (Jon Forums)" <redmine@...>

10 messages 2012/04/06

[#44303] [ruby-trunk - Feature #6284][Open] Add composition for procs — "pabloh (Pablo Herrero)" <pablodherrero@...>

57 messages 2012/04/12

[#44349] [ruby-trunk - Feature #6293][Open] new queue / blocking queues — "tenderlovemaking (Aaron Patterson)" <aaron@...>

10 messages 2012/04/13

[#44402] [ruby-trunk - Feature #6308][Open] Eliminate delegation from WeakRef — "headius (Charles Nutter)" <headius@...>

20 messages 2012/04/17

[#44403] [ruby-trunk - Feature #6309][Open] Add a reference queue for weak references — "headius (Charles Nutter)" <headius@...>

15 messages 2012/04/17

[#44533] [ruby-trunk - Bug #6341][Open] SIGSEGV: Thread.new { fork { GC.start } }.join — "rudolf (r stu3)" <redmine@...>

24 messages 2012/04/22

[#44630] [ruby-trunk - Feature #6361][Open] Bitwise string operations — "MartinBosslet (Martin Bosslet)" <Martin.Bosslet@...>

31 messages 2012/04/26

[#44648] [ruby-trunk - Feature #6367][Open] #same? for Enumerable — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

16 messages 2012/04/26

[#44704] [ruby-trunk - Feature #6373][Open] public #self — "trans (Thomas Sawyer)" <transfire@...>

61 messages 2012/04/27

[#44748] [ruby-trunk - Feature #6376][Open] Feature lookup and checking if feature is loaded — "trans (Thomas Sawyer)" <transfire@...>

13 messages 2012/04/28

[ruby-core:44391] Re: [ruby-trunk - Feature #6293][Assigned] new queue / blocking queues

From: Aaron Patterson <tenderlove@...>
Date: 2012-04-16 15:24:23 UTC
List: ruby-core #44391
On Mon, Apr 16, 2012 at 06:25:59PM +0900, SASADA Koichi wrote:
> Hi,
> 
> Just an idea.
> 
> (2012/04/14 11:25), Aaron Patterson wrote:
> > I could, but I think the changes I want would add too much
> > complexity to the traditional Queue class.  We have to add
> > branching code for every method that could block / not-block.  Not
> > to mention users must pass the magical true | false to indicate if
> > they want blocking or non-blocking behavior.  For example:
> > 
> > queue.pop(true)  # does "true" mean I enable blocking? 
> > queue.pop(false) # does "false" mean I disable blocking?
> > 
> > It seems confusing to me, especially given the *actual* api with
> > twists your brain with a double negative (from thread.rb):
> > 
> > def pop(non_block=false) ... end
> > 
> > So calling pop() means we're doing a not not blocking call. :(
> 
> How about to add try_pop?

try_pop seems fine, but it still seems strange to combine blocking and
non-blocking queues (but maybe *I* am the one who is strange).

In the case of BlockingQueue#pop in the patch I submitted, it allows a
timeout.  I don't think it's a feature that should be abandoned.

> >>> * include Enumerable
> >> 
> >> The semantics is not trivial.  See the discussion in #4589.
> > 
> > I've read #4589.  I don't think it's that much of a problem.
> > Other languages[1] include enumerable type behavior in their
> > queues, and consistency is not guaranteed.
> > 
> > 1.
> > http://docs.oracle.com/javase/6/docs/api/java/util/Queue.html#methods_inherited_from_class_java.util.Collection
> 
> How
> > 
> about to implement Queue#to_a method that generate array which
> contains queues containing objects?

That seems fine!  Then we can eliminate Enumerable mixed in. :-)

> # I agree the name Thread::Queue because it is clear
> # that this object should be for synchronization.
> # Simple Queue class is ambiguous that we can use it
> # for synchronization or not.  However, in the Ruby world,
> # ::Queue is familiar as a data for synchronization.

Yes.  I think keeping ::Queue is good.  I think ::Queue can be
implemented in terms of Thread::BlockingQueue.  I would have refactored
::Queue to be a subclass of Thread::BlockingQueue, but I didn't want my
patch to be ignored because the diff size. :-)

-- 
Aaron Patterson
http://tenderlovemaking.com/

In This Thread