ozsantana-has_many_select 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
data/History.txt ADDED
@@ -0,0 +1,8 @@
1
+ == 0.0.2 2008-08-04
2
+
3
+ * Insert with primary_key
4
+
5
+ == 0.0.1 2008-08-01
6
+
7
+ * 1 major enhancement:
8
+ * Initial release
data/License.txt ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2008 Ozéias Sant'ana
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/Manifest.txt ADDED
@@ -0,0 +1,28 @@
1
+ History.txt
2
+ License.txt
3
+ Manifest.txt
4
+ PostInstall.txt
5
+ README.txt
6
+ Rakefile
7
+ config/hoe.rb
8
+ config/requirements.rb
9
+ lib/has_many_select.rb
10
+ lib/has_many_select/associations.rb
11
+ lib/has_many_select/association_proxy.rb
12
+ lib/has_many_select/has_many_association.rb
13
+ lib/has_many_select/version.rb
14
+ script/console
15
+ script/destroy
16
+ script/generate
17
+ script/txt2html
18
+ setup.rb
19
+ tasks/deployment.rake
20
+ tasks/environment.rake
21
+ tasks/website.rake
22
+ test/test_has_many_select.rb
23
+ test/test_helper.rb
24
+ website/index.html
25
+ website/index.txt
26
+ website/javascripts/rounded_corners_lite.inc.js
27
+ website/stylesheets/screen.css
28
+ website/template.html.erb
data/PostInstall.txt ADDED
@@ -0,0 +1,5 @@
1
+
2
+ For more information on has_many_select, see http://github.com/ozsantana/has_many_select/
3
+
4
+ Then you must require the gem in your environment.rb
5
+ require 'has_many_select'
data/README.txt ADDED
@@ -0,0 +1,58 @@
1
+ README for has_many_select
2
+ ==============================
3
+
4
+ This gem is provides a patch for ActiveRecord 2.1.0 to enable the use of the :primary_key
5
+ option used in combination with the has_many option.
6
+
7
+ The problem:
8
+ Legacy systems outside the standard.
9
+
10
+ class HeaderSale < ActiveRecord::Base
11
+ set_table_name("cab_pedido")
12
+ set_primary_key("r_e_c_n_o_") # false primary_key, real is cpv_pedido. The field r_e_c_n_o_ is serial.
13
+
14
+ has_many :justifications,
15
+ :foreign_key => 'nr_pedido'
16
+ end
17
+
18
+ x = HeaderSale.find(:first, :conditions => 'cpv_pedido = 193514')
19
+ => 'SELECT * FROM "cab_pedido_vendas" WHERE (cpv_pedido = 193514) LIMIT 1'
20
+ x.justifications
21
+ => 'SELECT * FROM "justificativa" WHERE ("justificativa".nr_pedido = 307634)' # ERROR
22
+ the correct select is:
23
+ => 'SELECT * FROM "justificativa" WHERE ("justificativa".nr_pedido = 193514)' # CORRECT
24
+
25
+ == Usage
26
+
27
+ Then you must require the gem in your environment.rb
28
+ require 'has_many_select'
29
+
30
+ In your model:
31
+
32
+ class HeaderSale < ActiveRecord::Base
33
+ set_table_name("cab_pedido")
34
+ set_primary_key("r_e_c_n_o_") # false primary_key, real is cpv_pedido. The field r_e_c_n_o_ is serial.
35
+
36
+ has_many :justifications,
37
+ :foreign_key => 'nr_pedido', :primary_key => 'cpv_pedido'
38
+ end
39
+
40
+ x = HeaderSale.find(:first, :conditions => 'cpv_pedido = 193514')
41
+ => 'SELECT * FROM "cab_pedido_vendas" WHERE (cpv_pedido = 193514) LIMIT 1'
42
+ x.justifications
43
+ => 'SELECT * FROM "justificativa" WHERE ("justificativa".nr_pedido = 193514)' # CORRECT
44
+
45
+ == Installation
46
+
47
+ gem sources -a http://gems.github.com
48
+
49
+ gem install ozsantana-has_many_select
50
+
51
+ == Author
52
+
53
+ Author of this gem is Ozéias Sant'ana < oz.santana@gmail.com >
54
+ based on: http://github.com/rails/rails/commit/3351d2997017465047b2c3dc63dc31e2362368af
55
+
56
+ == License
57
+
58
+ this gem is distributed under the MIT license
data/Rakefile ADDED
@@ -0,0 +1,4 @@
1
+ require 'config/requirements'
2
+ require 'config/hoe' # setup Hoe + all gem configuration
3
+
4
+ Dir['tasks/**/*.rake'].each { |rake| load rake }
data/config/hoe.rb ADDED
@@ -0,0 +1,73 @@
1
+ require 'has_many_select/version'
2
+
3
+ AUTHOR = 'FIXME full name' # can also be an array of Authors
4
+ EMAIL = "FIXME email"
5
+ DESCRIPTION = "description of gem"
6
+ GEM_NAME = 'has_many_select' # what ppl will type to install your gem
7
+ RUBYFORGE_PROJECT = 'has_many_select' # The unix name for your project
8
+ HOMEPATH = "http://#{RUBYFORGE_PROJECT}.rubyforge.org"
9
+ DOWNLOAD_PATH = "http://rubyforge.org/projects/#{RUBYFORGE_PROJECT}"
10
+ EXTRA_DEPENDENCIES = [
11
+ # ['activesupport', '>= 1.3.1']
12
+ ] # An array of rubygem dependencies [name, version]
13
+
14
+ @config_file = "~/.rubyforge/user-config.yml"
15
+ @config = nil
16
+ RUBYFORGE_USERNAME = "unknown"
17
+ def rubyforge_username
18
+ unless @config
19
+ begin
20
+ @config = YAML.load(File.read(File.expand_path(@config_file)))
21
+ rescue
22
+ puts <<-EOS
23
+ ERROR: No rubyforge config file found: #{@config_file}
24
+ Run 'rubyforge setup' to prepare your env for access to Rubyforge
25
+ - See http://newgem.rubyforge.org/rubyforge.html for more details
26
+ EOS
27
+ exit
28
+ end
29
+ end
30
+ RUBYFORGE_USERNAME.replace @config["username"]
31
+ end
32
+
33
+
34
+ REV = nil
35
+ # UNCOMMENT IF REQUIRED:
36
+ # REV = YAML.load(`svn info`)['Revision']
37
+ VERS = HasManySelect::VERSION::STRING + (REV ? ".#{REV}" : "")
38
+ RDOC_OPTS = ['--quiet', '--title', 'has_many_select documentation',
39
+ "--opname", "index.html",
40
+ "--line-numbers",
41
+ "--main", "README",
42
+ "--inline-source"]
43
+
44
+ class Hoe
45
+ def extra_deps
46
+ @extra_deps.reject! { |x| Array(x).first == 'hoe' }
47
+ @extra_deps
48
+ end
49
+ end
50
+
51
+ # Generate all the Rake tasks
52
+ # Run 'rake -T' to see list of generated tasks (from gem root directory)
53
+ $hoe = Hoe.new(GEM_NAME, VERS) do |p|
54
+ p.developer(AUTHOR, EMAIL)
55
+ p.description = DESCRIPTION
56
+ p.summary = DESCRIPTION
57
+ p.url = HOMEPATH
58
+ p.rubyforge_name = RUBYFORGE_PROJECT if RUBYFORGE_PROJECT
59
+ p.test_globs = ["test/**/test_*.rb"]
60
+ p.clean_globs |= ['**/.*.sw?', '*.gem', '.config', '**/.DS_Store'] #An array of file patterns to delete on clean.
61
+
62
+ # == Optional
63
+ p.changes = p.paragraphs_of("History.txt", 0..1).join("\n\n")
64
+ #p.extra_deps = EXTRA_DEPENDENCIES
65
+
66
+ #p.spec_extras = {} # A hash of extra values to set in the gemspec.
67
+ end
68
+
69
+ CHANGES = $hoe.paragraphs_of('History.txt', 0..1).join("\\n\\n")
70
+ PATH = (RUBYFORGE_PROJECT == GEM_NAME) ? RUBYFORGE_PROJECT : "#{RUBYFORGE_PROJECT}/#{GEM_NAME}"
71
+ $hoe.remote_rdoc_dir = File.join(PATH.gsub(/^#{RUBYFORGE_PROJECT}\/?/,''), 'rdoc')
72
+ $hoe.rsync_args = '-av --delete --ignore-errors'
73
+ $hoe.spec.post_install_message = File.open(File.dirname(__FILE__) + "/../PostInstall.txt").read rescue ""
@@ -0,0 +1,15 @@
1
+ require 'fileutils'
2
+ include FileUtils
3
+
4
+ require 'rubygems'
5
+ %w[rake hoe newgem rubigen].each do |req_gem|
6
+ begin
7
+ require req_gem
8
+ rescue LoadError
9
+ puts "This Rakefile requires the '#{req_gem}' RubyGem."
10
+ puts "Installation: gem install #{req_gem} -y"
11
+ exit
12
+ end
13
+ end
14
+
15
+ $:.unshift(File.join(File.dirname(__FILE__), %w[.. lib]))
@@ -0,0 +1 @@
1
+ Dir[File.join(File.dirname(__FILE__), 'has_many_select/**/*.rb')].sort.each { |lib| require lib }
@@ -0,0 +1,17 @@
1
+ module ActiveRecord
2
+ module Associations
3
+ class AssociationProxy #:nodoc:
4
+ protected
5
+ def set_belongs_to_association_for(record)
6
+ if @reflection.options[:as]
7
+ record["#{@reflection.options[:as]}_id"] = @owner.id unless @owner.new_record?
8
+ record["#{@reflection.options[:as]}_type"] = @owner.class.base_class.name.to_s
9
+ elsif @reflection.options[:primary_key]
10
+ record[@reflection.primary_key_name] = owner_quoted_id unless @owner.new_record?
11
+ else
12
+ record[@reflection.primary_key_name] = @owner.id unless @owner.new_record?
13
+ end
14
+ end
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,29 @@
1
+ module ActiveRecord
2
+ module Associations
3
+ module ClassMethods
4
+ private
5
+ def create_has_many_reflection(association_id, options, &extension)
6
+ options.assert_valid_keys(
7
+ :class_name, :table_name, :foreign_key, :primary_key,
8
+ :dependent,
9
+ :select, :conditions, :include, :order, :group, :limit, :offset,
10
+ :as, :through, :source, :source_type,
11
+ :uniq,
12
+ :finder_sql, :counter_sql,
13
+ :before_add, :after_add, :before_remove, :after_remove,
14
+ :extend, :readonly
15
+ )
16
+ options[:extend] = create_extension_modules(association_id, extension, options[:extend])
17
+
18
+ create_reflection(:has_many, association_id, options, self)
19
+ end
20
+
21
+ class JoinDependency # :nodoc:
22
+ class JoinBase # :nodoc:
23
+ attr_reader :active_record, :table_joins
24
+ delegate :table_name, :column_names, :primary_key, :reflections, :sanitize_sql, :to => :active_record
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,56 @@
1
+ module ActiveRecord
2
+ module Associations
3
+ class HasManyAssociation < AssociationCollection #:nodoc:
4
+ protected
5
+ def owner_quoted_id
6
+ if @reflection.options[:primary_key]
7
+ quote_value(@owner.send(@reflection.options[:primary_key]))
8
+ else
9
+ @owner.quoted_id
10
+ end
11
+ end
12
+
13
+ def delete_records(records)
14
+ case @reflection.options[:dependent]
15
+ when :destroy
16
+ records.each(&:destroy)
17
+ when :delete_all
18
+ @reflection.klass.delete(records.map(&:id))
19
+ else
20
+ ids = quoted_record_ids(records)
21
+ @reflection.klass.update_all(
22
+ "#{@reflection.primary_key_name} = NULL",
23
+ "#{@reflection.primary_key_name} = #{owner_quoted_id} AND #{@reflection.klass.primary_key} IN (#{ids})"
24
+ )
25
+ end
26
+ end
27
+
28
+ def construct_sql
29
+ case
30
+ when @reflection.options[:finder_sql]
31
+ @finder_sql = interpolate_sql(@reflection.options[:finder_sql])
32
+
33
+ when @reflection.options[:as]
34
+ @finder_sql =
35
+ "#{@reflection.quoted_table_name}.#{@reflection.options[:as]}_id = #{owner_quoted_id} AND " +
36
+ "#{@reflection.quoted_table_name}.#{@reflection.options[:as]}_type = #{@owner.class.quote_value(@owner.class.base_class.name.to_s)}"
37
+ @finder_sql << " AND (#{conditions})" if conditions
38
+
39
+ else
40
+ @finder_sql = "#{@reflection.quoted_table_name}.#{@reflection.primary_key_name} = #{owner_quoted_id}"
41
+ @finder_sql << " AND (#{conditions})" if conditions
42
+ end
43
+
44
+ if @reflection.options[:counter_sql]
45
+ @counter_sql = interpolate_sql(@reflection.options[:counter_sql])
46
+ elsif @reflection.options[:finder_sql]
47
+ # replace the SELECT clause with COUNT(*), preserving any hints within /* ... */
48
+ @reflection.options[:counter_sql] = @reflection.options[:finder_sql].sub(/SELECT (\/\*.*?\*\/ )?(.*)\bFROM\b/im) { "SELECT #{$1}COUNT(*) FROM" }
49
+ @counter_sql = interpolate_sql(@reflection.options[:counter_sql])
50
+ else
51
+ @counter_sql = @finder_sql
52
+ end
53
+ end
54
+ end
55
+ end
56
+ end
@@ -0,0 +1,9 @@
1
+ module HasManySelect
2
+ module VERSION #:nodoc:
3
+ MAJOR = 0
4
+ MINOR = 0
5
+ TINY = 2
6
+
7
+ STRING = [MAJOR, MINOR, TINY].join('.')
8
+ end
9
+ end
data/script/console ADDED
@@ -0,0 +1,10 @@
1
+ #!/usr/bin/env ruby
2
+ # File: script/console
3
+ irb = RUBY_PLATFORM =~ /(:?mswin|mingw)/ ? 'irb.bat' : 'irb'
4
+
5
+ libs = " -r irb/completion"
6
+ # Perhaps use a console_lib to store any extra methods I may want available in the cosole
7
+ # libs << " -r #{File.dirname(__FILE__) + '/../lib/console_lib/console_logger.rb'}"
8
+ libs << " -r #{File.dirname(__FILE__) + '/../lib/has_many_select.rb'}"
9
+ puts "Loading has_many_select gem"
10
+ exec "#{irb} #{libs} --simple-prompt"
data/script/destroy ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+ APP_ROOT = File.expand_path(File.join(File.dirname(__FILE__), '..'))
3
+
4
+ begin
5
+ require 'rubigen'
6
+ rescue LoadError
7
+ require 'rubygems'
8
+ require 'rubigen'
9
+ end
10
+ require 'rubigen/scripts/destroy'
11
+
12
+ ARGV.shift if ['--help', '-h'].include?(ARGV[0])
13
+ RubiGen::Base.use_component_sources! [:rubygems, :newgem, :newgem_theme, :test_unit]
14
+ RubiGen::Scripts::Destroy.new.run(ARGV)
data/script/generate ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+ APP_ROOT = File.expand_path(File.join(File.dirname(__FILE__), '..'))
3
+
4
+ begin
5
+ require 'rubigen'
6
+ rescue LoadError
7
+ require 'rubygems'
8
+ require 'rubigen'
9
+ end
10
+ require 'rubigen/scripts/generate'
11
+
12
+ ARGV.shift if ['--help', '-h'].include?(ARGV[0])
13
+ RubiGen::Base.use_component_sources! [:rubygems, :newgem, :newgem_theme, :test_unit]
14
+ RubiGen::Scripts::Generate.new.run(ARGV)
data/script/txt2html ADDED
@@ -0,0 +1,82 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ GEM_NAME = 'has_many_select' # what ppl will type to install your gem
4
+ RUBYFORGE_PROJECT = 'has_many_select'
5
+
6
+ require 'rubygems'
7
+ begin
8
+ require 'newgem'
9
+ require 'rubyforge'
10
+ rescue LoadError
11
+ puts "\n\nGenerating the website requires the newgem RubyGem"
12
+ puts "Install: gem install newgem\n\n"
13
+ exit(1)
14
+ end
15
+ require 'redcloth'
16
+ require 'syntax/convertors/html'
17
+ require 'erb'
18
+ require File.dirname(__FILE__) + "/../lib/#{GEM_NAME}/version.rb"
19
+
20
+ version = HasManySelect::VERSION::STRING
21
+ download = "http://rubyforge.org/projects/#{RUBYFORGE_PROJECT}"
22
+
23
+ def rubyforge_project_id
24
+ RubyForge.new.autoconfig["group_ids"][RUBYFORGE_PROJECT]
25
+ end
26
+
27
+ class Fixnum
28
+ def ordinal
29
+ # teens
30
+ return 'th' if (10..19).include?(self % 100)
31
+ # others
32
+ case self % 10
33
+ when 1: return 'st'
34
+ when 2: return 'nd'
35
+ when 3: return 'rd'
36
+ else return 'th'
37
+ end
38
+ end
39
+ end
40
+
41
+ class Time
42
+ def pretty
43
+ return "#{mday}#{mday.ordinal} #{strftime('%B')} #{year}"
44
+ end
45
+ end
46
+
47
+ def convert_syntax(syntax, source)
48
+ return Syntax::Convertors::HTML.for_syntax(syntax).convert(source).gsub(%r!^<pre>|</pre>$!,'')
49
+ end
50
+
51
+ if ARGV.length >= 1
52
+ src, template = ARGV
53
+ template ||= File.join(File.dirname(__FILE__), '/../website/template.html.erb')
54
+ else
55
+ puts("Usage: #{File.split($0).last} source.txt [template.html.erb] > output.html")
56
+ exit!
57
+ end
58
+
59
+ template = ERB.new(File.open(template).read)
60
+
61
+ title = nil
62
+ body = nil
63
+ File.open(src) do |fsrc|
64
+ title_text = fsrc.readline
65
+ body_text_template = fsrc.read
66
+ body_text = ERB.new(body_text_template).result(binding)
67
+ syntax_items = []
68
+ body_text.gsub!(%r!<(pre|code)[^>]*?syntax=['"]([^'"]+)[^>]*>(.*?)</\1>!m){
69
+ ident = syntax_items.length
70
+ element, syntax, source = $1, $2, $3
71
+ syntax_items << "<#{element} class='syntax'>#{convert_syntax(syntax, source)}</#{element}>"
72
+ "syntax-temp-#{ident}"
73
+ }
74
+ title = RedCloth.new(title_text).to_html.gsub(%r!<.*?>!,'').strip
75
+ body = RedCloth.new(body_text).to_html
76
+ body.gsub!(%r!(?:<pre><code>)?syntax-temp-(\d+)(?:</code></pre>)?!){ syntax_items[$1.to_i] }
77
+ end
78
+ stat = File.stat(src)
79
+ created = stat.ctime
80
+ modified = stat.mtime
81
+
82
+ $stdout << template.result(binding)