Array (original) (raw)

Methods

D

E

F

I

S

T

W

Class Public methods

Wraps its argument in an array unless it is already an array (or array-like).

Specifically:

This method is similar in purpose to Kernel#Array, but there are some differences:

The last point is easily explained with some enumerables:

Array(foo: :bar)
Array.wrap(foo: :bar)

There’s also a related idiom that uses the splat operator:

[*object]

which returns [] for nil, but calls to Array(object) otherwise.

The differences with Kernel#Array explained above apply to the rest of objects.

Source: show | on GitHub

def self.wrap(object) if object.nil? [] elsif object.respond_to?(:to_ary) object.to_ary || [object] else [object] end end

Instance Public methods

Returns a deep copy of array.

array = [1, [2, 3]] dup = array.deep_dup dup[1][2] = 4

array[1][2] dup[1][2]

Returns a copy of the Array excluding the specified elements.

["David", "Rafael", "Aaron", "Todd"].excluding("Aaron", "Todd") [ [ 0, 1 ], [ 1, 0 ] ].excluding([ [ 1, 0 ] ])

Note: This is an optimization of Enumerable#excluding that uses Array#- instead of Array#reject for performance reasons.

Source: show | on GitHub

def excluding(*elements) self - elements.flatten(1) end

Removes and returns the elements for which the block returns a true value. If no block is given, an Enumerator is returned instead.

numbers = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] odd_numbers = numbers.extract! { |number| number.odd? } numbers

Extracts options from a set of arguments. Removes and returns the last element in the array if it’s a hash, otherwise returns a blank hash.

def options(*args) args.extract_options! end

options(1, 2)
options(1, 2, a: :b)

Equal to self[4].

%w( a b c d e ).fifth

Equal to self[41]. Also known as accessing “the reddit”.

(1..42).to_a.forty_two

Equal to self[3].

%w( a b c d e ).fourth

Returns the tail of the array from position.

%w( a b c d ).from(0)
%w( a b c d ).from(2)
%w( a b c d ).from(10) %w().from(0)
%w( a b c d ).from(-2) %w( a b c ).from(-10)

Source: show | on GitHub

def from(position) self[position, length] || [] end

Splits or iterates over the array in number of groups, padding any remaining slots with fill_with unless it is false.

%w(1 2 3 4 5 6 7 8 9 10).in_groups(3) {|group| p group} ["1", "2", "3", "4"] ["5", "6", "7", nil] ["8", "9", "10", nil]

%w(1 2 3 4 5 6 7 8 9 10).in_groups(3, ' ') {|group| p group} ["1", "2", "3", "4"] ["5", "6", "7", " "] ["8", "9", "10", " "]

%w(1 2 3 4 5 6 7).in_groups(3, false) {|group| p group} ["1", "2", "3"] ["4", "5"] ["6", "7"]

Source: show | on GitHub

def in_groups(number, fill_with = nil, &block)

division = size.div number modulo = size % number

groups = [] start = 0

number.times do |index| length = division + (modulo > 0 && modulo > index ? 1 : 0) groups << last_group = slice(start, length) last_group << fill_with if fill_with != false && modulo > 0 && length == division start += length end

if block_given? groups.each(&block) else groups end end

Splits or iterates over the array in groups of size number, padding any remaining slots with fill_with unless it is false.

%w(1 2 3 4 5 6 7 8 9 10).in_groups_of(3) {|group| p group} ["1", "2", "3"] ["4", "5", "6"] ["7", "8", "9"] ["10", nil, nil]

%w(1 2 3 4 5).in_groups_of(2, ' ') {|group| p group} ["1", "2"] ["3", "4"] ["5", " "]

%w(1 2 3 4 5).in_groups_of(2, false) {|group| p group} ["1", "2"] ["3", "4"] ["5"]

Source: show | on GitHub

def in_groups_of(number, fill_with = nil, &block) if number.to_i <= 0 raise ArgumentError, "Group size must be a positive integer, was #{number.inspect}" end

if fill_with == false collection = self else

padding = (number - size % number) % number
collection = dup.concat(Array.new(padding, fill_with))

end

if block_given? collection.each_slice(number, &block) else collection.each_slice(number).to_a end end

Returns a new array that includes the passed elements.

[ 1, 2, 3 ].including(4, 5) [ [ 0, 1 ] ].including([ [ 1, 0 ] ])

Source: show | on GitHub

def including(*elements) self + elements.flatten(1) end

Wraps the array in an ActiveSupport::ArrayInquirer object, which gives a friendlier way to check its string-like contents.

pets = [:cat, :dog].inquiry

pets.cat?
pets.ferret?

pets.any?(:cat, :ferret)
pets.any?(:ferret, :alligator)

Source: show | on GitHub

def inquiry ActiveSupport::ArrayInquirer.new(self) end

Equal to self[1].

%w( a b c d e ).second

Equal to self[-2].

%w( a b c d e ).second_to_last

Divides the array into one or more subarrays based on a delimiting value or the result of an optional block.

[1, 2, 3, 4, 5].split(3)
(1..10).to_a.split { |i| i % 3 == 0 }

Source: show | on GitHub

def split(value = nil, &block) arr = dup result = [] if block_given? while (idx = arr.index(&block)) result << arr.shift(idx) arr.shift end else while (idx = arr.index(value)) result << arr.shift(idx) arr.shift end end result << arr end

Equal to self[2].

%w( a b c d e ).third

Equal to self[-3].

%w( a b c d e ).third_to_last

Returns the beginning of the array up to position.

%w( a b c d ).to(0)
%w( a b c d ).to(2)
%w( a b c d ).to(10) %w().to(0)
%w( a b c d ).to(-2) %w( a b c ).to(-10)

Source: show | on GitHub

def to(position) if position >= 0 take position + 1 else self[0..position] end end

Extends Array#to_s to convert a collection of elements into a comma separated id list if :db argument is given as the format.

This method is aliased to to_formatted_s.

Blog.all.to_fs(:db)
Blog.none.to_fs(:db) [1,2].to_fs

Source: show | on GitHub

def to_fs(format = :default) case format when :db if empty? "null" else collect(&:id).join(",") end else to_s end end

Calls to_param on all its elements and joins the result with slashes. This is used by url_for in Action Pack.

Source: show | on GitHub

def to_param collect(&:to_param).join "/" end

Converts an array into a string suitable for use as a URL query string, using the given key as the param name.

['Rails', 'coding'].to_query('hobbies')

Source: show | on GitHub

def to_query(key) prefix = "#{key}[]"

if empty? nil.to_query(prefix) else collect { |value| value.to_query(prefix) }.join "&" end end

Converts the array to a comma-separated sentence where the last element is joined by the connector word.

You can pass the following options to change the default behavior. If you pass an option key that doesn’t exist in the list below, it will raise an ArgumentError.

Options

Examples

[].to_sentence
['one'].to_sentence
['one', 'two'].to_sentence
['one', 'two', 'three'].to_sentence

['one', 'two'].to_sentence(passing: 'invalid option')

['one', 'two'].to_sentence(two_words_connector: '-')

['one', 'two', 'three'].to_sentence(words_connector: ' or ', last_word_connector: ' or at least ')

Using :locale option:

['uno', 'dos'].to_sentence(locale: :es)

['uno', 'dos', 'tres'].to_sentence(locale: :es)

Source: show | on GitHub

def to_sentence(options = {}) options.assert_valid_keys(:words_connector, :two_words_connector, :last_word_connector, :locale)

default_connectors = { words_connector: ", ", two_words_connector: " and ", last_word_connector: ", and " } if options[:locale] != false && defined?(I18n) i18n_connectors = I18n.translate(:'support.array', locale: options[:locale], default: {}) default_connectors.merge!(i18n_connectors) end options = default_connectors.merge!(options)

case length when 0 +"" when 1 +"#{self[0]}" when 2 +"#{self[0]}#{options[:two_words_connector]}#{self[1]}" else +"#{self[0...-1].join(options[:words_connector])}#{options[:last_word_connector]}#{self[-1]}" end end

Returns a string that represents the array in XML by invoking to_xml on each element. Active Record collections delegate their representation in XML to this method.

All elements are expected to respond to to_xml, if any of them does not then an exception is raised.

The root node reflects the class name of the first element in plural if all elements belong to the same type and that’s not Hash:

customer.projects.to_xml

20000.0 1567 2008-04-09 ... 57230.0 1567 2008-04-15 ...

Otherwise the root element is “objects”:

[{ foo: 1, bar: 2}, { baz: 3}].to_xml

2 1 3

If the collection is empty the root element is “nil-classes” by default:

[].to_xml

To ensure a meaningful root element use the :root option:

customer_with_no_projects.projects.to_xml(root: 'projects')

By default name of the node for the children of root is root.singularize. You can change it with the :children option.

The options hash is passed downwards:

Message.all.to_xml(skip_types: true)

2008-03-07T09:58:18+01:00 1 1 2008-03-07T09:58:18+01:00 1

Source: show | on GitHub

def to_xml(options = {}) require "active_support/builder" unless defined?(Builder::XmlMarkup)

options = options.dup options[:indent] ||= 2 options[:builder] ||= Builder::XmlMarkup.new(indent: options[:indent]) options[:root] ||=
if first.class != Hash && all?(first.class) underscored = ActiveSupport::Inflector.underscore(first.class.name) ActiveSupport::Inflector.pluralize(underscored).tr("/", "_") else "objects" end

builder = options[:builder] builder.instruct! unless options.delete(:skip_instruct)

root = ActiveSupport::XmlMini.rename_key(options[:root].to_s, options) children = options.delete(:children) || root.singularize attributes = options[:skip_types] ? {} : { type: "array" }

if empty? builder.tag!(root, attributes) else builder.tag!(root, attributes) do each { |value| ActiveSupport::XmlMini.to_tag(children, value, options) } yield builder if block_given? end end end