mirror of
https://github.com/github/rails.git
synced 2026-01-29 16:28:09 -05:00
Added Array#to_s(:db) that'll produce a comma-separated list of ids [DHH] Split Grouping into its own file
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4387 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
@@ -932,6 +932,14 @@ class BasicsTest < Test::Unit::TestCase
|
||||
assert_equal(41, c2.references)
|
||||
end
|
||||
|
||||
def test_quoting_arrays
|
||||
replies = Reply.find(:all, :conditions => [ "id IN (?)", topics(:first).replies.to_s(:db) ])
|
||||
assert_equal topics(:first).replies.size, replies.size
|
||||
|
||||
replies = Reply.find(:all, :conditions => [ "id IN (?)", [].to_s(:db) ])
|
||||
assert_equal 0, replies.size
|
||||
end
|
||||
|
||||
MyObject = Struct.new :attribute1, :attribute2
|
||||
|
||||
def test_serialized_attribute
|
||||
|
||||
@@ -1,5 +1,9 @@
|
||||
*SVN*
|
||||
|
||||
* Added Array#to_s(:db) that'll produce a comma-separated list of ids [DHH]. Example:
|
||||
|
||||
Purchase.find(:all, :conditions => [ "product_id IN (?)", shop.products.to_s(:db) ])
|
||||
|
||||
* Normalize classify's argument to a String so that it plays nice with Symbols. [Marcel Molina Jr.]
|
||||
|
||||
* Strip out leading schema name in classify. References #5139. [schoenm@earthlink.net]
|
||||
|
||||
@@ -1,44 +1,7 @@
|
||||
require File.dirname(__FILE__) + '/array/conversions'
|
||||
require File.dirname(__FILE__) + '/array/grouping'
|
||||
|
||||
class Array #:nodoc:
|
||||
include ActiveSupport::CoreExtensions::Array::Conversions
|
||||
|
||||
# Iterate over an array in groups of a certain size, padding any remaining
|
||||
# slots with specified value (<tt>nil</tt> by default).
|
||||
#
|
||||
# E.g.
|
||||
#
|
||||
# %w(1 2 3 4 5 6 7).in_groups_of(3) {|g| p g}
|
||||
# ["1", "2", "3"]
|
||||
# ["4", "5", "6"]
|
||||
# ["7", nil, nil]
|
||||
def in_groups_of(number, fill_with = nil, &block)
|
||||
require 'enumerator'
|
||||
collection = dup
|
||||
collection << fill_with until collection.size.modulo(number).zero?
|
||||
grouped_collection = [] unless block_given?
|
||||
collection.each_slice(number) do |group|
|
||||
block_given? ? yield(group) : grouped_collection << group
|
||||
end
|
||||
grouped_collection unless block_given?
|
||||
end
|
||||
|
||||
# Divide the array into one or more subarrays based on a delimiting +value+
|
||||
# or the result of an optional block.
|
||||
#
|
||||
# ex.
|
||||
#
|
||||
# [1, 2, 3, 4, 5].split(3) # => [[1, 2], [4, 5]]
|
||||
# (1..10).to_a.split { |i| i % 3 == 0 } # => [[1, 2], [4, 5], [7, 8], [10]]
|
||||
def split(value = nil, &block)
|
||||
block ||= Proc.new { |e| e == value }
|
||||
inject([[]]) do |results, element|
|
||||
if block.call(element)
|
||||
results << []
|
||||
else
|
||||
results.last << element
|
||||
end
|
||||
results
|
||||
end
|
||||
end
|
||||
include ActiveSupport::CoreExtensions::Array::Grouping
|
||||
end
|
||||
|
||||
@@ -26,6 +26,24 @@ module ActiveSupport #:nodoc:
|
||||
join '/'
|
||||
end
|
||||
|
||||
def self.included(klass) #:nodoc:
|
||||
klass.send(:alias_method, :to_default_s, :to_s)
|
||||
klass.send(:alias_method, :to_s, :to_formatted_s)
|
||||
end
|
||||
|
||||
def to_formatted_s(format = :default)
|
||||
case format
|
||||
when :db
|
||||
if respond_to?(:empty?) && self.empty?
|
||||
"null"
|
||||
else
|
||||
collect { |element| element.id }.join(",")
|
||||
end
|
||||
else
|
||||
to_default_s
|
||||
end
|
||||
end
|
||||
|
||||
def to_xml(options = {})
|
||||
raise "Not all elements respond to to_xml" unless all? { |e| e.respond_to? :to_xml }
|
||||
|
||||
|
||||
46
activesupport/lib/active_support/core_ext/array/grouping.rb
Normal file
46
activesupport/lib/active_support/core_ext/array/grouping.rb
Normal file
@@ -0,0 +1,46 @@
|
||||
module ActiveSupport #:nodoc:
|
||||
module CoreExtensions #:nodoc:
|
||||
module Array #:nodoc:
|
||||
module Grouping
|
||||
# Iterate over an array in groups of a certain size, padding any remaining
|
||||
# slots with specified value (<tt>nil</tt> by default).
|
||||
#
|
||||
# E.g.
|
||||
#
|
||||
# %w(1 2 3 4 5 6 7).in_groups_of(3) {|g| p g}
|
||||
# ["1", "2", "3"]
|
||||
# ["4", "5", "6"]
|
||||
# ["7", nil, nil]
|
||||
def in_groups_of(number, fill_with = nil, &block)
|
||||
require 'enumerator'
|
||||
collection = dup
|
||||
collection << fill_with until collection.size.modulo(number).zero?
|
||||
grouped_collection = [] unless block_given?
|
||||
collection.each_slice(number) do |group|
|
||||
block_given? ? yield(group) : grouped_collection << group
|
||||
end
|
||||
grouped_collection unless block_given?
|
||||
end
|
||||
|
||||
# Divide the array into one or more subarrays based on a delimiting +value+
|
||||
# or the result of an optional block.
|
||||
#
|
||||
# ex.
|
||||
#
|
||||
# [1, 2, 3, 4, 5].split(3) # => [[1, 2], [4, 5]]
|
||||
# (1..10).to_a.split { |i| i % 3 == 0 } # => [[1, 2], [4, 5], [7, 8], [10]]
|
||||
def split(value = nil, &block)
|
||||
block ||= Proc.new { |e| e == value }
|
||||
inject([[]]) do |results, element|
|
||||
if block.call(element)
|
||||
results << []
|
||||
else
|
||||
results.last << element
|
||||
end
|
||||
results
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -13,7 +13,7 @@ class ArrayExtToParamTests < Test::Unit::TestCase
|
||||
end
|
||||
end
|
||||
|
||||
class ArrayExtConversionTests < Test::Unit::TestCase
|
||||
class ArrayExtToSentenceTests < Test::Unit::TestCase
|
||||
def test_plain_array_to_sentence
|
||||
assert_equal "", [].to_sentence
|
||||
assert_equal "one", ['one'].to_sentence
|
||||
@@ -39,6 +39,19 @@ class ArrayExtConversionTests < Test::Unit::TestCase
|
||||
end
|
||||
end
|
||||
|
||||
class ArrayExtToSTests < Test::Unit::TestCase
|
||||
def test_to_s_db
|
||||
collection = [
|
||||
Class.new { def id() 1 end }.new,
|
||||
Class.new { def id() 2 end }.new,
|
||||
Class.new { def id() 3 end }.new
|
||||
]
|
||||
|
||||
assert_equal "null", [].to_s(:db)
|
||||
assert_equal "1,2,3", collection.to_s(:db)
|
||||
end
|
||||
end
|
||||
|
||||
class ArrayExtGroupingTests < Test::Unit::TestCase
|
||||
def test_group_by_with_perfect_fit
|
||||
groups = []
|
||||
|
||||
Reference in New Issue
Block a user