Recently, I had an opportunity to suggest a refactoring of some switch-code (case-like statements) into objects. So... if the original source (in Ruby) were:
case condition_variable
when :condition_one
  # This condition requires the most lines to handle, let us say.
  <code for handling condition one>
when :condition_two
  <code>
when :condition_three
  <code>
end #case
The first increment of refactoring is as follows. See how it cleanly divides and documents the code for handling condition one? (An important part of refactoring-to-patterns is stopping when the ugliness no longer shouts!)
class ConditionOne
  def handle( <parameters for handling condition one> )
    <code for handling condition one>
  end #def
end #class
case condition_variable
when :condition_one
  ConditionOne.new().handle( <arguments>)
when :condition_two
  <code>
when :condition_three
  <code>
end #case
If later a need is felt to refactor conditions two and three, another increment of refactoring is:
condition = case condition_variable
when :condition_one
  ConditionOne.new( <arguments for condition one>)
when :condition_two
  ConditionTwo.new( <arguments for condition two>)
when :condition_three
  ConditionThree.new( <arguments for condition three>)
end #case
condition.handle()
Some further refactoring leads to:
i = [ :condition_one,
    :condition_two,
    :condition_three].
    index( condition_variable)
arguments = [ # For condition...
    [<arguments>], # one.
    [<arguments>], # two.
    [<arguments>]] # three.
condition = [
    ConditionOne,
    ConditionTwo,
    ConditionThree].at( i).new( arguments.at( i))
condition.handle()
If a need is felt, further refactoring could subclass a class called, Condition.
Actually, ConditionOne and its siblings want meaningful, specific names. See how this solves the problem of the code being too procedural?
Sources & further information:
AnalysisIsRefactoring
CaseStatementsConsideredHarmful
HistoryOfRefactoring
PolymorphismVsSelectionIdiom
RefactoringIsaRequirement
RefactoringToPatterns
RefactorLowHangingFruit
RefactorMercilessly
SafelyRefactoringLegacyCode
SwitchStatement
SwitchStatementsSmell
WhatIsaFactor
WhyDidYouRefactorThat
WhyNotEnoughRefactoringHappens
Copyright (c) 2010 Mark D. Blackwell.
Wednesday, January 27, 2010
Thursday, January 14, 2010
_why the lucky stiff
Suddenly I am struck with sadness for our loss of the highly creative _why the lucky stiff. (I discovered this while researching Ruby Shoes.) Not just in programming, but creative also in drawing and prose.
There is more here, here and here, and a cute sample of his early writing. Also, I found a _why-related, compilation blog post.
On last.fm, a radio station in his name contains some strange and intelligent things.
His June, 2009 talk on "Hackety Hack" at an ART && CODE Symposium shows his general aim of convincing others (besides his own creative work) to expand the learning opportunities available to children for programming. Perhaps this was the original basis for his pseudonym? Perhaps the reason for his disappearance was promotion: to generate large-scale publicity for this worthy cause.
Copyright (c) 2010 Mark D. Blackwell.
There is more here, here and here, and a cute sample of his early writing. Also, I found a _why-related, compilation blog post.
On last.fm, a radio station in his name contains some strange and intelligent things.
His June, 2009 talk on "Hackety Hack" at an ART && CODE Symposium shows his general aim of convincing others (besides his own creative work) to expand the learning opportunities available to children for programming. Perhaps this was the original basis for his pseudonym? Perhaps the reason for his disappearance was promotion: to generate large-scale publicity for this worthy cause.
Copyright (c) 2010 Mark D. Blackwell.
Labels:
_why,
_why the lucky stiff,
art,
art and code symposium,
blogging,
computer,
drawing,
education,
hackety hack,
intuitive,
legacy,
music,
programming,
radio,
ruby,
ruby shoes,
writing
Subscribe to:
Comments (Atom)