Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aetherknight/recursive-open-struct
OpenStruct subclass that returns nested hash attributes as RecursiveOpenStructs
https://github.com/aetherknight/recursive-open-struct
openstruct-subclass ruby
Last synced: 4 days ago
JSON representation
OpenStruct subclass that returns nested hash attributes as RecursiveOpenStructs
- Host: GitHub
- URL: https://github.com/aetherknight/recursive-open-struct
- Owner: aetherknight
- License: other
- Created: 2010-01-12T11:14:06.000Z (about 15 years ago)
- Default Branch: main
- Last Pushed: 2024-10-04T05:53:40.000Z (4 months ago)
- Last Synced: 2025-01-04T09:13:09.179Z (23 days ago)
- Topics: openstruct-subclass, ruby
- Language: Ruby
- Homepage:
- Size: 185 KB
- Stars: 285
- Watchers: 11
- Forks: 53
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Authors: AUTHORS.txt
Awesome Lists containing this project
README
# recursive-open-struct
OpenStruct subclass that returns nested hash attributes as
RecursiveOpenStructs.## Usage
It allows for hashes within hashes to be called in a chain of methods:
```ruby
ros = RecursiveOpenStruct.new( { wha: { tagoo: 'siam' } } )ros.wha.tagoo # => 'siam'
```Also, if needed, nested hashes can still be accessed as hashes:
```ruby
ros.wha_as_a_hash # { tagoo: 'siam' }
```### Optional: Recurse Over Arrays
RecursiveOpenStruct can also optionally recurse across arrays, although you
have to explicitly enable it.Default behavior:
```ruby
h = { :somearr => [ { name: 'a'}, { name: 'b' } ] }ros = RecursiveOpenStruct.new(h)
ros.somearr # => [ { name: 'a'}, { name: 'b' } ]
```Enabling `recurse_over_arrays`:
```ruby
ros = RecursiveOpenStruct.new(h, recurse_over_arrays: true )ros.somearr[0].name # => 'a'
ros.somearr[1].name # => 'b'
```### Optional: Preserve Original Keys
Also, by default it will turn all hash keys into symbols internally:
```ruby
h = { 'fear' => 'is', 'the' => 'mindkiller' } }
ros = RecursiveOpenStruct.new(h)
ros.to_h # => { fear: 'is', the: 'mindkiller' }
```You can preserve the original keys by enabling `:preserve_original_keys`:
```ruby
h = { 'fear' => 'is', 'the' => 'mindkiller' } }
ros = RecursiveOpenStruct.new(h, preserve_original_keys: true)
ros.to_h # => { 'fear' => 'is', 'the' => 'mindkiller' }
```### Optional: Raise error on missing attribute
This option allows to raise an error if you try to call an attribute you didn't specify in hash
```ruby
h = { 'fear' => 'is', 'the' => 'mindkiller' } }
ros = RecursiveOpenStruct.new(h, raise_on_missing: true)
ros.undefined # => undefined method `undefined' for #
```The default behaviour returns nil
```ruby
h = { 'fear' => 'is', 'the' => 'mindkiller' } }
ros = RecursiveOpenStruct.new(h)
ros.undefined # => nil
```## Installation
Available as a gem in rubygems, the default gem repository.
If you use bundler, just add recursive-open-struct to your gemfile :
```ruby
gem 'recursive-open-struct'
```You may also install the gem manually:
gem install recursive-open-struct
## Contributing
If you would like to file or fix a bug, or propose a new feature, please review
[CONTRIBUTING](CONTRIBUTING.md) first.## Supported Ruby Versions
Recursive-open-struct attempts to support just the versions of Ruby that are
still actively maintained. Once a given major/minor version of Ruby no longer
receives patches, they will no longer be supported (but recursive-open-struct
may still work). I usually update the travis.yml file to reflect this when
preparing for a new release or do some other work on recursive-open-struct.I also try to update recursive-open-struct to support new features in
OpenStruct itself as new versions of Ruby are released. However, I don't
actively monitor the status of this, so a newer feature might not work. If you
encounter such a feature, please file a bug or a PR to fix it, and I will try
to cut a new release of recursive-open-struct quickly.## SemVer Compliance
Rescursive-open-struct follows [SemVer
2.0](https://semver.org/spec/v2.0.0.html) for its versioning.## Copyright
Copyright (c) 2009-2018, The Recursive-open-struct developers (given in the
file AUTHORS.txt). See LICENSE.txt for details.