No commit activity in last 3 years
No release in over 3 years
FancyOpenStruct is a subclass of OpenStruct, and is a variant of RecursiveOpenStruct. This allows you to convert nested hashes into a structure where keys and values can be navigated and modified via dot-syntax, like: foo.bar = :something. This particular gem also adds support for Hash methods (such as length or merge), and also allows you to access and modify the data structure the same way that you would handle a normal Hash.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

 Project Readme

FancyOpenStruct¶ ↑

<img src=“http://allthebadges.io/tomchapin/fancy-open-struct/badge_fury.png” alt=“Version” /> <img src=“http://allthebadges.io/tomchapin/fancy-open-struct/travis.png” alt=“Build Status” /> <img src=“http://allthebadges.io/tomchapin/fancy-open-struct/coveralls.png” alt=“Coverage” /> <img src=“http://allthebadges.io/tomchapin/fancy-open-struct/code_climate.png” alt=“Code Climate” />

FancyOpenStruct is a subclass of OpenStruct, and is a variant of RecursiveOpenStruct.

This gem allows you to convert nested hashes into a structure where keys and values can be navigated and modified via dot-syntax, like: foo.bar = :something. This particular gem also adds support for the Hash methods you know and love (such as length or merge), and also allows you to access and modify the contained data structure the same way that you would handle a normal Hash.

Usage¶ ↑

FancyOpenStruct allows for hashes within hashes to be called in a chain of methods:

require 'fancy-open-struct'

fos = FancyOpenStruct.new( { :fooa => { :foob => 'fooc' } } )

fos.fooa.foob # => 'fooc'

Also, if needed, nested hashes can still be accessed as hashes:

fos.fooa_as_a_hash # { :foob => 'fooc' }

Get and set values either via dot syntax, or hash syntax (Hash keys are handled as Symbols):

fos = FancyOpenStruct.new

fos.foo = 'bar'
fos[:foo] # 'bar'

fos[:baz] = 'qux'
fos.baz # 'qux'

fos.length # 2

FancyOpenStruct can also optionally recurse across arrays, although you have to explicitly enable it:

h = { :somearr => [ { :name => 'a'}, { :name => 'b' } ] }

fos = FancyOpenStruct.new(h, :recurse_over_arrays => true )

fos.somarr[0].name # => 'a'
fos.somarr[1].name # => 'b'

Installation¶ ↑

Available as a gem in rubygems, the default gem repository.

If you use bundler, just throw that in your gemfile :

gem 'fancy-open-struct'

You may also install the gem manually :

gem install fancy-open-struct

Note on Patches/Pull Requests¶ ↑

  • Fork the project.

  • Make your feature addition or bug fix.

  • Add tests for it. This is important so I don’t break it in a future version unintentionally.

  • Commit, do not mess with rakefile, version, or history. (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)

  • Send me a pull request. Bonus points for topic branches.

Copyright © 2014 Thomas H. Chapin. See LICENSE for details.

This gem is based on the recursive-open-struct gem by William (B.J.) Snow Orvis, which can be found here: github.com/aetherknight/recursive-open-struct