spok 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 81c3ccce2886f257f49bbb8ddd91d8758594cc799eefd975e34c563f958bed71
4
+ data.tar.gz: bfffef121638849c52dd3f25cb1712c1accc9bcf2288c2ad5077c3f9a2628045
5
+ SHA512:
6
+ metadata.gz: f4c39525eb0c22b85cdd4906f34f290c802dc4a27afc9aaa0a6f61858c3f29a49baf007e6ede03e3eed0993a30cfa9e24e3295af437a7f570df26d822785b7fe
7
+ data.tar.gz: f39f10f38183cd427ddc579c09189daefdff7640cdd94e8796d5e2a9109fc2e7bbd2e66adf1762554a4e0fa03e148e779a555734d5fe3672fade587fa0e0a928
data/CHANGELOG.md ADDED
@@ -0,0 +1,7 @@
1
+ # Change log
2
+
3
+ All notable changes to this project will be documented in this file.
4
+ This project adheres to [Semantic Versioning](http://semver.org/).
5
+
6
+ ## [1.0.0] - 2018-09-14
7
+ - First public release.
@@ -0,0 +1,71 @@
1
+ # Contributor Code of Conduct
2
+
3
+ ## Our Pledge
4
+
5
+ In the interest of fostering an open and welcoming environment, we as
6
+ contributors and maintainers pledge to making participation in our project and
7
+ our community a harassment-free experience for everyone, regardless of age, body
8
+ size, disability, ethnicity, gender identity and expression, level of experience,
9
+ education, socio-economic status, nationality, personal appearance, race,
10
+ religion, or sexual identity and orientation.
11
+
12
+ ## Our Standards
13
+
14
+ Examples of behavior that contributes to creating a positive environment
15
+ include:
16
+
17
+ * Using welcoming and inclusive language
18
+ * Being respectful of differing viewpoints and experiences
19
+ * Gracefully accepting constructive criticism
20
+ * Focusing on what is best for the community
21
+ * Showing empathy towards other community members
22
+
23
+ Examples of unacceptable behavior by participants include:
24
+
25
+ * The use of sexualized language or imagery and unwelcome sexual attention or
26
+ advances
27
+ * Trolling, insulting/derogatory comments, and personal or political attacks
28
+ * Public or private harassment
29
+ * Publishing others' private information, such as a physical or electronic
30
+ address, without explicit permission
31
+ * Other conduct which could reasonably be considered inappropriate in a
32
+ professional setting
33
+
34
+ ## Our Responsibilities
35
+
36
+ Project maintainers are responsible for clarifying the standards of acceptable
37
+ behavior and are expected to take appropriate and fair corrective action in
38
+ response to any instances of unacceptable behavior.
39
+
40
+ Project maintainers have the right and responsibility to remove, edit, or
41
+ reject comments, commits, code, wiki edits, issues, and other contributions
42
+ that are not aligned to this Code of Conduct, or to ban temporarily or
43
+ permanently any contributor for other behaviors that they deem inappropriate,
44
+ threatening, offensive, or harmful.
45
+
46
+ ## Scope
47
+
48
+ This Code of Conduct applies both within project spaces and in public spaces
49
+ when an individual is representing the project or its community. Examples of
50
+ representing a project or community include using an official project e-mail
51
+ address, posting via an official social media account, or acting as an appointed
52
+ representative at an online or offline event. Representation of a project may be
53
+ further defined and clarified by project maintainers.
54
+
55
+ ## Enforcement
56
+
57
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be
58
+ reported by contacting the project team at dev@magnetis.com.br. All
59
+ complaints will be reviewed and investigated and will result in a response that
60
+ is deemed necessary and appropriate to the circumstances. The project team is
61
+ obligated to maintain confidentiality with regard to the reporter of an incident.
62
+ Further details of specific enforcement policies may be posted separately.
63
+
64
+ Project maintainers who do not follow or enforce the Code of Conduct in good
65
+ faith may face temporary or permanent repercussions as determined by other
66
+ members of the project's leadership.
67
+
68
+ ## Attribution
69
+
70
+ This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71
+ available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
data/CONTRIBUTING.md ADDED
@@ -0,0 +1,17 @@
1
+ ## Contributing to Spok
2
+
3
+ Before contributing, please read our [Code of Conduct](https://github.com/magnetis/spok/blob/master/CODE_OF_CONDUCT.md) and [License](https://github.com/magnetis/spok/blob/master/LICENSE.txt).
4
+
5
+ #### **Did you find a bug?**
6
+
7
+ * **Ensure the bug was not already reported** by searching on [Issues](https://github.com/magnetis/spok/issues) page.
8
+
9
+ * If you're unable to find an open issue addressing the problem, [open a new one](https://github.com/magnetis/spok/issues/new). Please, be sure to include a **title and clear description**, as much relevant information as possible.
10
+
11
+ #### **Do you have questions about the source code?**
12
+
13
+ * You can contact us on dev@magnetis.com.br
14
+
15
+ Thanks! :heart: :tada:
16
+
17
+ Magnetis Team
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in spok.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,203 @@
1
+ Copyright 2014-2017 Magnetis http://www.magnetis.com.br
2
+
3
+ Apache License
4
+ Version 2.0, January 2004
5
+ http://www.apache.org/licenses/
6
+
7
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
8
+
9
+ 1. Definitions.
10
+
11
+ "License" shall mean the terms and conditions for use, reproduction,
12
+ and distribution as defined by Sections 1 through 9 of this document.
13
+
14
+ "Licensor" shall mean the copyright owner or entity authorized by
15
+ the copyright owner that is granting the License.
16
+
17
+ "Legal Entity" shall mean the union of the acting entity and all
18
+ other entities that control, are controlled by, or are under common
19
+ control with that entity. For the purposes of this definition,
20
+ "control" means (i) the power, direct or indirect, to cause the
21
+ direction or management of such entity, whether by contract or
22
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
23
+ outstanding shares, or (iii) beneficial ownership of such entity.
24
+
25
+ "You" (or "Your") shall mean an individual or Legal Entity
26
+ exercising permissions granted by this License.
27
+
28
+ "Source" form shall mean the preferred form for making modifications,
29
+ including but not limited to software source code, documentation
30
+ source, and configuration files.
31
+
32
+ "Object" form shall mean any form resulting from mechanical
33
+ transformation or translation of a Source form, including but
34
+ not limited to compiled object code, generated documentation,
35
+ and conversions to other media types.
36
+
37
+ "Work" shall mean the work of authorship, whether in Source or
38
+ Object form, made available under the License, as indicated by a
39
+ copyright notice that is included in or attached to the work
40
+ (an example is provided in the Appendix below).
41
+
42
+ "Derivative Works" shall mean any work, whether in Source or Object
43
+ form, that is based on (or derived from) the Work and for which the
44
+ editorial revisions, annotations, elaborations, or other modifications
45
+ represent, as a whole, an original work of authorship. For the purposes
46
+ of this License, Derivative Works shall not include works that remain
47
+ separable from, or merely link (or bind by name) to the interfaces of,
48
+ the Work and Derivative Works thereof.
49
+
50
+ "Contribution" shall mean any work of authorship, including
51
+ the original version of the Work and any modifications or additions
52
+ to that Work or Derivative Works thereof, that is intentionally
53
+ submitted to Licensor for inclusion in the Work by the copyright owner
54
+ or by an individual or Legal Entity authorized to submit on behalf of
55
+ the copyright owner. For the purposes of this definition, "submitted"
56
+ means any form of electronic, verbal, or written communication sent
57
+ to the Licensor or its representatives, including but not limited to
58
+ communication on electronic mailing lists, source code control systems,
59
+ and issue tracking systems that are managed by, or on behalf of, the
60
+ Licensor for the purpose of discussing and improving the Work, but
61
+ excluding communication that is conspicuously marked or otherwise
62
+ designated in writing by the copyright owner as "Not a Contribution."
63
+
64
+ "Contributor" shall mean Licensor and any individual or Legal Entity
65
+ on behalf of whom a Contribution has been received by Licensor and
66
+ subsequently incorporated within the Work.
67
+
68
+ 2. Grant of Copyright License. Subject to the terms and conditions of
69
+ this License, each Contributor hereby grants to You a perpetual,
70
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
71
+ copyright license to reproduce, prepare Derivative Works of,
72
+ publicly display, publicly perform, sublicense, and distribute the
73
+ Work and such Derivative Works in Source or Object form.
74
+
75
+ 3. Grant of Patent License. Subject to the terms and conditions of
76
+ this License, each Contributor hereby grants to You a perpetual,
77
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
78
+ (except as stated in this section) patent license to make, have made,
79
+ use, offer to sell, sell, import, and otherwise transfer the Work,
80
+ where such license applies only to those patent claims licensable
81
+ by such Contributor that are necessarily infringed by their
82
+ Contribution(s) alone or by combination of their Contribution(s)
83
+ with the Work to which such Contribution(s) was submitted. If You
84
+ institute patent litigation against any entity (including a
85
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
86
+ or a Contribution incorporated within the Work constitutes direct
87
+ or contributory patent infringement, then any patent licenses
88
+ granted to You under this License for that Work shall terminate
89
+ as of the date such litigation is filed.
90
+
91
+ 4. Redistribution. You may reproduce and distribute copies of the
92
+ Work or Derivative Works thereof in any medium, with or without
93
+ modifications, and in Source or Object form, provided that You
94
+ meet the following conditions:
95
+
96
+ (a) You must give any other recipients of the Work or
97
+ Derivative Works a copy of this License; and
98
+
99
+ (b) You must cause any modified files to carry prominent notices
100
+ stating that You changed the files; and
101
+
102
+ (c) You must retain, in the Source form of any Derivative Works
103
+ that You distribute, all copyright, patent, trademark, and
104
+ attribution notices from the Source form of the Work,
105
+ excluding those notices that do not pertain to any part of
106
+ the Derivative Works; and
107
+
108
+ (d) If the Work includes a "NOTICE" text file as part of its
109
+ distribution, then any Derivative Works that You distribute must
110
+ include a readable copy of the attribution notices contained
111
+ within such NOTICE file, excluding those notices that do not
112
+ pertain to any part of the Derivative Works, in at least one
113
+ of the following places: within a NOTICE text file distributed
114
+ as part of the Derivative Works; within the Source form or
115
+ documentation, if provided along with the Derivative Works; or,
116
+ within a display generated by the Derivative Works, if and
117
+ wherever such third-party notices normally appear. The contents
118
+ of the NOTICE file are for informational purposes only and
119
+ do not modify the License. You may add Your own attribution
120
+ notices within Derivative Works that You distribute, alongside
121
+ or as an addendum to the NOTICE text from the Work, provided
122
+ that such additional attribution notices cannot be construed
123
+ as modifying the License.
124
+
125
+ You may add Your own copyright statement to Your modifications and
126
+ may provide additional or different license terms and conditions
127
+ for use, reproduction, or distribution of Your modifications, or
128
+ for any such Derivative Works as a whole, provided Your use,
129
+ reproduction, and distribution of the Work otherwise complies with
130
+ the conditions stated in this License.
131
+
132
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
133
+ any Contribution intentionally submitted for inclusion in the Work
134
+ by You to the Licensor shall be under the terms and conditions of
135
+ this License, without any additional terms or conditions.
136
+ Notwithstanding the above, nothing herein shall supersede or modify
137
+ the terms of any separate license agreement you may have executed
138
+ with Licensor regarding such Contributions.
139
+
140
+ 6. Trademarks. This License does not grant permission to use the trade
141
+ names, trademarks, service marks, or product names of the Licensor,
142
+ except as required for reasonable and customary use in describing the
143
+ origin of the Work and reproducing the content of the NOTICE file.
144
+
145
+ 7. Disclaimer of Warranty. Unless required by applicable law or
146
+ agreed to in writing, Licensor provides the Work (and each
147
+ Contributor provides its Contributions) on an "AS IS" BASIS,
148
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
149
+ implied, including, without limitation, any warranties or conditions
150
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
151
+ PARTICULAR PURPOSE. You are solely responsible for determining the
152
+ appropriateness of using or redistributing the Work and assume any
153
+ risks associated with Your exercise of permissions under this License.
154
+
155
+ 8. Limitation of Liability. In no event and under no legal theory,
156
+ whether in tort (including negligence), contract, or otherwise,
157
+ unless required by applicable law (such as deliberate and grossly
158
+ negligent acts) or agreed to in writing, shall any Contributor be
159
+ liable to You for damages, including any direct, indirect, special,
160
+ incidental, or consequential damages of any character arising as a
161
+ result of this License or out of the use or inability to use the
162
+ Work (including but not limited to damages for loss of goodwill,
163
+ work stoppage, computer failure or malfunction, or any and all
164
+ other commercial damages or losses), even if such Contributor
165
+ has been advised of the possibility of such damages.
166
+
167
+ 9. Accepting Warranty or Additional Liability. While redistributing
168
+ the Work or Derivative Works thereof, You may choose to offer,
169
+ and charge a fee for, acceptance of support, warranty, indemnity,
170
+ or other liability obligations and/or rights consistent with this
171
+ License. However, in accepting such obligations, You may act only
172
+ on Your own behalf and on Your sole responsibility, not on behalf
173
+ of any other Contributor, and only if You agree to indemnify,
174
+ defend, and hold each Contributor harmless for any liability
175
+ incurred by, or claims asserted against, such Contributor by reason
176
+ of your accepting any such warranty or additional liability.
177
+
178
+ END OF TERMS AND CONDITIONS
179
+
180
+ APPENDIX: How to apply the Apache License to your work.
181
+
182
+ To apply the Apache License to your work, attach the following
183
+ boilerplate notice, with the fields enclosed by brackets "[]"
184
+ replaced with your own identifying information. (Don't include
185
+ the brackets!) The text should be enclosed in the appropriate
186
+ comment syntax for the file format. We also recommend that a
187
+ file or class name and description of purpose be included on the
188
+ same "printed page" as the copyright notice for easier
189
+ identification within third-party archives.
190
+
191
+ Copyright [yyyy] [name of copyright owner]
192
+
193
+ Licensed under the Apache License, Version 2.0 (the "License");
194
+ you may not use this file except in compliance with the License.
195
+ You may obtain a copy of the License at
196
+
197
+ http://www.apache.org/licenses/LICENSE-2.0
198
+
199
+ Unless required by applicable law or agreed to in writing, software
200
+ distributed under the License is distributed on an "AS IS" BASIS,
201
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
202
+ See the License for the specific language governing permissions and
203
+ limitations under the License.
data/README.md ADDED
@@ -0,0 +1,30 @@
1
+ # Spok
2
+
3
+ TODO: Write a gem description
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ gem 'spok'
10
+
11
+ And then execute:
12
+
13
+ $ bundle
14
+
15
+ Or install it yourself as:
16
+
17
+ $ gem install spok
18
+
19
+ ## Usage
20
+
21
+ TODO: Write usage instructions here
22
+
23
+ ## Contributing
24
+
25
+ Please read our [Contributing](CONTRIBUTING.md) guide for more information.
26
+
27
+ ## License
28
+
29
+ This project is licensed under the terms of the Apache 2. Copyright 2014-2017 Magnetis http://www.magnetis.com.br
30
+ See the [LICENSE](LICENSE.txt) file for license rights and limitations (Apache 2).
data/Rakefile ADDED
@@ -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
data/lib/spok.rb ADDED
@@ -0,0 +1,213 @@
1
+ require "spok/version"
2
+ require 'spok/workday'
3
+
4
+ # Public: Class responsible for dealing with periods of Dates, considering
5
+ # workdays and restdays.
6
+ class Spok
7
+ # Internal: String specifying format for dates in the period.
8
+ DATE_FORMAT = '%Y%m%d'
9
+ attr_reader :start_date, :end_date
10
+
11
+ # Public: Parses a string into a Spok.
12
+ #
13
+ # dates_string - String containing the start and end dates for a period of
14
+ # days separated by a dash.
15
+ #
16
+ # Examples
17
+ #
18
+ # Spok.parse('20120101-20120103')
19
+ # # => #<Spok:0x00007f951e8a2ea0 ...>
20
+ #
21
+ # Spok.parse('invalid string')
22
+ # # => nil
23
+ #
24
+ # Returns a Spok or nil when the string does not contain two valid dates.
25
+ def self.parse(dates_string)
26
+ return nil unless dates_string
27
+
28
+ start_date, end_date = dates_string.split('-')
29
+
30
+ if start_date && end_date
31
+ Spok.new(::Date.parse(start_date), ::Date.parse(end_date))
32
+ else
33
+ nil
34
+ end
35
+ end
36
+
37
+ # Public: Initialize a Spok.
38
+ #
39
+ # start_date - Initial Date for the Spok.
40
+ # end_date - Final Date for Spok.
41
+ def initialize(start_date, end_date)
42
+ @start_date = start_date
43
+ @end_date = end_date
44
+ validate!
45
+ end
46
+
47
+ # Public: Returns the Spok start date as an Integer.
48
+ #
49
+ # Examples
50
+ #
51
+ # spok.start_date_as_integer
52
+ # # => 20120101
53
+ def start_date_as_integer
54
+ as_integer @start_date
55
+ end
56
+
57
+ # Public: Returns the Spok end date as an Integer.
58
+ #
59
+ # Examples
60
+ #
61
+ # spok.end_date_as_integer
62
+ # # => 20120103
63
+ def end_date_as_integer
64
+ as_integer @end_date
65
+ end
66
+
67
+ # Public: Returns the Spok start date as a String.
68
+ #
69
+ # Examples
70
+ #
71
+ # spok.start_date_as_string
72
+ # # => "20120101"
73
+ def start_date_as_string
74
+ as_string @start_date
75
+ end
76
+
77
+ # Public: Returns the Spok end date as a String.
78
+ #
79
+ # Examples
80
+ #
81
+ # spok.end_date_as_string
82
+ # # => "20120103"
83
+ def end_date_as_string
84
+ as_string @end_date
85
+ end
86
+
87
+ # Public: Returns an array containing all workdays on Spok.
88
+ #
89
+ # calendar - Symbol informing in which calendar to check for workdays
90
+ # (default: :brasil).
91
+ #
92
+ # Examples
93
+ #
94
+ # spok.workdays
95
+ # # => [Mon, 02 Jan 2012, Tue, 03 Jan 2012]
96
+ def workdays(calendar = :brasil)
97
+ (@start_date..@end_date).to_a.delete_if{ |date| Workday.restday?(date, calendar: calendar) }
98
+ end
99
+
100
+ # Public: Returns a Spok containing the same dates in a different calendar.
101
+ #
102
+ # calendar - Symbol informing calendar for new Spok (default: :bovespa).
103
+ #
104
+ # Examples
105
+ #
106
+ # spok.to_calendar(:bovespa)
107
+ # # => #<Spok:0x00007fbf122dba08 ...>
108
+ def to_calendar(calendar = :bovespa)
109
+ Spok.new(
110
+ Workday.last_workday(@start_date, calendar: calendar),
111
+ Workday.last_workday(@end_date, calendar: calendar)
112
+ )
113
+ end
114
+
115
+ # Public: Returns an array containing all Dates on Spok.
116
+ #
117
+ # Examples
118
+ #
119
+ # spok.to_a
120
+ # # => [Sun, 01 Jan 2012, Mon, 02 Jan 2012, Tue, 03 Jan 2012]
121
+ def to_a
122
+ (@start_date..@end_date).to_a
123
+ end
124
+
125
+ # Public: Returns a String containing the Spok start and end date separated
126
+ # by a dash.
127
+ #
128
+ # Examples
129
+ #
130
+ # spok.to_s
131
+ # # => "20120101-20120103"
132
+ def to_s
133
+ "#{start_date_as_string}-#{end_date_as_string}"
134
+ end
135
+
136
+ # Public: Informs whether the Spok has just one day or not.
137
+ #
138
+ # Examples
139
+ #
140
+ # spok.one_day?
141
+ # # => false
142
+ #
143
+ # Returns a boolean.
144
+ def one_day?
145
+ @start_date == @end_date
146
+ end
147
+
148
+ # Public: Returns an Integer with the number of days in the Spok.
149
+ #
150
+ # Examples
151
+ #
152
+ # spok.days_count
153
+ # # => 2
154
+ def days_count
155
+ (@end_date - @start_date).to_i
156
+ end
157
+
158
+ # Public: Returns a Float with the number of years in the Spok.
159
+ #
160
+ # Examples
161
+ #
162
+ # spok.years_count
163
+ # # => 1.6
164
+ def years_count
165
+ ((@end_date - @start_date).to_f / 365).to_f.round(1)
166
+ end
167
+
168
+ # Public: Compares the Spok with other Spok. Two spoks are considered
169
+ # equal when they are both instances of Spok, and have the same start and
170
+ # end dates.
171
+ #
172
+ # other_spok - Spok to be checked against.
173
+ #
174
+ # Examples
175
+ #
176
+ # spok == other_spok
177
+ # # => false
178
+ #
179
+ # Returns a boolean.
180
+ def ==(other_spok)
181
+ other_spok.class == self.class &&
182
+ other_spok.start_date == @start_date &&
183
+ other_spok.end_date == @end_date
184
+ end
185
+
186
+ # Public: Returns a range containing the Dates in the Spok.
187
+ #
188
+ # Examples
189
+ #
190
+ # spok.to_range
191
+ # # => Sun, 01 Jan 2012..Tue, 03 Jan 2012
192
+ def to_range
193
+ (@start_date..@end_date)
194
+ end
195
+
196
+ private
197
+
198
+ def as_string(date)
199
+ date.strftime(DATE_FORMAT)
200
+ end
201
+
202
+ def as_integer(date)
203
+ date.strftime(DATE_FORMAT).to_i
204
+ end
205
+
206
+ def validate!
207
+ raise ArgumentError.new("Start date must be present.") unless @start_date
208
+ raise ArgumentError.new("End date must be present.") unless @end_date
209
+ if @start_date > @end_date
210
+ raise ArgumentError.new("End date (#{@end_date}) must be greater or equal to start date (#{@start_date})")
211
+ end
212
+ end
213
+ end