sixarm_ruby_numeric_round 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.tar.gz.sig ADDED
Binary file
data/.gemtest ADDED
File without changes
data/README.md ADDED
@@ -0,0 +1,105 @@
1
+ # SixArm.com » Ruby » <br> Numeric rounding methods
2
+
3
+ * Doc: <http://sixarm.com/sixarm_ruby_numeric_round/doc>
4
+ * Gem: <http://rubygems.org/gems/sixarm_ruby_numeric_round>
5
+ * Repo: <http://github.com/sixarm/sixarm_ruby_numeric_round>
6
+ * Email: Joel Parker Henderson, <joel@sixarm.com>
7
+
8
+
9
+ ## Introduction
10
+
11
+ Simple numeric rounding methods like #round, #floor, #ceil with various precisions.
12
+
13
+ For docs go to <http://sixarm.com/sixarm_ruby_numeric_round/doc>
14
+
15
+ Want to help? We're happy to get pull requests.
16
+
17
+
18
+ ## Install quickstart
19
+
20
+ Install:
21
+
22
+ gem install sixarm_ruby_numeric_round
23
+
24
+ Bundler:
25
+
26
+ gem "sixarm_ruby_numeric_round", "~>1.0.0"
27
+
28
+ Require:
29
+
30
+ require "sixarm_ruby_numeric_round"
31
+
32
+
33
+ ## Install with security (optional)
34
+
35
+ To enable high security for all our gems:
36
+
37
+ wget http://sixarm.com/sixarm.pem
38
+ gem cert --add sixarm.pem
39
+ gem sources --add http://sixarm.com
40
+
41
+ To install with high security:
42
+
43
+ gem install sixarm_ruby_numeric_round --test --trust-policy HighSecurity
44
+
45
+
46
+ ## Examples
47
+
48
+ Round at a given decimal point:
49
+
50
+ 4.555.ceil_at(1) #=> 4.6
51
+ 4.555.floor_at(1) #=> 4.5
52
+ 4.555.round_at(1) #=> 4.6
53
+
54
+ Round to a given precision:
55
+
56
+ 4.555.ceil_to(0.1) #=> 4.6
57
+ 4.555.floor_to(0.1) #=> 4.5
58
+ 4.555.round_to(0.1) #=> 4.6
59
+
60
+ Conceptually, the methods for round, floor, and ceil will typically be for floating point numbers.
61
+ However, these methods can actually be for pretty much any Numeric object.
62
+ For example, one could round an Integer to the nearest kilo.
63
+
64
+
65
+ ## Credit
66
+
67
+ These methods are based on the Facets library for Ruby and the developer named Trans.
68
+
69
+ The #round_at and #round_to methods are exact copies and fully compatible with Facets. The rest of the methods are very similar code and fully co-existant with Facets.
70
+
71
+ We're asking the Facets team to consider including the rest of the methods.
72
+
73
+
74
+ ## Changes
75
+
76
+ * 2012-05-30 1.0.0 Create baesd on Facets methods by Trans.
77
+
78
+
79
+ ## License
80
+
81
+ You may choose any of these open source licenses:
82
+
83
+ * Apache License
84
+ * BSD License
85
+ * CreativeCommons License, Non-commercial Share Alike
86
+ * GNU General Public License Version 2 (GPL 2)
87
+ * GNU Lesser General Public License (LGPL)
88
+ * MIT License
89
+ * Perl Artistic License
90
+ * Ruby License
91
+
92
+ The software is provided "as is", without warranty of any kind,
93
+ express or implied, including but not limited to the warranties of
94
+ merchantability, fitness for a particular purpose and noninfringement.
95
+
96
+ In no event shall the authors or copyright holders be liable for any
97
+ claim, damages or other liability, whether in an action of contract,
98
+ tort or otherwise, arising from, out of or in connection with the
99
+ software or the use or other dealings in the software.
100
+
101
+ This license is for the included software that is created by SixArm;
102
+ some of the included software may have its own licenses, copyrights,
103
+ authors, etc. and these do take precedence over the SixArm license.
104
+
105
+ Copyright (c) 2005-2012 Joel Parker Henderson
data/Rakefile ADDED
@@ -0,0 +1,8 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'rake'
3
+ require 'rake/testtask'
4
+
5
+ Rake::TestTask.new(:test) do |t|
6
+ t.libs << 'lib' << 'test'
7
+ t.pattern = 'test/*.rb'
8
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 1.0.0
@@ -0,0 +1,141 @@
1
+ # -*- coding: utf-8 -*-
2
+ =begin rdoc
3
+ Please see README
4
+ =end
5
+
6
+ class Numeric
7
+
8
+ # Conceptually, ceil is expected to apply to floating point numbers.
9
+ # However it can actually be applied to pretty much any Numeric object.
10
+ # For example, one could ceil an Integer to the nearest kilo.
11
+ #
12
+ # See Float#ceil_at.
13
+
14
+ def ceil_at(*args)
15
+ to_f.ceil_at(*args)
16
+ end
17
+
18
+ # See Float#ceil_to.
19
+
20
+ def ceil_to(*args)
21
+ to_f.ceil_to(*args)
22
+ end
23
+
24
+ # Conceptually, floor is expected to apply to floating point numbers.
25
+ # However it can actually be applied to pretty much any Numeric object.
26
+ # For example, one could floor an Integer to the nearest kilo.
27
+ #
28
+ # See Float#floor_at.
29
+
30
+ def floor_at(*args)
31
+ to_f.floor_at(*args)
32
+ end
33
+
34
+ # See Float#floor_to.
35
+
36
+ def floor_to(*args)
37
+ to_f.floor_to(*args)
38
+ end
39
+
40
+ # Conceptually, round is expected to apply to floating point numbers.
41
+ # However it can actually be applied to pretty much any Numeric object.
42
+ # For example, one could round an Integer to the nearest kilo.
43
+ #
44
+ # See Float#round_at.
45
+
46
+ def round_at(*args)
47
+ to_f.round_at(*args)
48
+ end
49
+
50
+ # See Float#round_to.
51
+
52
+ def round_to(*args)
53
+ to_f.round_to(*args)
54
+ end
55
+
56
+ end
57
+
58
+ class Float
59
+
60
+ # Ceil to the given decimal position.
61
+ #
62
+ # 4.555.ceil_at(0) #=> 5.0
63
+ # 4.555.ceil_at(1) #=> 4.6
64
+ # 4.555.ceil_at(2) #=> 4.56
65
+ # 4.555.ceil_at(3) #=> 4.555
66
+ #
67
+ # CREDIT: Trans & Joel Parker Henderson
68
+
69
+ def ceil_at( d ) #d=0
70
+ (self * (10.0 ** d)).ceil.to_f / (10.0 ** d)
71
+ end
72
+
73
+ # Ceils to the nearest _n_th degree.
74
+ #
75
+ # 4.555.ceil_to(1) #=> 5.0
76
+ # 4.555.ceil_to(0.1) #=> 4.6
77
+ # 4.555.ceil_to(0.01) #=> 4.56
78
+ # 4.555.ceil_to(0) #=> 4.555
79
+ #
80
+ # CREDIT: Trans & Joel Parker Henderson
81
+
82
+ def ceil_to( n ) #n=1
83
+ return self if n == 0
84
+ (self * (1.0 / n)).ceil.to_f / (1.0 / n)
85
+ end
86
+
87
+ # Floor to the given decimal position.
88
+ #
89
+ # 4.555.floor_at(0) #=> 4.0
90
+ # 4.555.floor_at(1) #=> 4.5
91
+ # 4.555.floor_at(2) #=> 4.55
92
+ # 4.555.floor_at(3) #=> 4.555
93
+ #
94
+ # CREDIT: Trans & Joel Parker Henderson
95
+
96
+ def floor_at( d ) #d=0
97
+ (self * (10.0 ** d)).floor.to_f / (10.0 ** d)
98
+ end
99
+
100
+ # Floors to the nearest _n_th degree.
101
+ #
102
+ # 4.555.floor_to(1) #=> 4.0
103
+ # 4.555.floor_to(0.1) #=> 4.5
104
+ # 4.555.floor_to(0.01) #=> 4.55
105
+ # 4.555.floor_to(0) #=> 4.555
106
+ #
107
+ # CREDIT: Trans & Joel Parker Henderson
108
+
109
+ def floor_to( n ) #n=1
110
+ return self if n == 0
111
+ (self * (1.0 / n)).floor.to_f / (1.0 / n)
112
+ end
113
+
114
+ # Round to the given decimal position.
115
+ #
116
+ # 4.555.round_at(0) #=> 5.0
117
+ # 4.555.round_at(1) #=> 4.6
118
+ # 4.555.round_at(2) #=> 4.56
119
+ # 4.555.round_at(3) #=> 4.555
120
+ #
121
+ # CREDIT: Trans & Joel Parker Henderson
122
+
123
+ def round_at( d ) #d=0
124
+ (self * (10.0 ** d)).round.to_f / (10.0 ** d)
125
+ end
126
+
127
+ # Rounds to the nearest _n_th degree.
128
+ #
129
+ # 4.555.round_to(1) #=> 5
130
+ # 4.555.round_to(0.1) #=> 4.6
131
+ # 4.555.round_to(0.01) #=> 4.56
132
+ # 4.555.round_to(0) #=> 4.555
133
+ #
134
+ # CREDIT: Trans & Joel Parker Henderson
135
+
136
+ def round_to( n ) #n=1
137
+ return self if n == 0
138
+ (self * (1.0 / n)).round.to_f / (1.0 / n)
139
+ end
140
+
141
+ end
@@ -0,0 +1,82 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'minitest/autorun'
3
+ require 'simplecov'
4
+ SimpleCov.start
5
+ require 'sixarm_ruby_numeric_round'
6
+
7
+ describe Float do
8
+
9
+ describe "#ceil_at" do
10
+
11
+ it "works" do
12
+ 4.555.ceil_at(0).must_equal 5.0
13
+ 4.555.ceil_at(1).must_equal 4.6
14
+ 4.555.ceil_at(2).must_equal 4.56
15
+ 4.555.ceil_at(3).must_equal 4.555
16
+ end
17
+
18
+ end
19
+
20
+ describe "#ceil_to" do
21
+
22
+ it "works" do
23
+ 4.555.ceil_to(1).must_equal 5.0
24
+ 4.555.ceil_to(0.1).must_equal 4.6
25
+ 4.555.ceil_to(0.01).must_equal 4.56
26
+ 4.555.ceil_to(0).must_equal 4.555
27
+ end
28
+
29
+ end
30
+
31
+ describe "#floor_at" do
32
+
33
+ it "works" do
34
+ 4.555.floor_at(0).must_equal 4.0
35
+ 4.555.floor_at(1).must_equal 4.5
36
+ 4.555.floor_at(2).must_equal 4.55
37
+ 4.555.floor_at(3).must_equal 4.555
38
+ end
39
+
40
+ end
41
+
42
+ describe "#floor_to" do
43
+
44
+ it "works" do
45
+ 4.555.floor_to(1).must_equal 4.0
46
+ 4.555.floor_to(0.1).must_equal 4.5
47
+ 4.555.floor_to(0.01).must_equal 4.55
48
+ 4.555.floor_to(0).must_equal 4.555
49
+ end
50
+
51
+ end
52
+
53
+ describe "#round_at" do
54
+
55
+ it "works" do
56
+ 4.555.round_at(0).must_equal 5.0
57
+ 4.555.round_at(1).must_equal 4.6
58
+ 4.555.round_at(2).must_equal 4.56
59
+ 4.555.round_at(3).must_equal 4.555
60
+ end
61
+
62
+ end
63
+
64
+ describe "#round_to" do
65
+
66
+ it "works" do
67
+ 4.555.round_to(1).must_equal 5
68
+ 4.555.round_to(0.1).must_equal 4.6
69
+ 4.555.round_to(0.01).must_equal 4.56
70
+ 4.555.round_to(0).must_equal 4.555
71
+ end
72
+
73
+ end
74
+
75
+ end
76
+
77
+
78
+
79
+
80
+
81
+
82
+
metadata ADDED
@@ -0,0 +1,78 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sixarm_ruby_numeric_round
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - SixArm
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain:
12
+ - !binary |-
13
+ LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSURCRENDQW0yZ0F3SUJB
14
+ Z0lKQUtQd0VFVFU1YkhvTUEwR0NTcUdTSWIzRFFFQkJRVUFNR0F4Q3pBSkJn
15
+ TlYKQkFZVEFsVlRNUk13RVFZRFZRUUlFd3BEWVd4cFptOXlibWxoTVJZd0ZB
16
+ WURWUVFIRXcxVFlXNGdSbkpoYm1OcApjMk52TVE4d0RRWURWUVFLRXdaVGFY
17
+ aEJjbTB4RXpBUkJnTlZCQU1UQ25OcGVHRnliUzVqYjIwd0hoY05NVEF4Ck1q
18
+ RXpNak15TnpFeldoY05NVE13T1RBNE1qTXlOekV6V2pCZ01Rc3dDUVlEVlFR
19
+ R0V3SlZVekVUTUJFR0ExVUUKQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFV
20
+ RUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUE1BMEdBMVVFQ2hNRwpVMmw0UVhK
21
+ dE1STXdFUVlEVlFRREV3cHphWGhoY20wdVkyOXRNSUdmTUEwR0NTcUdTSWIz
22
+ RFFFQkFRVUFBNEdOCkFEQ0JpUUtCZ1FDOTRtRDlKRHdCc3Vuc09JMFZSM0NY
23
+ WGJPV2c5Y1dhV2Npd0Z5Sk5GaU03QTlJOEtQTGZYVXcKUUM0Y3pVZTVadUc0
24
+ V0h2aW5yV2hrckNLKzFkV0Jxb0VDbHhkRi9Gb0tPNWErdG9uR0Nqam1meTgx
25
+ Sm1Gamp5eAplVHNqc0h5dncrUWlrOWtwZjlhajYrcG5rTnJWc3dnTkhWZWEy
26
+ bzl5YWJiRWlTNlZTZUpXb1FJREFRQUJvNEhGCk1JSENNQjBHQTFVZERnUVdC
27
+ QlF6UEp0cW1TZ2M1M2VETjdhU3pEUXdyOVRBTERDQmtnWURWUjBqQklHS01J
28
+ R0gKZ0JRelBKdHFtU2djNTNlRE43YVN6RFF3cjlUQUxLRmtwR0l3WURFTE1B
29
+ a0dBMVVFQmhNQ1ZWTXhFekFSQmdOVgpCQWdUQ2tOaGJHbG1iM0p1YVdFeEZq
30
+ QVVCZ05WQkFjVERWTmhiaUJHY21GdVkybHpZMjh4RHpBTkJnTlZCQW9UCkJs
31
+ TnBlRUZ5YlRFVE1CRUdBMVVFQXhNS2MybDRZWEp0TG1OdmJZSUpBS1B3RUVU
32
+ VTViSG9NQXdHQTFVZEV3UUYKTUFNQkFmOHdEUVlKS29aSWh2Y05BUUVGQlFB
33
+ RGdZRUFvb0VleFAvb1BhbTFUUDcxU3l1aHhNYit1VHJaYlNRZQpqVkIrRXhS
34
+ d1dhZEd3YU5QVUE1NmQzOXF3YXZ3UCtpdSszSnBlb25OTVZ2YldYRjVuYUNY
35
+ L2RORkllUkVIekVSClpEUlFZTXFydTlURU1uYTZIRDl6cGNzdEY3dndUaEdv
36
+ dmxPUSszWTZwbFE0bk16aXBYY1o5VEhxczY1UElMMHEKZWFid3BDYkFvcG89
37
+ Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K
38
+ date: 2012-05-31 00:00:00.000000000 Z
39
+ dependencies: []
40
+ description:
41
+ email: sixarm@sixarm.com
42
+ executables: []
43
+ extensions: []
44
+ extra_rdoc_files: []
45
+ files:
46
+ - .gemtest
47
+ - Rakefile
48
+ - README.md
49
+ - VERSION
50
+ - lib/sixarm_ruby_numeric_round.rb
51
+ - test/sixarm_ruby_numeric_round_test.rb
52
+ homepage: http://sixarm.com/
53
+ licenses: []
54
+ post_install_message:
55
+ rdoc_options: []
56
+ require_paths:
57
+ - lib
58
+ required_ruby_version: !ruby/object:Gem::Requirement
59
+ none: false
60
+ requirements:
61
+ - - ! '>='
62
+ - !ruby/object:Gem::Version
63
+ version: '0'
64
+ required_rubygems_version: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ! '>='
68
+ - !ruby/object:Gem::Version
69
+ version: '0'
70
+ requirements: []
71
+ rubyforge_project:
72
+ rubygems_version: 1.8.23
73
+ signing_key:
74
+ specification_version: 3
75
+ summary: SixArm.com » Ruby » Numeric round, floor, ceil methods
76
+ test_files:
77
+ - test/sixarm_ruby_numeric_round_test.rb
78
+ has_rdoc: true
metadata.gz.sig ADDED
@@ -0,0 +1,2 @@
1
+ E�����nU���'�S1��t$`�W���Ăonp�coxd�HB��+�+i��s</_�w4�C���-k����W��.g����SWR�d|�ºG��`
2
+ M?�Ӽ�N"��a� X)¤ �A��qcO