My collection of essential (and possibly nonessential) core extensions/mixins (mixins that are intended to be mixed into core classes).
I may add more as I need more, using RubyOnRail's ActiveSupport as my main source (hey, it's MIT licensed),
My strategy for adding extensions is as follows:
- if it can be a mixin, make it a mixin instead of modifying the core class directly
- only essential stuff in the modules that map to to core classes
Each extension that takes the form of a mixin shall have the following form:
CoreExt::`TargetClassOrModule`
#- contains the function version of the new functionality
CoreExt::`TargetClassOrModule`::MethodVersions
#- is intended to be `include`d into the `TargetClassOrModule`
CoreExt::String.camelize('string_argument') #=> 'StringArgument'
CoreExt::String.undescore('StringArgument') #=> 'string_argument'
String.include(CoreExt::String::MethodVersions)
'StringArgument'.underscore #=> 'string_argument'
'string_argument'.camelize #=> 'StringArgument'
I either won't be adding specialized functionality (e.g., web-related stuff, linguistic functions) or such functionality will be separated into its own optional modules.
I may simplify some of the functionality as in the case of (e.g., my version of camelize
IS the oppossite of underscore -- no special treatment for predefined acronyms) or expand it, if it fits my philosophy.
I highly recommend using the uninclude
plugin. With it, you can for example, decorate your library's entry methods to include a mixin in to a core class before it starts and uniclude it at the end. That will allow you to use a modified core class in the context of your library without polluting the outside world.
I might expose some functionality in the form of executables to support your UNIX workflow. Check out the camelCase' and
snake_case` executables.
Add this line to your application's Gemfile:
gem 'core_ext'
And then execute:
$ bundle
Or install it yourself as:
$ gem install core_ext
Use it in any way you like.
- Fork it ( https://github.com/[my-github-username]/core_xt/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
This gem uses a slightly modified version of the SemVer specification, namely:
spec.version = "BREAKING.PATCHES.NONBREAKING"
You can use this versioning with your dependency tools, only you have a somewhat stronger guarantee that your code won't break if you limit yourself to the third number, but you need to allow second level updates in order to get (security and other) patches.
Since the above-described type of versioning doesn't tell you anything about the functional state of the gem (you can go from a "hello world" to a full blown operating system
without making a breaking change, as long as your operating system prints "hello world" to the screen) (SemVer, when used correctly, doesn't tell anything about the functional state of a software package either), a second, human-friendly version number can be found in spec.metadata[:human_version]
.
The magnitude of this version number shall be made to correspond to actual functional changes in the software. If I've worked a lot on the package, I'll make it move a lot, but unless I've made breaking changes, I'll stick to only moving the third number in the spec.version
version.
This number is for you. If you see it increase a lot, it probably means much more new goodies, but is less strictly defined then the version number for the machine. (I reserve the right to later change the way I change this number).