Lotus::Utils

Ruby core extentions and class utilities for Lotus

Status

Gem Version Build Status Coverage Code Climate Dependencies Inline Docs

Contact

Rubies

Lotus::Utils supports Ruby (MRI) 2+, JRuby 9k+ & Rubinius 2.3+

Installation

Add this line to your application's Gemfile:

gem 'lotus-utils'

And then execute:

$ bundle

Or install it yourself as:

$ gem install lotus-utils

Usage

Lotus::Utils is designed to enhance Ruby's code and stdlib. By default this gem doesn't load any code, you must require what you need.

Features

Lotus::Interactor

Standardized Service Object with small interface and rich returning result. [API doc]

Lotus::Logger

Enhanced version of Ruby's Logger. [API doc]

Lotus::Utils::Attributes

Set of attributes with indifferent access. [API doc]

Lotus::Utils::BasicObject

Enhanced version of Ruby's BasicObject. [API doc]

Lotus::Utils::Callbacks

Callbacks to decorate methods with before and after logic. It supports polymorphic callbacks (methods and procs). [API doc]

Lotus::Utils::Class

Load classes from strings. It also supports namespaces. [API doc]

Lotus::Utils::ClassAttribute

Inheritable class attributes. [API doc]

Lotus::Utils::Deprecation

Deprecate Lotus features. [API doc]

Lotus::Utils::Duplicable

Safe #dup logic for Ruby objects. [API doc]

Lotus::Utils::Escape

Safe and fast escape for URLs, HTML content and attributes. Based on OWASP/ESAPI code. [API doc]

Lotus::Utils::Hash

Enhanced version of Ruby's Hash. [API doc]

Lotus::Utils::IO

Silence Ruby warnings. [API doc]

Lotus::Utils::Inflector

Complete and customizable english inflections (pluralization and singularization). [API doc]

Lotus::Utils::Kernel

Type coercions for most common Ruby types. [API doc]

Lotus::Utils::LoadPaths

Manage directories where to find Ruby source code or web static assets. [API doc]

Lotus::Utils::PathPrefix

Safe logic to manage relative URLs. [API doc]

Lotus::Utils::String

Enhanced version of Ruby's String. [API doc]

Versioning

Lotus::Utils uses Semantic Versioning 2.0.0

Contributing

  1. Fork it ( https://github.com/lotus/utils/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

Copyright © 2014-2016 Luca Guidi – Released under MIT License