CSC/ECE 517 Fall 2009/wiki 1a SJ: Difference between revisions

From Expertiza_Wiki
Jump to navigation Jump to search
No edit summary
 
 
(30 intermediate revisions by the same user not shown)
Line 1: Line 1:
== What is code refactoring ==
== What is Code Refactoring ==
According to the famous book "Refactoring: Improving the Design of Existing Code " by Martin Fowler: Refactoring is the process of applying behavior-preserving transformations to a program with the objective of improving the program’s design. Intuitively people refer to code refactoring as "cleaning it up".
According to the famous book "Refactoring: Improving the Design of Existing Code " by Martin Fowler: Refactoring is the process of applying behavior-preserving transformations to a program with the objective of improving the program’s design. Intuitively people refer to code refactoring as "cleaning it up".


=== Motivation of refactoring ===
=== Motivation of Refactoring ===
Refactoring is very useful for software engineer to maintain the quality of their code in different environment. In fact, no software can be guaranteed to be perfect when it is first developed. Usually when the source code is applied to different customer needs, we want to improve the inner-structure without modify the external behavior. The ability to refactor your code takes the pressure off the design phase of software development. Refactoring gives you the ability to change the design of the code at a later stage. This means that you don’t have to get the design absolutely right before you write any code. You can get a rough design worked out, code it up and then if (when) you spot a better design you can refactor your code towards the better design.
Refactoring is very useful for software engineer to maintain the quality of their code in different environment. In fact, no software can be guaranteed to be perfect when it is first developed. Usually when the source code is applied to different customer needs, we want to improve the inner-structure without modify the external behavior. The ability to refactor your code takes the pressure off the design phase of software development. Refactoring gives you the ability to change the design of the code at a later stage. This means that you don’t have to get the design absolutely right before you write any code. You can get a rough design worked out, code it up and then if (when) you spot a better design you can refactor your code towards the better design.


===List of main refactoring===
===List of Common Refactorings===
In the following we list some popular refactoring to specify how refactoring transform the code. For more detail information, the reader please refer to the section 2.1.2 of the thesis of Thomas Corbat[1]. [1] provide Ruby example for each refactoring this list.   
In the following we list some popular refactoring to specify how refactoring transform the code. For more detail information, the reader please refer to the section 2.1.2 of the thesis of Thomas Corbat[1]. [1] provide Ruby example for each refactoring this list.   
    
    
Line 38: Line 38:
|}
|}


=== Some Ruby Example of refactoring ===
=== Ruby Example of Refactoring ===
before rename:
Before rename:


  def badRenameMethod
  def badRenameMethod
Line 45: Line 45:
  end
  end


after rename:
After rename:


  def hello
  def hello
put("Hello World");
    puts("Hello World");
  end
  end


before encapsulation:
Before encapsulation:
   
   
  class SomeClass
  class SomeClass
Line 59: Line 59:
  end
  end


after encapsulation:
After encapsulation:


  class SomeClass                 
  class SomeClass                 
Line 77: Line 77:
  end
  end


=== Some Java Example of refactoring ===
=== Java Example of Refactoring ===
before rename:
Before rename:


  public class rename_method
  public class rename_method
Line 88: Line 88:
  }
  }


after rename:
After rename:


  public class rename_method
  public class rename_method
Line 99: Line 99:




before encapsulation:
Before encapsulation:


  public class encap_field
  public class encap_field
Line 106: Line 106:
  }
  }


after encapsulation:
After encapsulation:


  public class encap_field
  public class encap_field
Line 128: Line 128:
  | Current Ruby IDE || Refactoring Support (Y/N)
  | Current Ruby IDE || Refactoring Support (Y/N)
|-
|-
  | ActiveState Komodo  || N
  |[http://www.activestate.com ActiveState Komodo] || N
  |-  
  |-  
  | NetBeans || N
  | [http://www.netbeans.org NetBeans] || N
  |-
  |-
  | Arachno Ruby ||  N
  | [http://www.ruby-ide.com Arachno Ruby] ||  N
|-
|-
  | FreeRIDE || N
  | [http://freeride.rubyforge.org/wiki/wiki.pl FreeRIDE] || N
|-
|-
  | Mondrian Ruby IDE || N
  | [http://www.mondrian-ide.com/ Mondrian Ruby IDE] || N
|-
|-
  | Ruby in Steel || N
  | [http://www.sapphiresteel.com Ruby in Steel] || N
|-
|-
  | RubyMine || Y
  | [http://www.jetbrains.com/ruby/index.html RubyMine] || Y
|-
|-
  | Eclipse (Aptana) || Y   
  | [http://www.eclipse.org Eclipse] (Aptana) || Y   
  |}
  |}


=== Example of using Ruby refactoring tools in Eclipse ===
=== Example of Using Ruby Refactoring Tools in Eclipse ===
example of rename:
Here the renaming of the method "badRenameMethod" to "Hello" is illustrated for Ruby.  The source code is show in section 1.3.
 
{|
{|
| [[Image:r00.jpg|thumb|upright|alt= rename step0]]
| [[Image:r00.jpg|thumb|upright|alt= rename step 1]]
| [[Image:r01.jpg|thumb|upright|alt= rename step1]]
| [[Image:r01.jpg|thumb|upright|alt= rename step 2]]
| [[Image:r02.jpg|thumb|upright|alt= rename step2]]
| [[Image:r02.jpg|thumb|upright|alt= rename step 3]]
| [[Image:r03.jpg|thumb|upright|alt= rename step3]]
| [[Image:r03.jpg|thumb|upright|alt= rename step 4]]
| [[Image:r04.jpg|thumb|upright|alt= rename step4]]
| [[Image:r04.jpg|thumb|upright|alt= rename step 5]]
|}
|}


example of encapsulation:
Here the encapsulation of the field "field" is illustrated for Ruby.  The source code is show in section 1.3.
{|
{|
| [[Image:r05.jpg|thumb|upright|alt= encapsulation step0]]
| [[Image:r05.jpg|thumb|upright|alt= encapsulation step 1]]
| [[Image:r06.jpg|thumb|upright|alt= encapsulation step1]]
| [[Image:r06.jpg|thumb|upright|alt= encapsulation step 2]]
| [[Image:r07.jpg|thumb|upright|alt= encapsulation step2]]
| [[Image:r07.jpg|thumb|upright|alt= encapsulation step 3]]
| [[Image:r08.jpg|thumb|upright|alt= encapsulation step3]]
| [[Image:r08.jpg|thumb|upright|alt= encapsulation step 4]]
| [[Image:r09.jpg|thumb|upright|alt= encapsulation step4]]
| [[Image:r09.jpg|thumb|upright|alt= encapsulation step 5]]
|}
|}


=== Example of using Java refactoring tools in Eclipse ===
=== Example of Using Java Refactoring Tools in Eclipse ===
example of rename:
Here the renaming of the method "badRenameMethod" to "Hello" is illustrated for Java. The source code is show in section 1.4.


{|
{|
| [[Image:j00.jpg|thumb|upright|alt= rename step0]]
| [[Image:j00.jpg|thumb|upright|alt= rename step 1]]
| [[Image:j01.jpg|thumb|upright|alt= rename step1]]
| [[Image:j01.jpg|thumb|upright|alt= rename step 2]]
| [[Image:j02.jpg|thumb|upright|alt= rename step2]]
| [[Image:j02.jpg|thumb|upright|alt= rename step 3]]
| [[Image:j03.jpg|thumb|upright|alt= rename step3]]
| [[Image:j03.jpg|thumb|upright|alt= rename step 4]]
| [[Image:j04.jpg|thumb|upright|alt= rename step4]]
| [[Image:j04.jpg|thumb|upright|alt= rename step 5]]
| [[Image:j05.jpg|thumb|upright|alt= rename step0]]
| [[Image:j05.jpg|thumb|upright|alt= rename step 6]]
|}
|}
 
Here the encapsulation of the field "field" is illustrated for Java. The source code is show in section 1.4.
example of encapsulation:
{|
{|
| [[Image:j06.jpg|thumb|upright|alt= encapsulation step1]]
| [[Image:j06.jpg|thumb|upright|alt= encapsulation step 1]]
| [[Image:j07.jpg|thumb|upright|alt= encapsulation step2]]
| [[Image:j07.jpg|thumb|upright|alt= encapsulation step 2]]
| [[Image:j08.jpg|thumb|upright|alt= encapsulation step3]]
| [[Image:j08.jpg|thumb|upright|alt= encapsulation step 3]]
| [[Image:j09.jpg|thumb|upright|alt= encapsulation step4]]
| [[Image:j09.jpg|thumb|upright|alt= encapsulation step 4]]
|}
|}


== Ruby vs Java in terms of refactoring==
== Comparison of Ruby and Java Refactoring Tools ==
Comprehensiveness comparison:


{|
|1. Refactoring Options for Java in Eclipse  ||||  2. Refactoring Options in Eclipse for Ruby
|-
|Rename  || || Rename
|-
|Move || || Move
|-
|Change Method Signature || || Merge Class Parts in File
|-
|Extract Local Variable || || Pull Up
|-
|Extract Constant || || Pull Down
|-
|Inline || || Merge With External Class Parts
|-
|Convert Anonymous Class to Nested || || Split Local Variable
|-
|Convert Member to Top Level || || Merge With External Class Parts
|-
|Convert Local Variable to Field || || Inline
|-
|Extract Super Class || || Extract Constant
|-
|Extract Interface || || Encapsulate Field
|-
|Extract Class || || Convert Local Variable to Field
|-
|Use Supertype where possible
|-
|Pull Up
|-
|Pull Down
|-
|Introduce Parameter Object
|-
|Introduce Indirection
|-
|Introduce Factory
|-
|Introduce Parameter
|-
|Encapsulate Field
|-
|Generalize Declared Type
|-
|Infer Generic Type Arguments
|}


The refactoring options for Ruby and Java cover all the basic refactorings.  The differences in the number of options mainly come from the difference in the two languages.  Ruby is a dynamically typed language, has unbounded polymorphism, and all classes are open to extension.  On the other hand, Java is a statically typed language, polymorphism is mainly implemented via interfaces and inheritance, and classes cannot be extended at runtime.  The given examples (in section 1.3, 1.4) illustrate the ease of use of the refactoring tools for both Ruby and Java and how well these tools are integrated into the Eclipse IDE.


== References ==
== References ==

Latest revision as of 20:25, 16 September 2009

What is Code Refactoring

According to the famous book "Refactoring: Improving the Design of Existing Code " by Martin Fowler: Refactoring is the process of applying behavior-preserving transformations to a program with the objective of improving the program’s design. Intuitively people refer to code refactoring as "cleaning it up".

Motivation of Refactoring

Refactoring is very useful for software engineer to maintain the quality of their code in different environment. In fact, no software can be guaranteed to be perfect when it is first developed. Usually when the source code is applied to different customer needs, we want to improve the inner-structure without modify the external behavior. The ability to refactor your code takes the pressure off the design phase of software development. Refactoring gives you the ability to change the design of the code at a later stage. This means that you don’t have to get the design absolutely right before you write any code. You can get a rough design worked out, code it up and then if (when) you spot a better design you can refactor your code towards the better design.

List of Common Refactorings

In the following we list some popular refactoring to specify how refactoring transform the code. For more detail information, the reader please refer to the section 2.1.2 of the thesis of Thomas Corbat[1]. [1] provide Ruby example for each refactoring this list.

1. Merge Class Parts
2. Convert Local Variable to Field
3. Encapsulate Field
4. Extract Method
5. Inline Class
6. Inline Method
7. Move Field
8. Move Method
9. Rename Class
10. Rename Field
11. Rename Local Variable
12. Rename Method
13. Replace Temporary Variable with Query
14. Split Temporary Variable

Ruby Example of Refactoring

Before rename:

def badRenameMethod
   puts("Hello World");
end

After rename:

def hello
   puts("Hello World");
end

Before encapsulation:

class SomeClass
   def initialize
       @field = 0;
   end
end

After encapsulation:

class SomeClass                
   def initialize
       @field = 0;
   end
   
   def field
       @field
   end
   private :field
   
   def field= field
       @field = field
   end
   private :field=
end

Java Example of Refactoring

Before rename:

public class rename_method
{
   static void badRenameMethod()
   {
       System.out.println("Hello, world!");
   }
}

After rename:

public class rename_method
{
   static void hello()
   {
       System.out.println("Hello, world!");
   }
}


Before encapsulation:

public class encap_field
{
   public String field;
}

After encapsulation:

public class encap_field
{
   private int field;
   public void setField(int field)
   {
       this.field = field;
   }
   public int getField()
   {
       return field;
   }
}

Refactoring support for Current Ruby IDE

This the following table we summary the current ruby IDE and their refactoring support situation.

Current Ruby IDE Refactoring Support (Y/N)
ActiveState Komodo N
NetBeans N
Arachno Ruby N
FreeRIDE N
Mondrian Ruby IDE N
Ruby in Steel N
RubyMine Y
Eclipse (Aptana) Y

Example of Using Ruby Refactoring Tools in Eclipse

Here the renaming of the method "badRenameMethod" to "Hello" is illustrated for Ruby. The source code is show in section 1.3.

rename step 1
rename step 2
rename step 3
rename step 4
rename step 5

Here the encapsulation of the field "field" is illustrated for Ruby. The source code is show in section 1.3.

encapsulation step 1
encapsulation step 2
encapsulation step 3
encapsulation step 4
encapsulation step 5

Example of Using Java Refactoring Tools in Eclipse

Here the renaming of the method "badRenameMethod" to "Hello" is illustrated for Java. The source code is show in section 1.4.

rename step 1
rename step 2
rename step 3
rename step 4
rename step 5
rename step 6

Here the encapsulation of the field "field" is illustrated for Java. The source code is show in section 1.4.

encapsulation step 1
encapsulation step 2
encapsulation step 3
encapsulation step 4

Comparison of Ruby and Java Refactoring Tools

Comprehensiveness comparison:

1. Refactoring Options for Java in Eclipse 2. Refactoring Options in Eclipse for Ruby
Rename Rename
Move Move
Change Method Signature Merge Class Parts in File
Extract Local Variable Pull Up
Extract Constant Pull Down
Inline Merge With External Class Parts
Convert Anonymous Class to Nested Split Local Variable
Convert Member to Top Level Merge With External Class Parts
Convert Local Variable to Field Inline
Extract Super Class Extract Constant
Extract Interface Encapsulate Field
Extract Class Convert Local Variable to Field
Use Supertype where possible
Pull Up
Pull Down
Introduce Parameter Object
Introduce Indirection
Introduce Factory
Introduce Parameter
Encapsulate Field
Generalize Declared Type
Infer Generic Type Arguments

The refactoring options for Ruby and Java cover all the basic refactorings. The differences in the number of options mainly come from the difference in the two languages. Ruby is a dynamically typed language, has unbounded polymorphism, and all classes are open to extension. On the other hand, Java is a statically typed language, polymorphism is mainly implemented via interfaces and inheritance, and classes cannot be extended at runtime. The given examples (in section 1.3, 1.4) illustrate the ease of use of the refactoring tools for both Ruby and Java and how well these tools are integrated into the Eclipse IDE.

References

[1] Thomas Corbat, Lukas Felber, Mirko Stocker Refactoring Support for the Eclipse Ruby Development Tools, Diploma Thesis, HSR University of Applied Sciences Rapperswil Institute for Software

[2] code refactoring wiki, http://en.wikipedia.org/wiki/Code_refactoring

[3] the first workshop on refactoring, https://netfiles.uiuc.edu/dig/RefactoringWorkshop

[4] refactoring tutorial on ruby on rail, http://www.good-tutorials.com/tutorials/ruby-on-rails/refactoring