[ANN] map-1.5.0

NAME
  map.rb

SYNOPSIS
  the ruby container you've always wanted: a string/symbol indifferent
ordered
  hash that works in all rubies

  maps are rad ordered hashes that are both ordered, string/symbol
  indifferent, and have all sorts of sweetness like recursive
convertsion,
  more robust implementation than HashWithIndifferentAccess, support
for
  struct like (map.foo) access, and support for option/keyword access
which
  avoids several nasty classes of errors in many ruby libraries

INSTALL
  gem install map

URI
  http://github.com/ahoward/map

DESCRIPTION

# maps are always ordered. constructing them in an ordered fashion
builds
# them that way, although the normal hash contructor is also supported

···

#
  m = Map[:k, :v, :key, :val]
  m = Map(:k, :v, :key, :val)

  m = Map[[:k, :v], [:key, :val]]
  m = Map[{:k => :v, :key => :val}]

  m = Map.new
  m[:a] = 0
  m[:b] = 1
  m[:c] = 2

  p m.keys #=> ['a','b','c'] ### always ordered!
  p m.keys #=> [0,1,2] ### always ordered!

# maps don't care between symbol and string keys
#
  p m[:a] #=> 0
  p m["a"] #=> 0

# many functions operate in a way one would expect from an ordered
container
#
  m.update(:k2 => :v2)
  m.update(:k2, :v2)

# maps keep mapiness for even deep operations
#
  m.update :nested => {:hashes => {:are => :converted}}

# maps can give back clever little struct objects
#
  m = Map(:foo => {:bar => 42})
  s = m.struct
  p s.foo.bar #=> 42

# because option parsing is such a common use case for needing string/
symbol
# indifference map.rb comes out of the box for option support
#
  def foo(*args, &block)
    opts = Map.options(args)
    a = opts.getopt(:a)
    b = opts.getopt(:b, :default => false)
  end

  opts = Map.options(:a => 42, :b => nil, :c => false)
  opts.getopt(:a) #=> 42
  opts.getopt(:b) #=> nil
  opts.getopt(:b, :default => 42) #=> 42
  opts.getopt(:c) #=> false
  opts.getopt(:d, :default => false) #=> false

# this avoids such bugs as
#
  options = {:read_only => true}
  read_only = options[:read_only] || true # should be false but is
true

# with options this becomes
#
  options = Map.options(:read_only => true)
  read_only = options.getopt(:read_only, :default => false) #=> true

# tons more goodness, see test/map_test.rb
#

USAGE
  again, see test/map_test.rb

enjoy.

Hi, Ara, thanks for another uber cool gem. the #options made me smile :slight_smile:
btw how do i run the test...

botp@jedi2:/usr/local/lib/ruby/gems/1.9.1/gems/map-1.5.0
$ ruby test/map_test.rb
test/map_test.rb:109: syntax error, unexpected ',', expecting tASSOC
    assert{ map[:a] = {:b => {:c, 42}} }

kind regards -botp

···

On Fri, Oct 29, 2010 at 7:32 AM, ara.t.howard <ara.t.howard@gmail.com> wrote:

NAME map.rb

cfp:~/git/map > rake test
(in /Users/ahoward/src/git/map)

···

On Oct 28, 6:26 pm, botp <botp...@gmail.com> wrote:

On Fri, Oct 29, 2010 at 7:32 AM, ara.t.howard <ara.t.how...@gmail.com> wrote:
> NAME map.rb

Hi, Ara, thanks for another uber cool gem. the #options made me smile :slight_smile:
btw how do i run the test...

botp@jedi2:/usr/local/lib/ruby/gems/1.9.1/gems/map-1.5.0
$ ruby test/map_test.rb
test/map_test.rb:109: syntax error, unexpected ',', expecting tASSOC
assert{ map[:a] = {:b => {:c, 42}} }

kind regards -botp

=======================================================================================================================
@1 => /opt/local/bin/ruby -I ./lib -I ./test/lib /Users/ahoward/src/
git/map/test/map_test.rb
-----------------------------------------------------------------------------------------------------------------------
Loaded suite /Users/ahoward/src/git/map/test/map_test
Started
...................
Finished in 0.133468 seconds.

19 tests, 4404 assertions, 0 failures, 0 errors
-----------------------------------------------------------------------------------------------------------------------
@1 <= SUCCESS
-----------------------------------------------------------------------------------------------------------------------

i would love help with docs and tests. if you post your github name
i'll add you. (some people like forking, but i'm old skool ;-))

i made a mistake, there was a 1.9.x mistake in test running. github
has the fix. 1.5.1 is out.

···

On Oct 28, 6:26 pm, botp <botp...@gmail.com> wrote:

On Fri, Oct 29, 2010 at 7:32 AM, ara.t.howard <ara.t.how...@gmail.com> wrote:
> NAME map.rb

Hi, Ara, thanks for another uber cool gem. the #options made me smile :slight_smile:
btw how do i run the test...

botp@jedi2:/usr/local/lib/ruby/gems/1.9.1/gems/map-1.5.0
$ ruby test/map_test.rb
test/map_test.rb:109: syntax error, unexpected ',', expecting tASSOC
assert{ map[:a] = {:b => {:c, 42}} }

kind regards -botp