[#33161] Call/CC and Ruby iterators. — olczyk@... (Thaddeus L Olczyk)

Reading about call/cc in Scheme I get the impression that it is very

11 messages 2002/02/05

[#33242] favicon.ico — Dave Thomas <Dave@...>

19 messages 2002/02/06
[#33256] Re: favicon.ico — Leon Torres <leon@...> 2002/02/06

[#33435] Reg: tiny contest: who's faster? (add_a_gram) — grady@... (Steven Grady)

> My current solution works correctly with various inputs.

17 messages 2002/02/08

[#33500] Ruby Embedded Documentation — William Djaja Tjokroaminata <billtj@...>

Hi,

24 messages 2002/02/10
[#33502] Re: Ruby Embedded Documentation — "Lyle Johnson" <ljohnson@...> 2002/02/10

> Now, I am using Ruby on Linux, and I have downloaded Ruby version

[#33615] Name resolution in Ruby — stern@... (Alan Stern)

I've been struggling to understand how name resolution is supposed to

16 messages 2002/02/11

[#33617] choice of HTML templating system — Paul Brannan <paul@...>

I am not a web developer, nor do I pretend to be one.

23 messages 2002/02/11

[#33619] make first letter lowercase — sebi@... (sebi)

hello,

20 messages 2002/02/11
[#33620] Re: [newbie] make first letter lowercase — Tobias Reif <tobiasreif@...> 2002/02/11

sebi wrote:

[#33624] Re: [newbie] make first letter lowercase — "Jeff 'japhy' Pinyan" <jeffp@...> 2002/02/11

On Feb 11, Tobias Reif said:

[#33632] Re: [newbie] make first letter lowercase — Mathieu Bouchard <matju@...> 2002/02/12

[#33731] simple XML parsing (greedy / non-greedy — Ron Jeffries <ronjeffries@...>

Suppose I had this text

14 messages 2002/02/13

[#33743] qualms about respond_to? idiom — David Alan Black <dblack@...>

Hi --

28 messages 2002/02/13
[#33751] Re: qualms about respond_to? idiom — Dave Thomas <Dave@...> 2002/02/13

David Alan Black <dblack@candle.superlink.net> writes:

[#33754] Re: qualms about respond_to? idiom — David Alan Black <dblack@...> 2002/02/13

Hi --

[#33848] "Powered by Ruby" banner — Yuri Leikind <YuriLeikind@...>

Hello Ruby folks,

78 messages 2002/02/14
[#33909] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/14

On Thu, 14 Feb 2002, Yuri Leikind wrote:

[#33916] RE: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

A modest submission:

[#33929] Re: "Powered by Ruby" banner — yet another bill smith <bigbill.smith@...> 2002/02/15

Kent Dahl wrote:

[#33932] OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 5:54 AM, "yet another bill smith" <bigbill.smith@verizon.net>

[#33933] RE: OT Netscape 4.x? was Re: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

i just don't understand why it didn't show up! dhtml/javascript, ok, but a

[#33937] Re: OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 7:16 AM, "Jack Dempsey" <dempsejn@georgetown.edu> wrote:

[#33989] Re: OT OmniWeb [was: Netscape 4.x?] — Sean Russell <ser@...> 2002/02/16

Chris Gehlker wrote:

[#33991] Re: OT OmniWeb [was: Netscape 4.x?] — Rob Partington <rjp@...> 2002/02/16

In message <3c6e5e01_1@spamkiller.newsgroups.com>,

[#33993] Re: OT OmniWeb [was: Netscape 4.x?] — Thomas Hurst <tom.hurst@...> 2002/02/16

* Rob Partington (rjp@browser.org) wrote:

[#33925] Re: "Powered by Ruby" banner — Martin Maciaszek <mmaciaszek@...> 2002/02/15

In article <3C6CFCCA.5AD5CA67@scnsoft.com>, Yuri Leikind wrote:

[#33956] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/15

On Fri, 15 Feb 2002, Martin Maciaszek wrote:

[#33851] Ruby and .NET — Patrik Sundberg <ps@...>

I have been reading a bit about .NET for the last couple of days and must say

53 messages 2002/02/14

[#34024] Compiled companion language for Ruby? — Erik Terpstra <erik@...>

Hmmm, seems that my previous post was in a different thread, I'll try

12 messages 2002/02/16

[#34036] The GUI Returns — "Horacio Lopez" <vruz@...>

Hello all,

33 messages 2002/02/17

[#34162] Epic4/Ruby — Thomas Hurst <tom.hurst@...>

Rejoice, for you no longer have to put up with that evil excuse for a

34 messages 2002/02/18

[#34185] Operator overloading and multiple arguments — ptkwt@...1.aracnet.com (Phil Tomson)

I'm trying to overload the '<=' operator in a class in order to use it for

10 messages 2002/02/18

[#34217] Ruby for web development — beripome@... (Billy)

Hi all,

21 messages 2002/02/19

[#34350] FAQ for comp.lang.ruby — "Hal E. Fulton" <hal9000@...>

RUBY NEWSGROUP FAQ -- Welcome to comp.lang.ruby! (Revised 2001-2-18)

15 messages 2002/02/20

[#34375] Setting the Ruby continued — <jostein.berntsen@...>

Hi,

24 messages 2002/02/20
[#34384] Re: Setting the Ruby continued — Paulo Schreiner <paulo@...> 2002/02/20

Also VERY important:

[#34467] recursive require — Ron Jeffries <ronjeffries@...>

I'm having a really odd thing happen with two files that mutually

18 messages 2002/02/21

[#34503] special characters — Tobias Reif <tobiasreif@...>

Hi all,

13 messages 2002/02/22

[#34517] Windows Installer Ruby 166-0 available — Andrew Hunt <andy@...>

16 messages 2002/02/22

[#34597] rdoc/xml questions — Dave Thomas <Dave@...>

24 messages 2002/02/23

[#34631] Object/Memory Management — "Sean O'Dell" <sean@...>

I'm new to Ruby and the community here (I've been learning Ruby for a grand

44 messages 2002/02/23

[#34682] duplicate method name — Ron Jeffries <ronjeffries@...>

I just found a case in a test file where i had two tests of the same

16 messages 2002/02/24
[#34687] Re: duplicate method name — s@... (Stefan Schmiedl) 2002/02/24

Hi Ron.

[#34791] Style Question — Ron Jeffries <ronjeffries@...>

So I'm building this set theory library. The "only" object is supposed

13 messages 2002/02/25

[#34912] RCR?: parallel to until: as_soon_as — Tobias Reif <tobiasreif@...>

Hi,

18 messages 2002/02/26

[#34972] OT A Question on work styles — Chris Gehlker <gehlker@...>

As a Mac baby I just had to step through ruby in GDB *from the command line*

20 messages 2002/02/28

[#35015] Time Comparison — "Sean O'Dell" <sean@...>

I am using the time object to compare times between two files and I'm

21 messages 2002/02/28

Re: qualms about respond_to? idiom

From: Hugh Sasse Staff Elec Eng <hgs@...>
Date: 2002-02-14 18:22:32 UTC
List: ruby-talk #33897
On Fri, 15 Feb 2002, Gunnar Andersson wrote:

>
> > Hugh Sasse writes:
> > On Thu, 14 Feb 2002, Dave Thomas wrote:
>
> > > A polymorphic way of doing this is to move responsibility
> > > down to the
> > > stream elements. Say each had a method handle_stack. Then your main
> > > code could simply call handle_stack on _all_ tags:
> > >
> > >    e.handle_stack(context)
>
> > So is this an example of "Tell, Don't Ask", or is that more about an
> > object's internal state?  It does overcome this
> > problem, but it also means all the objects have to know how
> > to handle a
> > stack.  Doesn't that lead to "unnecessary" coupling between objects?
>
> Well you have type-dependent behavior so you really only have those
> choices, I'd say.
>
>  1. Either you switch on the type, which is what the original
>     was doing, basically.
>  2. Or you use the polymorphic approach and make use of dynamic
>     dispatch.

I think we are agreed that *in general*, 2 is preferable...
>
>  Looking at Dave's example, using names like "stack" and "push"
>  works because it is unlikely you'd want to handle your XML tags
>  in a queue.  It is clear a stack is the way to go and probably not
>  much to worry about.

I'm happy about there being a stack.  But there may be other things you
want to do with your XML tags which raise the same problem, as I'll
try to clarify below...
>
>  But in similar cases, if you don't want to pass out the stack,
>  there are other ways, like passing self, the tag calls back on
>  that,  and your tag-juggling-object delegates the "push" to the
>  internal stack.  (or "store" in the example below)

So it is sort of held within the object itself?

>  You've coupled the tags and their handler (this is inevitable),
>  but at least not thrown a Stack and it's specific push/pop methods
>  into the mix.

I think this is more what I am after. (Again, below...)
>
>  class Handler
>
>       ... foo-juggling-code ...
>       foo.maybe_store_yourself(self)
>       ...
>
>     # This is called back from the Foos
>     def store(item)
>        # The fact that we use a stack is encapsulated...
>        @stack.push(item)
>     end
>
>
> end
>
>    # One type does:
>    def maybe_store_yourself(handler)
>      handler.store(self)
>    end
>
>    # Another type does nothing
>    def maybe_store_yourself(handler)
>    end

I think this is even better than having the method in each object you
want to store.  This means that the coupling won't get many(stacks,
trees, something-D.Knuth-may-invent-next-week) to many(XML tags, AST's,
DOM ojects, etc), each side couples to the handler. A Mediator pattern.

I think this overcomes the problem I was seeing.  As the project grows,
amd more things have to use the Stack, and the Stack is not the only
thing handling the objects, then combinatorial explosion results.  In
such a case the design rules of "minimise coupling" apply.
>
> <philosophy rant>
> Adds coupling?  You can look at _any_ piece of code and
> find at least some dependencies.  You either add coupling or

Agreed, but I was trying to think of scaling it to more classes
that might need to use the stack.  Also, I was asking to try and
understand the issues, rather than say "this is wrong".  I was
fairly certain Dave Thomas would have an excellent reason for
b(reak|end)ing rules about minimising coupling, but I couldn't
deduce it.

        [...]
> without it?  Sometimes you (not *YOU* but all of us, well, maybe not
> the gurus but anyway... ;-) have a tendency to over-analyze these
> things because we look at our dogmatic rules and see that either
> way we seem to break at least one of them.  In my experience,

Yes, some of the rules pull in different directions -- creative tension,
etc.  This is what I wanted to explore.  Sometimes the fact that
"Either way you break a rule" means your looking at the problem
incorrectly, and you need to break an assumption, which is unstated.
Hence lateral thinking.

> after thinking "enough", you try one thing and if that doesn't
> really work in the long run, it will show (smell) and you
> refactor.
> </philosophy rant>
>
> So basically you have those two choices.
>
> Should you choose to switch on type, I would prefer doing it
> in a more explicit way.  respond_to? is most likely just a
> concealed way of switching on type, albeit somewhat more flexible
> than switching on the object's Class.
> In some cases (a limited use of) respond_to? makes sense, in
> others not.

Agreed. It would be nice if one could examine the contract of the
method, but until we have Design by Contract I won't open that can
of worms!
        [...]
> And consider the success of functional programming in some
> fields.  A lot of functions are polymorphic, but you also
> see quite some pattern-matching (=switch on type, more or less)
> to decide what to actually do.

This suggests to me that our language/thinking is geared so much
to physical things that we have difficulty in extracting a set of
behaviours as an abstraction to use in reasoning.
>
> What's one reason to love the Ruby community?  Because of the smart
> people in it!  Some of the discussions here are great!  I sure
> learn a lot.

Yes, me too.
>
> Cheers
> /Gunnar

        Hugh

In This Thread

Prev Next