Software Development (CSC 321 2016S) : Outlines

Outline 16: Legacy Code


Held: ,

Back to Outline 15 - Codes of Ethics, Revisited. On to Outline 17 - UML.

Summary

We explore issues of working with legacy code and how code smells and refactoring will help us not just with legacy code, but with all of our code.

Related Pages

Overview

Administrivia

Upcoming Work

Good Things to Do

Academic

Peer

Other

Preparatory Activity

On a sheet of paper (supplied), answer the following questions.

  1. What is "legacy code"? (We see lots of definitions within the chapter.)
  2. List three "code smells" that you regularly notice.
  3. What is SOFA?
  4. List three refactoring techniqeus that you regularly use.

Legacy Code

Code Smells

Refactoring

An Example

From Field et al., pp. 2-4.

class Movie
  REGULAR = 0
  NEW_RELEASE = 1
  CHILDRENS = 2
  attr_reader :title
  attr_accessor :price_code
  def initialize(title, price_code)
    @title, @price_code = title, price_code
  end 
end

class Rental
  attr_reader :movie, :days_rented
  def initialize(movie, days_rented)
    @movie, @days_rented = movie, days_rented
  end 
end

class Customer
  attr_reader :name

  def initialize(name)
    @name = name
    @rentals = []
  end

  def add_rental(arg)
    @rentals << arg
  end

  def statement
    total_amount, frequent_renter_points = 0, 0
    result = "Rental Record for #{@name}\n"
    @rentals.each do |element|
      this_amount = 0

      # determine amounts for each line
      case element.movie.price_code
      when Movie::REGULAR
        this_amount += 2
        this_amount += (element.days_rented - 2) * 1.5 if element.days_rented > 2
      when Movie::NEW_RELEASE
        this_amount += element.days_rented * 3
      when Movie::CHILDRENS
        this_amount += 1.5
        this_amount += (element.days_rented - 3) * 1.5 if element.days_rented > 3
      end

      # add frequent renter points
      frequent_renter_points += 1
      # add bonus for a two day new release rental
      if element.movie.price_code == Movie.NEW_RELEASE && element.days_rented > 1
          frequent_renter_points += 1
      end

      # show figures for this rental
      result += "\t" + element.movie.title + "\t" + this_amount.to_s + "\n"
      total_amount += this_amount
    end

    # add footer lines
    result += "Amount owed is #{total_amount}\n"
    result += "You earned #{frequent_renter_points} frequent renter points"
    result
  end
end