FancyOpenStruct

<img src=“http://allthebadges.io/tomchapin/fancy-open-struct/badge_fury.png” alt=“Version” /> <img src=“http://allthebadges.io/tomchapin/fancy-open-struct/gemnasium.png” alt=“Dependencies” /> <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