[#389739] Ruby Challenge — teresa nuagen <unguyen90@...>

Here is a ruby challenge for all you computer science lovers out there,

22 messages 2011/11/05
[#389769] Re: Ruby Challenge — "Jonan S." <jonanscheffler@...> 2011/11/05

Totally unrelated to any husker computer science programs right? Like

[#389905] Re: Ruby Challenge — Stephen Ramsay <sramsay.unl@...> 2011/11/09

Jonan S. wrote in post #1030330:

[#389907] Re: Ruby Challenge — aseret nuagen <unguyen90@...> 2011/11/09

> You mean like the professor for the course? Because that would be me .

[#389915] Re: Ruby Challenge — Robert Klemme <shortcutter@...> 2011/11/09

On Wed, Nov 9, 2011 at 4:52 AM, aseret nuagen <unguyen90@aim.com> wrote:

[#389792] Tricky DSL, how to do it? — Intransition <transfire@...>

I'd want to write a DSL such that a surface method_missing catches

18 messages 2011/11/06

[#389858] Compiling Ruby Inline C code - resolving errors — Martin Hansen <mail@...>

I am trying to get this Ruby inline C code http://pastie.org/2825882 to

12 messages 2011/11/08

[#389928] Forming a Ruby meetup group... — "Darryl L. Pierce" <mcpierce@...>

Where I work we have a local Ruby group that used to meet up, until the

12 messages 2011/11/09

[#389950] The faster way to read files — "Noé Alejandro" <casanejo@...>

Does anybody know which is the fastest way to read a file? Lets say

18 messages 2011/11/09

[#390064] referring to version numbers in a gem — Chad Perrin <code@...>

How do I specify and access a gem's version number within the code of the

28 messages 2011/11/11

[#390238] RVM problem, plz help — Misha Ognev <b1368810@...>

Hi, I have this problem:

15 messages 2011/11/16

[#390308] any command line tools for querying yaml files — Rahul Kumar <sentinel1879@...>

(Sorry, this is not exactly a ruby question).

11 messages 2011/11/18

[#390338] Newbie - cmd question — Otto Dydakt <ottodydakt@...>

I've literally JUST downloaded ruby from rubyinstaller.org.

21 messages 2011/11/19
[#390342] Re: Newbie - cmd question — Otto Dydakt <ottodydakt@...> 2011/11/19

OK thank you, I uninstalled & reinstalled, checking the three boxes at

[#390343] Re: Newbie - cmd question — "Ian M. Asaff" <ian.asaff@...> 2011/11/19

did you type "irb" first to bring up the ruby command prompt?

[#391154] Re: Newbie - cmd question — "Hussain A." <hahmad@...> 2011/12/12

Hi all,

[#391165] Re: Newbie - cmd question — Luis Lavena <luislavena@...> 2011/12/12

Hussain A. wrote in post #1036281:

[#390374] Principle of Best Principles — Intransition <transfire@...>

I seem to run into a couple of design issue a lot and I never know what is

16 messages 2011/11/20

[#390396] how to call Function argument into another ruby script. — hari mahesh <harismahesh@...>

Consider I have a ruby file called library.rb.

10 messages 2011/11/21

[#390496] How to make 1.9.2 my default version using RVM — Fily Salas <fs_tigre@...>

Hi,

25 messages 2011/11/24

[#390535] Is high-speed sorting impossible with Ruby? — "Gaurav C." <chande.gaurav@...>

Well, first of all, I'm new to Ruby, and to this forum. So, hello. :)

39 messages 2011/11/25
[#390580] Re: Is high-speed sorting impossible with Ruby? — Joao Pedrosa <joaopedrosa@...> 2011/11/27

Hi,

[#390593] Re: Is high-speed sorting impossible with Ruby? — "Gaurav C." <chande.gaurav@...> 2011/11/27

Joao Pedrosa wrote in post #1033884:

[#390600] Re: Is high-speed sorting impossible with Ruby? — Douglas Seifert <doug@...> 2011/11/27

A big gain can be had by disabling the garbage collector. Here is my best

[#390601] Re: Is high-speed sorting impossible with Ruby? — Douglas Seifert <doug@...> 2011/11/27

I've thrown various solutions up on github here:

[#390650] Loading a faulty ruby file - forcing this — Marc Heiler <shevegen@...>

Hi.

10 messages 2011/11/29

[#390689] Stupid question — James Gallagher <lollyproductions@...>

Hi everyone.

22 messages 2011/11/30

Re: Principle of Best Principles

From: Robert Klemme <shortcutter@...>
Date: 2011-11-22 08:08:06 UTC
List: ruby-talk #390414
On Mon, Nov 21, 2011 at 11:00 PM, Intransition <transfire@gmail.com> wrote:
> As it turns out you (and others) are pretty spot on, though I'm not sure the
> n:1 relationship is necessarily the best way to think about it, it did
> provide a good starting point. But the "too loose coupling" is really the
> great point here. And that's something you don't often hear!!! We always
> here about over-coupling.

Just out of curiosity: whereabouts do you hear so often about
"over-coupling"?  One explanation for the high frequency might be that
a lot of code that gets written has too tight coupling ("spaghetti
code") - at least that's what I see in my daily work.  One reason for
that in turn might be that people do not have a clear understanding
where they are heading to with a piece of code.  Another reason might
be that the purpose of a piece of code changes over time and often
people do not go through the exercise of refactoring - either because
of laziness or - more likely in the corporate world - because they
don't get the resources (time) granted (which, btw, seems a very short
sighted strategy to me because it will come back haunt you later).

> But really it's "just right coupling" that is the real deal.

Absolutely.  It's generally easy to go to extremes.  It's much harder
to find the right middle ground.  A good solution to a technical
problem requires more work than a mediocre solution.  So chances are
that good solutions rather lie in the middle ground than at the
extremes.  You can even generalize that to other areas of life itself:

http://en.wikipedia.org/wiki/Middle_way

> So in my (real life) case I kept the coupling.
>
> However, I did end up applying the Single Responsibility Principle, and
> though it was bit difficult to work out the restructuring as first, the code
> turned out much cleaner in the end. So that pattern at least proved itself.
>
> Lessons learned.
>
> Thanks.

What a great feedback!  It's good to see how the community evolves
through collaborative learning experiences.  That's what makes this
community such a great place.

Kind regards

robert


PS: I find Meyer's book "OOSC" a great source of OO design advice -
although it is hidden in a large description of Eiffel.  The way he
dissects various aspects (e.g. inheritance) shows that he has thought
a lot about OO - and came to an understanding which is rarely equaled.

-- 
remember.guy do |as, often| as.you_can - without end
http://blog.rubybestpractices.com/

In This Thread