Skip to content

Commit 5066cf7

Browse files
committed
- create gem 0.1.0
1 parent c66dc20 commit 5066cf7

23 files changed

+465
-54
lines changed

.github/workflows/main.yml

Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
name: Ruby
2+
3+
on:
4+
push:
5+
branches:
6+
- master
7+
8+
pull_request:
9+
10+
jobs:
11+
build:
12+
runs-on: ubuntu-latest
13+
name: Ruby ${{ matrix.ruby }}
14+
strategy:
15+
matrix:
16+
ruby:
17+
- '3.3.7'
18+
19+
steps:
20+
- uses: actions/checkout@v4
21+
22+
- name: Set up Ruby
23+
uses: ruby/setup-ruby@v1
24+
with:
25+
ruby-version: ${{ matrix.ruby }}
26+
bundler-cache: true
27+
28+
- name: Install dependencies
29+
run: |
30+
bundle install
31+
bundle list
32+
33+
- name: Run tests
34+
run: bundle exec rake test

.gitignore

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
/.bundle/
2+
/.yardoc
3+
/_yardoc/
4+
/coverage/
5+
/doc/
6+
/pkg/
7+
/spec/reports/
8+
/tmp/
9+
.tool-versions

CHANGELOG.md

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
## [Unreleased]
2+
3+
## [0.1.0] - 2025-05-24
4+
5+
- Initial release

CODE_OF_CONDUCT.md

Lines changed: 132 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,132 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
We as members, contributors, and leaders pledge to make participation in our
6+
community a harassment-free experience for everyone, regardless of age, body
7+
size, visible or invisible disability, ethnicity, sex characteristics, gender
8+
identity and expression, level of experience, education, socio-economic status,
9+
nationality, personal appearance, race, caste, color, religion, or sexual
10+
identity and orientation.
11+
12+
We pledge to act and interact in ways that contribute to an open, welcoming,
13+
diverse, inclusive, and healthy community.
14+
15+
## Our Standards
16+
17+
Examples of behavior that contributes to a positive environment for our
18+
community include:
19+
20+
* Demonstrating empathy and kindness toward other people
21+
* Being respectful of differing opinions, viewpoints, and experiences
22+
* Giving and gracefully accepting constructive feedback
23+
* Accepting responsibility and apologizing to those affected by our mistakes,
24+
and learning from the experience
25+
* Focusing on what is best not just for us as individuals, but for the overall
26+
community
27+
28+
Examples of unacceptable behavior include:
29+
30+
* The use of sexualized language or imagery, and sexual attention or advances of
31+
any kind
32+
* Trolling, insulting or derogatory comments, and personal or political attacks
33+
* Public or private harassment
34+
* Publishing others' private information, such as a physical or email address,
35+
without their explicit permission
36+
* Other conduct which could reasonably be considered inappropriate in a
37+
professional setting
38+
39+
## Enforcement Responsibilities
40+
41+
Community leaders are responsible for clarifying and enforcing our standards of
42+
acceptable behavior and will take appropriate and fair corrective action in
43+
response to any behavior that they deem inappropriate, threatening, offensive,
44+
or harmful.
45+
46+
Community leaders have the right and responsibility to remove, edit, or reject
47+
comments, commits, code, wiki edits, issues, and other contributions that are
48+
not aligned to this Code of Conduct, and will communicate reasons for moderation
49+
decisions when appropriate.
50+
51+
## Scope
52+
53+
This Code of Conduct applies within all community spaces, and also applies when
54+
an individual is officially representing the community in public spaces.
55+
Examples of representing our community include using an official email address,
56+
posting via an official social media account, or acting as an appointed
57+
representative at an online or offline event.
58+
59+
## Enforcement
60+
61+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
62+
reported to the community leaders responsible for enforcement at
63+
[INSERT CONTACT METHOD].
64+
All complaints will be reviewed and investigated promptly and fairly.
65+
66+
All community leaders are obligated to respect the privacy and security of the
67+
reporter of any incident.
68+
69+
## Enforcement Guidelines
70+
71+
Community leaders will follow these Community Impact Guidelines in determining
72+
the consequences for any action they deem in violation of this Code of Conduct:
73+
74+
### 1. Correction
75+
76+
**Community Impact**: Use of inappropriate language or other behavior deemed
77+
unprofessional or unwelcome in the community.
78+
79+
**Consequence**: A private, written warning from community leaders, providing
80+
clarity around the nature of the violation and an explanation of why the
81+
behavior was inappropriate. A public apology may be requested.
82+
83+
### 2. Warning
84+
85+
**Community Impact**: A violation through a single incident or series of
86+
actions.
87+
88+
**Consequence**: A warning with consequences for continued behavior. No
89+
interaction with the people involved, including unsolicited interaction with
90+
those enforcing the Code of Conduct, for a specified period of time. This
91+
includes avoiding interactions in community spaces as well as external channels
92+
like social media. Violating these terms may lead to a temporary or permanent
93+
ban.
94+
95+
### 3. Temporary Ban
96+
97+
**Community Impact**: A serious violation of community standards, including
98+
sustained inappropriate behavior.
99+
100+
**Consequence**: A temporary ban from any sort of interaction or public
101+
communication with the community for a specified period of time. No public or
102+
private interaction with the people involved, including unsolicited interaction
103+
with those enforcing the Code of Conduct, is allowed during this period.
104+
Violating these terms may lead to a permanent ban.
105+
106+
### 4. Permanent Ban
107+
108+
**Community Impact**: Demonstrating a pattern of violation of community
109+
standards, including sustained inappropriate behavior, harassment of an
110+
individual, or aggression toward or disparagement of classes of individuals.
111+
112+
**Consequence**: A permanent ban from any sort of public interaction within the
113+
community.
114+
115+
## Attribution
116+
117+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118+
version 2.1, available at
119+
[https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1].
120+
121+
Community Impact Guidelines were inspired by
122+
[Mozilla's code of conduct enforcement ladder][Mozilla CoC].
123+
124+
For answers to common questions about this code of conduct, see the FAQ at
125+
[https://www.contributor-covenant.org/faq][FAQ]. Translations are available at
126+
[https://www.contributor-covenant.org/translations][translations].
127+
128+
[homepage]: https://www.contributor-covenant.org
129+
[v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html
130+
[Mozilla CoC]: https://github.com/mozilla/diversity
131+
[FAQ]: https://www.contributor-covenant.org/faq
132+
[translations]: https://www.contributor-covenant.org/translations

Gemfile

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
# frozen_string_literal: true
2+
3+
source "https://rubygems.org"
4+
5+
gemspec
6+
7+
gem "irb"
8+
gem "rake"
9+
gem "minitest"
10+
gem "minitest-reporters"

Gemfile.lock

Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
PATH
2+
remote: .
3+
specs:
4+
ruby_like_clojure (0.1.0)
5+
6+
GEM
7+
remote: https://rubygems.org/
8+
specs:
9+
ansi (1.5.0)
10+
builder (3.3.0)
11+
date (3.4.1)
12+
io-console (0.8.0)
13+
irb (1.15.1)
14+
pp (>= 0.6.0)
15+
rdoc (>= 4.0.0)
16+
reline (>= 0.4.2)
17+
minitest (5.25.4)
18+
minitest-reporters (1.7.1)
19+
ansi
20+
builder
21+
minitest (>= 5.0)
22+
ruby-progressbar
23+
pp (0.6.2)
24+
prettyprint
25+
prettyprint (0.2.0)
26+
psych (5.2.3)
27+
date
28+
stringio
29+
rake (13.2.1)
30+
rdoc (6.12.0)
31+
psych (>= 4.0.0)
32+
reline (0.6.0)
33+
io-console (~> 0.5)
34+
ruby-progressbar (1.13.0)
35+
stringio (3.1.5)
36+
37+
PLATFORMS
38+
ruby
39+
x86_64-darwin-24
40+
41+
DEPENDENCIES
42+
irb
43+
minitest
44+
minitest-reporters
45+
rake
46+
ruby_like_clojure!
47+
48+
BUNDLED WITH
49+
2.6.5

LICENSE.txt

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
The MIT License (MIT)
2+
3+
Copyright (c) 2025 Dan Sudol
4+
5+
Permission is hereby granted, free of charge, to any person obtaining a copy
6+
of this software and associated documentation files (the "Software"), to deal
7+
in the Software without restriction, including without limitation the rights
8+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
copies of the Software, and to permit persons to whom the Software is
10+
furnished to do so, subject to the following conditions:
11+
12+
The above copyright notice and this permission notice shall be included in
13+
all copies or substantial portions of the Software.
14+
15+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21+
THE SOFTWARE.

README.md

Lines changed: 74 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3,10 +3,81 @@ like:
33

44
assoc_in
55

6-
update
7-
86
update_in
97

8+
update
9+
1010
get_in
1111

12-
feel free to suggest other functions we can implement in ruby that you miss in clojure
12+
#### NOTE:
13+
These functions all return a new hash, they do not modify the original hash
14+
15+
###### feel free to suggest other functions we can implement in ruby that you miss in clojure
16+
17+
18+
## Usage
19+
20+
- assoc_in
21+
22+
```ruby
23+
RLC.assoc_in({a: 1}, [:b], 3)
24+
# => {a: 1, b: 3}
25+
```
26+
27+
```ruby
28+
RLC.assoc_in({a: 1}, [:b, :c], 3)
29+
# => {a: 1, b: {c: 3}}
30+
```
31+
32+
- update_in
33+
34+
```ruby
35+
RLC.update_in({}, [:a, :b]) { |other| (other || 0) + 2 }
36+
# => { a: { b: 2 } }
37+
```
38+
39+
```ruby
40+
RLC.update_in({ a: { b: 1 } }, [:a, :b]) { |other| (other || 0) + 2 }
41+
# => { a: { b: 3 } }
42+
```
43+
44+
- update
45+
46+
```ruby
47+
RLC.update({}, :a) { |other| (other || 0) + 2 }
48+
# => { a: 2 }
49+
```
50+
51+
```ruby
52+
RLC.update({ a: 1 }, :a) { |other| (other || 0) + 2 }
53+
# => { a: 3 }
54+
```
55+
56+
- get_in
57+
58+
```ruby
59+
RLC.get_in({ a: 1 }, [:a])
60+
# => 1
61+
```
62+
63+
```ruby
64+
RLC.get_in({ a: [1, 3] }, [:a, 1])
65+
# => 3
66+
```
67+
68+
```ruby
69+
RLC.get_in({ a: { b: 2 } }, [:a, :c])
70+
# => nil
71+
```
72+
73+
```ruby
74+
RLC.get_in({ a: { b: 2 } }, [:a, :c], 4)
75+
# => 4
76+
```
77+
78+
```ruby
79+
my_report_hash
80+
.then { HashUtils.update_in(_1, %w[reports group1], &method(:fill_in_things)) }
81+
.then { HashUtils.update_in(_1, %w[reports group2], &method(:add_things)) }
82+
# => new my_report_hash
83+
```

Rakefile

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
# frozen_string_literal: true
2+
3+
require "bundler/gem_tasks"
4+
require "minitest/test_task"
5+
6+
Minitest::TestTask.create(:test) do |t|
7+
t.libs << "test"
8+
t.test_globs = ["test/**/*_test.rb", "test/**/*_spec.rb"]
9+
end
10+
11+
task default: :test

bin/console

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
#!/usr/bin/env ruby
2+
# frozen_string_literal: true
3+
4+
require "bundler/setup"
5+
require "ruby_like_clojure"
6+
7+
# You can add fixtures and/or initialization code here to make experimenting
8+
# with your gem easier. You can also use a different console, if you like.
9+
10+
require "irb"
11+
IRB.start(__FILE__)

0 commit comments

Comments
 (0)