stable_sort 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: d61b6a670323dd69a4a5459e5f8f609200d0a9ac
4
+ data.tar.gz: e18748c4c9c95857df1605d20cd761f32a26b0f7
5
+ SHA512:
6
+ metadata.gz: 6d4c3b319970536c3a87cd08f34c6ecf100350e58f1ef9210384ca7fc0a446ee3600e0d3cbe18179d71add22dcd6b9ad45e32d0b67206e91f7bbcaf650dd6da2
7
+ data.tar.gz: 5a8a389481407b91ab209b5aa18bcced4afb7548f498e6008f9d3e02238ff7bf8f3b62a5d5a9c8e4ebcbfa70845269d31286e2e41c38c20dbe2f8498cdb1c1b4
@@ -0,0 +1,17 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --format documentation
2
+ --color
@@ -0,0 +1,3 @@
1
+ language: ruby
2
+ rvm:
3
+ - 2.0.0
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in stable_sort.gemspec
4
+ gemspec
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2013 Naoyoshi Aikawa
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,29 @@
1
+ # StableSort
2
+
3
+ TODO: Write a gem description
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ gem 'stable_sort'
10
+
11
+ And then execute:
12
+
13
+ $ bundle
14
+
15
+ Or install it yourself as:
16
+
17
+ $ gem install stable_sort
18
+
19
+ ## Usage
20
+
21
+ TODO: Write usage instructions here
22
+
23
+ ## Contributing
24
+
25
+ 1. Fork it
26
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
27
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
28
+ 4. Push to the branch (`git push origin my-new-feature`)
29
+ 5. Create new Pull Request
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
@@ -0,0 +1,6 @@
1
+ require "stable_sort/version"
2
+ require "stable_sort/extension/enumerator"
3
+ require "stable_sort/extension/array"
4
+
5
+ module StableSort
6
+ end
@@ -0,0 +1,17 @@
1
+ class Array
2
+ def stable_sort_by
3
+ sort_by.with_index{ |e, index| [yield(e), index] }
4
+ end
5
+
6
+ def stable_sort_by!
7
+ sort_by!.with_index{ |e, index| [yield(e), index] }
8
+ end
9
+
10
+ def stable_sort
11
+ stable_sort_by { |x| x }
12
+ end
13
+
14
+ def stable_sort!
15
+ stable_sort_by! { |x| x }
16
+ end
17
+ end
@@ -0,0 +1,9 @@
1
+ class Enumerator
2
+ def stable_sort_by
3
+ sort_by.with_index{ |e, index| [yield(e), index] }
4
+ end
5
+
6
+ def stable_sort
7
+ stable_sort_by { |x| x }
8
+ end
9
+ end
@@ -0,0 +1,3 @@
1
+ module StableSort
2
+ VERSION = "0.0.1"
3
+ end
@@ -0,0 +1,33 @@
1
+ require 'spec_helper'
2
+
3
+ describe Array do
4
+ describe "#stable_sort_by" do
5
+ it 'sorts stably' do
6
+ ['a', 'c', 'bd', 'fe', 'b'].sort_by { |x| x.length }.should_not eq ['a', 'c', 'b', 'bd', 'fe']
7
+ ['a', 'c', 'bd', 'fe', 'b'].stable_sort_by { |x| x.length }.should eq ['a', 'c', 'b', 'bd', 'fe']
8
+ end
9
+ end
10
+
11
+ describe "#stable_sort_by!" do
12
+ it 'sorts stably' do
13
+ arr = ['a', 'c', 'bd', 'fe', 'b']
14
+ arr.stable_sort_by! { |x| x.length }.should eq ['a', 'c', 'b', 'bd', 'fe']
15
+ arr.should eq ['a', 'c', 'b', 'bd', 'fe']
16
+ end
17
+ end
18
+
19
+ describe "#stable_sort" do
20
+ it 'sorts' do
21
+ ['a', 'c', 'bd', 'fe', 'b'].stable_sort.should eq ['a', 'b', 'bd', 'c', 'fe']
22
+ end
23
+ end
24
+
25
+ describe "#stable_sort!" do
26
+ it 'sorts' do
27
+ arr = ['a', 'c', 'bd', 'fe', 'b']
28
+ arr.stable_sort!.should eq ['a', 'b', 'bd', 'c', 'fe']
29
+ arr.should eq ['a', 'b', 'bd', 'c', 'fe']
30
+ end
31
+ end
32
+ end
33
+
@@ -0,0 +1,17 @@
1
+ require 'spec_helper'
2
+
3
+ describe Enumerator do
4
+ describe "#stable_sort_by" do
5
+ it 'sorts stably' do
6
+ ['a', 'c', 'bd', 'fe', 'b'].each.sort_by { |x| x.length }.should_not eq ['a', 'c', 'b', 'bd', 'fe'].each
7
+ ['a', 'c', 'bd', 'fe', 'b'].each.stable_sort_by { |x| x.length }.should eq ['a', 'c', 'b', 'bd', 'fe']
8
+ end
9
+ end
10
+
11
+ describe "#stable_sort" do
12
+ it 'sorts' do
13
+ ['a', 'c', 'bd', 'fe', 'b'].each.stable_sort.should eq ['a', 'b', 'bd', 'c', 'fe']
14
+ end
15
+ end
16
+ end
17
+
@@ -0,0 +1,2 @@
1
+ $LOAD_PATH.unshift File.expand_path('../../lib', __FILE__)
2
+ require 'stable_sort'
@@ -0,0 +1,7 @@
1
+ require 'spec_helper'
2
+
3
+ describe StableSort do
4
+ it 'should have a version number' do
5
+ StableSort::VERSION.should_not be_nil
6
+ end
7
+ end
@@ -0,0 +1,24 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'stable_sort/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "stable_sort"
8
+ spec.version = StableSort::VERSION
9
+ spec.authors = ["Naoyoshi Aikawa"]
10
+ spec.email = ["n.aikawa91@gmail.com"]
11
+ spec.description = %q{Add stable sort functionality}
12
+ spec.summary = %q{Add stable_sort and stable_sort_by to Array and Enumerator.}
13
+ spec.homepage = "https://github.com/awakia/ruby_stable_sort"
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files`.split($/)
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_development_dependency "bundler", "~> 1.3"
22
+ spec.add_development_dependency "rake"
23
+ spec.add_development_dependency "rspec"
24
+ end
metadata ADDED
@@ -0,0 +1,107 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: stable_sort
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Naoyoshi Aikawa
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2013-12-19 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ~>
18
+ - !ruby/object:Gem::Version
19
+ version: '1.3'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ~>
25
+ - !ruby/object:Gem::Version
26
+ version: '1.3'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '>='
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ description: Add stable sort functionality
56
+ email:
57
+ - n.aikawa91@gmail.com
58
+ executables: []
59
+ extensions: []
60
+ extra_rdoc_files: []
61
+ files:
62
+ - .gitignore
63
+ - .rspec
64
+ - .travis.yml
65
+ - Gemfile
66
+ - LICENSE.txt
67
+ - README.md
68
+ - Rakefile
69
+ - lib/stable_sort.rb
70
+ - lib/stable_sort/extension/array.rb
71
+ - lib/stable_sort/extension/enumerator.rb
72
+ - lib/stable_sort/version.rb
73
+ - spec/extension/array_spec.rb
74
+ - spec/extension/enumrator_spec.rb
75
+ - spec/spec_helper.rb
76
+ - spec/stable_sort_spec.rb
77
+ - stable_sort.gemspec
78
+ homepage: https://github.com/awakia/ruby_stable_sort
79
+ licenses:
80
+ - MIT
81
+ metadata: {}
82
+ post_install_message:
83
+ rdoc_options: []
84
+ require_paths:
85
+ - lib
86
+ required_ruby_version: !ruby/object:Gem::Requirement
87
+ requirements:
88
+ - - '>='
89
+ - !ruby/object:Gem::Version
90
+ version: '0'
91
+ required_rubygems_version: !ruby/object:Gem::Requirement
92
+ requirements:
93
+ - - '>='
94
+ - !ruby/object:Gem::Version
95
+ version: '0'
96
+ requirements: []
97
+ rubyforge_project:
98
+ rubygems_version: 2.0.3
99
+ signing_key:
100
+ specification_version: 4
101
+ summary: Add stable_sort and stable_sort_by to Array and Enumerator.
102
+ test_files:
103
+ - spec/extension/array_spec.rb
104
+ - spec/extension/enumrator_spec.rb
105
+ - spec/spec_helper.rb
106
+ - spec/stable_sort_spec.rb
107
+ has_rdoc: