series_joiner 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/.document ADDED
@@ -0,0 +1,5 @@
1
+ lib/**/*.rb
2
+ bin/*
3
+ -
4
+ features/**/*.feature
5
+ LICENSE.txt
data/Gemfile ADDED
@@ -0,0 +1,13 @@
1
+ source "http://rubygems.org"
2
+ # Add dependencies required to use your gem here.
3
+ # Example:
4
+ # gem "activesupport", ">= 2.3.5"
5
+
6
+ # Add dependencies to develop your gem here.
7
+ # Include everything needed to run rake, tests, features, etc.
8
+ group :development do
9
+ gem "shoulda", ">= 0"
10
+ gem "bundler", "~> 1.0.0"
11
+ gem "jeweler", "~> 1.5.2"
12
+ gem "rcov", ">= 0"
13
+ end
data/Gemfile.lock ADDED
@@ -0,0 +1,20 @@
1
+ GEM
2
+ remote: http://rubygems.org/
3
+ specs:
4
+ git (1.2.5)
5
+ jeweler (1.5.2)
6
+ bundler (~> 1.0.0)
7
+ git (>= 1.2.5)
8
+ rake
9
+ rake (0.8.7)
10
+ rcov (0.9.9)
11
+ shoulda (2.11.3)
12
+
13
+ PLATFORMS
14
+ ruby
15
+
16
+ DEPENDENCIES
17
+ bundler (~> 1.0.0)
18
+ jeweler (~> 1.5.2)
19
+ rcov
20
+ shoulda
data/LICENSE.txt ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2011 Cerebris Corporation
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/README.rdoc ADDED
@@ -0,0 +1,58 @@
1
+ = SeriesJoiner
2
+
3
+ A gem for joining items in arrays together into grammatically correct series.
4
+
5
+ SeriesJoiner extends the <tt>Array</tt> class with a <tt>join_as_series()</tt> method which is similar to the built-in <tt>join()</tt> method. However, <tt>join_as_series()</tt> allows for custom delimiters and conjunctions.
6
+
7
+ == Installation
8
+
9
+ Run the following (perhaps as sudo):
10
+
11
+ gem install series_joiner
12
+
13
+ == Bundler Configuration
14
+
15
+ Add the following to your Gemfile:
16
+
17
+ gem 'series_joiner'
18
+
19
+ == Usage
20
+
21
+ join_as_series() accepts the following options:
22
+
23
+ :delimiter # inserted between items, except for the final two (default => ',')
24
+ :final_delimiter # inserted between the final two items (if > 2), but before the conjunction (default => '')
25
+ :conjunction # inserted between the final two items (default => 'and')
26
+ :padding # inserted after delimiters, as well as before and after conjunctions (default => ' ')
27
+
28
+ By default, items are joined as follows:
29
+
30
+ ['a'].join_as_series #=> 'a'
31
+
32
+ ['a', 'b'].join_as_series #=> 'a and b'
33
+
34
+ ['a', 'b', 'c'].join_as_series #=> 'a, b and c'
35
+
36
+ ['a', 'b', 'c', 'd'].join_as_series #=> 'a, b, c and d'
37
+
38
+ Here are some examples using custom delimiters and/or conjunctions:
39
+
40
+ ['a', 'b', 'c'].join_as_series(:delimiter => ';') #=> 'a; b and c'
41
+
42
+ ['a', 'b', 'c'].join_as_series(:conjunction => 'or') #=> 'a, b or c'
43
+
44
+ ['a', 'b', 'c'].join_as_series(:delimiter => ';', :conjunction => '; or,') #=> 'a; b; or, c'
45
+
46
+ The use of the serial comma (i.e. the final comma sometimes used before the conjunction) is much debated in grammar (http://en.wikipedia.org/wiki/Serial_comma). By default, SeriesJoiner does not use the serial comma. However, the <tt>:final_delimiter</tt> option can be set to <tt>','</tt> to include it:
47
+
48
+ ['a', 'b', 'c'].join_as_series(:final_delimiter => ',') #=> 'a, b, and c'
49
+
50
+ == Implementation
51
+
52
+ This gem is generated with jeweler and uses shoulda for testing. To run tests:
53
+
54
+ rake test
55
+
56
+ == License
57
+
58
+ MIT License. Copyright (c) 2011 Cerebris Corporation. See LICENSE.txt for further details.
data/Rakefile ADDED
@@ -0,0 +1,53 @@
1
+ require 'rubygems'
2
+ require 'bundler'
3
+ begin
4
+ Bundler.setup(:default, :development)
5
+ rescue Bundler::BundlerError => e
6
+ $stderr.puts e.message
7
+ $stderr.puts "Run `bundle install` to install missing gems"
8
+ exit e.status_code
9
+ end
10
+ require 'rake'
11
+
12
+ require 'jeweler'
13
+ Jeweler::Tasks.new do |gem|
14
+ # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
15
+ gem.name = "series_joiner"
16
+ gem.homepage = "http://github.com/cerebris/series_joiner"
17
+ gem.license = "MIT"
18
+ gem.summary = "Join items in arrays together into grammatically correct series."
19
+ gem.description = "Extends Array with a join_as_series() method for joining arrays of items together into grammatically correct series. Useful for joining series like 'a, b and c'. Custom delimiters and conjunctions can be specified."
20
+ gem.email = "contact@cerebris.com"
21
+ gem.authors = ["Dan Gebhardt"]
22
+ # Include your dependencies below. Runtime dependencies are required when using your gem,
23
+ # and development dependencies are only needed for development (ie running rake tasks, tests, etc)
24
+ # gem.add_runtime_dependency 'jabber4r', '> 0.1'
25
+ # gem.add_development_dependency 'rspec', '> 1.2.3'
26
+ end
27
+ Jeweler::RubygemsDotOrgTasks.new
28
+
29
+ require 'rake/testtask'
30
+ Rake::TestTask.new(:test) do |test|
31
+ test.libs << 'lib' << 'test'
32
+ test.pattern = 'test/**/test_*.rb'
33
+ test.verbose = true
34
+ end
35
+
36
+ require 'rcov/rcovtask'
37
+ Rcov::RcovTask.new do |test|
38
+ test.libs << 'test'
39
+ test.pattern = 'test/**/test_*.rb'
40
+ test.verbose = true
41
+ end
42
+
43
+ task :default => :test
44
+
45
+ require 'rake/rdoctask'
46
+ Rake::RDocTask.new do |rdoc|
47
+ version = File.exist?('VERSION') ? File.read('VERSION') : ""
48
+
49
+ rdoc.rdoc_dir = 'rdoc'
50
+ rdoc.title = "series_joiner #{version}"
51
+ rdoc.rdoc_files.include('README*')
52
+ rdoc.rdoc_files.include('lib/**/*.rb')
53
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 1.0.0
@@ -0,0 +1,35 @@
1
+ module SeriesJoiner
2
+ # join_as_series - join items in an array together in a grammatically correct manner
3
+ #
4
+ # options:
5
+ # :delimiter => inserted between items, except for the final two (default => ',')
6
+ # :final_delimiter => inserted between the final two items (if > 2), but before the conjunction (default => '')
7
+ # :conjunction => inserted between the final two items (default => 'and')
8
+ # :padding => inserted after delimiters, as well as before and after conjunctions (default => ' ')
9
+ #
10
+ def join_as_series(options = {})
11
+ padding = options[:padding] || ' '
12
+ delimiter = options[:delimiter] || ','
13
+ final_delimiter = options[:final_delimiter] || ''
14
+ conjunction = options[:conjunction] || 'and'
15
+
16
+ sz = self.size
17
+ if sz > 0
18
+ r = self[0]
19
+ if sz > 1
20
+ if sz > 2
21
+ for i in 1..(sz - 2)
22
+ r += delimiter + padding + self[i]
23
+ end
24
+ r += final_delimiter
25
+ end
26
+ r += padding + conjunction + padding + self[sz - 1]
27
+ end
28
+ end
29
+ return r
30
+ end
31
+ end
32
+
33
+ class Array
34
+ include SeriesJoiner
35
+ end
@@ -0,0 +1,63 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run 'rake gemspec'
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = %q{series_joiner}
8
+ s.version = "1.0.0"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Dan Gebhardt"]
12
+ s.date = %q{2011-01-05}
13
+ s.description = %q{Extends Array with a join_as_series() method for joining arrays of items together into grammatically correct series. Useful for joining series like 'a, b and c'. Custom delimiters and conjunctions can be specified.}
14
+ s.email = %q{contact@cerebris.com}
15
+ s.extra_rdoc_files = [
16
+ "LICENSE.txt",
17
+ "README.rdoc"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ "Gemfile",
22
+ "Gemfile.lock",
23
+ "LICENSE.txt",
24
+ "README.rdoc",
25
+ "Rakefile",
26
+ "VERSION",
27
+ "lib/series_joiner.rb",
28
+ "series_joiner.gemspec",
29
+ "test/helper.rb",
30
+ "test/test_series_joiner.rb"
31
+ ]
32
+ s.homepage = %q{http://github.com/cerebris/series_joiner}
33
+ s.licenses = ["MIT"]
34
+ s.require_paths = ["lib"]
35
+ s.rubygems_version = %q{1.4.1}
36
+ s.summary = %q{Join items in arrays together into grammatically correct series.}
37
+ s.test_files = [
38
+ "test/helper.rb",
39
+ "test/test_series_joiner.rb"
40
+ ]
41
+
42
+ if s.respond_to? :specification_version then
43
+ s.specification_version = 3
44
+
45
+ if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
46
+ s.add_development_dependency(%q<shoulda>, [">= 0"])
47
+ s.add_development_dependency(%q<bundler>, ["~> 1.0.0"])
48
+ s.add_development_dependency(%q<jeweler>, ["~> 1.5.2"])
49
+ s.add_development_dependency(%q<rcov>, [">= 0"])
50
+ else
51
+ s.add_dependency(%q<shoulda>, [">= 0"])
52
+ s.add_dependency(%q<bundler>, ["~> 1.0.0"])
53
+ s.add_dependency(%q<jeweler>, ["~> 1.5.2"])
54
+ s.add_dependency(%q<rcov>, [">= 0"])
55
+ end
56
+ else
57
+ s.add_dependency(%q<shoulda>, [">= 0"])
58
+ s.add_dependency(%q<bundler>, ["~> 1.0.0"])
59
+ s.add_dependency(%q<jeweler>, ["~> 1.5.2"])
60
+ s.add_dependency(%q<rcov>, [">= 0"])
61
+ end
62
+ end
63
+
data/test/helper.rb ADDED
@@ -0,0 +1,18 @@
1
+ require 'rubygems'
2
+ require 'bundler'
3
+ begin
4
+ Bundler.setup(:default, :development)
5
+ rescue Bundler::BundlerError => e
6
+ $stderr.puts e.message
7
+ $stderr.puts "Run `bundle install` to install missing gems"
8
+ exit e.status_code
9
+ end
10
+ require 'test/unit'
11
+ require 'shoulda'
12
+
13
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
14
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
15
+ require 'series_joiner'
16
+
17
+ class Test::Unit::TestCase
18
+ end
@@ -0,0 +1,97 @@
1
+ require 'helper'
2
+
3
+ class TestSeriesJoiner < Test::Unit::TestCase
4
+ context "using default options" do
5
+ should "join an empty array as nil" do
6
+ assert_equal nil, [].join_as_series
7
+ end
8
+ should "join an array of one item" do
9
+ assert_equal 'a', ['a'].join_as_series
10
+ end
11
+ should "join an array of two items" do
12
+ assert_equal 'a and b', ['a', 'b'].join_as_series
13
+ end
14
+ should "join an array of three items" do
15
+ assert_equal 'a, b and c', ['a', 'b', 'c'].join_as_series
16
+ end
17
+ should "join an array of four items" do
18
+ assert_equal 'a, b, c and d', ['a', 'b', 'c', 'd'].join_as_series
19
+ end
20
+ end
21
+
22
+ context "using an 'or' conjunction" do
23
+ setup do
24
+ @options = {:conjunction => 'or'}
25
+ end
26
+
27
+ should "join an array of one item" do
28
+ assert_equal 'a', ['a'].join_as_series(@options)
29
+ end
30
+ should "join an array of two items" do
31
+ assert_equal 'a or b', ['a', 'b'].join_as_series(@options)
32
+ end
33
+ should "join an array of three items" do
34
+ assert_equal 'a, b or c', ['a', 'b', 'c'].join_as_series(@options)
35
+ end
36
+ should "join an array of four items" do
37
+ assert_equal 'a, b, c or d', ['a', 'b', 'c', 'd'].join_as_series(@options)
38
+ end
39
+ end
40
+
41
+ context "using a ';' delimiter" do
42
+ setup do
43
+ @options = {:delimiter => ';'}
44
+ end
45
+
46
+ should "join an array of one item" do
47
+ assert_equal 'a', ['a'].join_as_series(@options)
48
+ end
49
+ should "join an array of two items" do
50
+ assert_equal 'a and b', ['a', 'b'].join_as_series(@options)
51
+ end
52
+ should "join an array of three items" do
53
+ assert_equal 'a; b and c', ['a', 'b', 'c'].join_as_series(@options)
54
+ end
55
+ should "join an array of four items" do
56
+ assert_equal 'a; b; c and d', ['a', 'b', 'c', 'd'].join_as_series(@options)
57
+ end
58
+ end
59
+
60
+ context "using a ',' final delimiter" do
61
+ setup do
62
+ @options = {:final_delimiter => ','}
63
+ end
64
+
65
+ should "join an array of one item" do
66
+ assert_equal 'a', ['a'].join_as_series(@options)
67
+ end
68
+ should "join an array of two items" do
69
+ assert_equal 'a and b', ['a', 'b'].join_as_series(@options)
70
+ end
71
+ should "join an array of three items" do
72
+ assert_equal 'a, b, and c', ['a', 'b', 'c'].join_as_series(@options)
73
+ end
74
+ should "join an array of four items" do
75
+ assert_equal 'a, b, c, and d', ['a', 'b', 'c', 'd'].join_as_series(@options)
76
+ end
77
+ end
78
+
79
+ context "acting as a straight join without any padding" do
80
+ setup do
81
+ @options = {:delimiter => '/', :conjunction => '/', :padding => ''}
82
+ end
83
+
84
+ should "join an array of one item" do
85
+ assert_equal 'a', ['a'].join_as_series(@options)
86
+ end
87
+ should "join an array of two items" do
88
+ assert_equal 'a/b', ['a', 'b'].join_as_series(@options)
89
+ end
90
+ should "join an array of three items" do
91
+ assert_equal 'a/b/c', ['a', 'b', 'c'].join_as_series(@options)
92
+ end
93
+ should "join an array of four items" do
94
+ assert_equal 'a/b/c/d', ['a', 'b', 'c', 'd'].join_as_series(@options)
95
+ end
96
+ end
97
+ end
metadata ADDED
@@ -0,0 +1,138 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: series_joiner
3
+ version: !ruby/object:Gem::Version
4
+ hash: 23
5
+ prerelease:
6
+ segments:
7
+ - 1
8
+ - 0
9
+ - 0
10
+ version: 1.0.0
11
+ platform: ruby
12
+ authors:
13
+ - Dan Gebhardt
14
+ autorequire:
15
+ bindir: bin
16
+ cert_chain: []
17
+
18
+ date: 2011-01-05 00:00:00 -05:00
19
+ default_executable:
20
+ dependencies:
21
+ - !ruby/object:Gem::Dependency
22
+ prerelease: false
23
+ name: shoulda
24
+ type: :development
25
+ version_requirements: &id001 !ruby/object:Gem::Requirement
26
+ none: false
27
+ requirements:
28
+ - - ">="
29
+ - !ruby/object:Gem::Version
30
+ hash: 3
31
+ segments:
32
+ - 0
33
+ version: "0"
34
+ requirement: *id001
35
+ - !ruby/object:Gem::Dependency
36
+ prerelease: false
37
+ name: bundler
38
+ type: :development
39
+ version_requirements: &id002 !ruby/object:Gem::Requirement
40
+ none: false
41
+ requirements:
42
+ - - ~>
43
+ - !ruby/object:Gem::Version
44
+ hash: 23
45
+ segments:
46
+ - 1
47
+ - 0
48
+ - 0
49
+ version: 1.0.0
50
+ requirement: *id002
51
+ - !ruby/object:Gem::Dependency
52
+ prerelease: false
53
+ name: jeweler
54
+ type: :development
55
+ version_requirements: &id003 !ruby/object:Gem::Requirement
56
+ none: false
57
+ requirements:
58
+ - - ~>
59
+ - !ruby/object:Gem::Version
60
+ hash: 7
61
+ segments:
62
+ - 1
63
+ - 5
64
+ - 2
65
+ version: 1.5.2
66
+ requirement: *id003
67
+ - !ruby/object:Gem::Dependency
68
+ prerelease: false
69
+ name: rcov
70
+ type: :development
71
+ version_requirements: &id004 !ruby/object:Gem::Requirement
72
+ none: false
73
+ requirements:
74
+ - - ">="
75
+ - !ruby/object:Gem::Version
76
+ hash: 3
77
+ segments:
78
+ - 0
79
+ version: "0"
80
+ requirement: *id004
81
+ description: Extends Array with a join_as_series() method for joining arrays of items together into grammatically correct series. Useful for joining series like 'a, b and c'. Custom delimiters and conjunctions can be specified.
82
+ email: contact@cerebris.com
83
+ executables: []
84
+
85
+ extensions: []
86
+
87
+ extra_rdoc_files:
88
+ - LICENSE.txt
89
+ - README.rdoc
90
+ files:
91
+ - .document
92
+ - Gemfile
93
+ - Gemfile.lock
94
+ - LICENSE.txt
95
+ - README.rdoc
96
+ - Rakefile
97
+ - VERSION
98
+ - lib/series_joiner.rb
99
+ - series_joiner.gemspec
100
+ - test/helper.rb
101
+ - test/test_series_joiner.rb
102
+ has_rdoc: true
103
+ homepage: http://github.com/cerebris/series_joiner
104
+ licenses:
105
+ - MIT
106
+ post_install_message:
107
+ rdoc_options: []
108
+
109
+ require_paths:
110
+ - lib
111
+ required_ruby_version: !ruby/object:Gem::Requirement
112
+ none: false
113
+ requirements:
114
+ - - ">="
115
+ - !ruby/object:Gem::Version
116
+ hash: 3
117
+ segments:
118
+ - 0
119
+ version: "0"
120
+ required_rubygems_version: !ruby/object:Gem::Requirement
121
+ none: false
122
+ requirements:
123
+ - - ">="
124
+ - !ruby/object:Gem::Version
125
+ hash: 3
126
+ segments:
127
+ - 0
128
+ version: "0"
129
+ requirements: []
130
+
131
+ rubyforge_project:
132
+ rubygems_version: 1.4.1
133
+ signing_key:
134
+ specification_version: 3
135
+ summary: Join items in arrays together into grammatically correct series.
136
+ test_files:
137
+ - test/helper.rb
138
+ - test/test_series_joiner.rb