MonkeySupport

MonkeySupport is a collection of monkeypatches to Rails, replacing existing methods with (somewhat) optimized C equivalents.

If this interests you, you should also check out methodmissing's excellent HashWithIndifferentAccess at http://github.com/methodmissing/hwia .

Modules

MonkeySupport is largely a bunch of modules, each overwriting a part of ActiveSupport. By setting $MonkeyModuleExcludes to an array of module names before loading MonkeySupport, those modules will not be loaded. For example:

$MonkeyModuleExcludes = ["inflector", "output_safety"]
require 'monkeysupport'

You can also specify a whitelist of modules to load with $MonkeyModuleIncludes, if you'd like. Typically, leaving both these variables undefined is what you'll want, though.

MonkeySupport is currently comprised of the following modules:

  • inflector
  • output_safety

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.

Testing

There are some simple specs in ./spec. To run against the activesupport test suite, add require 'monkeysupport' below the activesupport requires in activesupport's Rakefile. and rake away.

Problems / TODO

  • Certain functions used to be memoized, then rails added test cases for adding new inflections on the fly. The memoization is currently disabled, but could be tweaked to be invalidated when the inflection rules change.
  • Need to do a better job of identifying ruby versions for output_safety module.
  • There's always more to port...

Copyright (c) 2009 Burke Libbey. MIT License. See LICENSE for details.