~michaelforrest/use-case-mapper/trunk

« back to all changes in this revision

Viewing changes to vendor/rails/activerecord/test/models/project.rb

  • Committer: Michael Forrest
  • Date: 2010-10-15 16:28:50 UTC
  • Revision ID: michael.forrest@canonical.com-20101015162850-tj2vchanv0kr0dun
refrozeĀ gems

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
class Project < ActiveRecord::Base
 
2
  has_and_belongs_to_many :developers, :uniq => true, :order => 'developers.name desc, developers.id desc'
 
3
  has_and_belongs_to_many :readonly_developers, :class_name => "Developer", :readonly => true
 
4
  has_and_belongs_to_many :selected_developers, :class_name => "Developer", :select => "developers.*", :uniq => true
 
5
  has_and_belongs_to_many :non_unique_developers, :order => 'developers.name desc, developers.id desc', :class_name => 'Developer'
 
6
  has_and_belongs_to_many :limited_developers, :class_name => "Developer", :limit => 1
 
7
  has_and_belongs_to_many :developers_named_david, :class_name => "Developer", :conditions => "name = 'David'", :uniq => true
 
8
  has_and_belongs_to_many :developers_named_david_with_hash_conditions, :class_name => "Developer", :conditions => { :name => 'David' }, :uniq => true
 
9
  has_and_belongs_to_many :salaried_developers, :class_name => "Developer", :conditions => "salary > 0"
 
10
  has_and_belongs_to_many :developers_with_finder_sql, :class_name => "Developer", :finder_sql => 'SELECT t.*, j.* FROM developers_projects j, developers t WHERE t.id = j.developer_id AND j.project_id = #{id} ORDER BY t.id'
 
11
  has_and_belongs_to_many :developers_by_sql, :class_name => "Developer", :delete_sql => "DELETE FROM developers_projects WHERE project_id = \#{id} AND developer_id = \#{record.id}"
 
12
  has_and_belongs_to_many :developers_with_callbacks, :class_name => "Developer", :before_add => Proc.new {|o, r| o.developers_log << "before_adding#{r.id || '<new>'}"},
 
13
                            :after_add => Proc.new {|o, r| o.developers_log << "after_adding#{r.id || '<new>'}"},
 
14
                            :before_remove => Proc.new {|o, r| o.developers_log << "before_removing#{r.id}"},
 
15
                            :after_remove => Proc.new {|o, r| o.developers_log << "after_removing#{r.id}"}
 
16
  has_and_belongs_to_many :well_payed_salary_groups, :class_name => "Developer", :group => "developers.salary", :having => "SUM(salary) > 10000", :select => "SUM(salary) as salary"
 
17
 
 
18
  attr_accessor :developers_log
 
19
 
 
20
  def after_initialize
 
21
    @developers_log = []
 
22
  end
 
23
 
 
24
end
 
25
 
 
26
class SpecialProject < Project
 
27
  def hello_world
 
28
    "hello there!"
 
29
  end
 
30
end