Project

colored2

3.32
Low commit activity in last 3 years
A long-lived project that still receives updates
This is a heavily modified fork of http://github.com/defunkt/colored gem, with many sensible pull requests combined. Since the authors of the original gem no longer support it, this might, perhaps, be considered a good alternative. Simple gem that adds various color methods to String class, and can be used as follows: require 'colored2' puts 'this is red'.red puts 'this is red with a yellow background'.red.on.yellow puts 'this is red with and italic'.red.italic puts 'this is green bold'.green.bold << ' and regular'.green puts 'this is really bold blue on white but reversed'.bold.blue.on.white.reversed puts 'this is regular, but '.red! << 'this is red '.yellow! << ' and yellow.'.no_color! puts ('this is regular, but '.red! do 'this is red '.yellow! do ' and yellow.'.no_color! end end)
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies
 Project Readme

RSpecs Rubocop

Gem Version MIT License Gitter

Colored2

The most downloaded ANSI color gem you'll find :-)

Gem Total Downloads

Backstory

It's an actively maintained fork of Chris @defunkt Wanstrath's gem colored, which appears to be no longer supported. So instead of accepting this as a pull request, a new gem was born.

This fork comes with a slightly spruced up syntax, some additional features, and a test suite written in RSpec.

Please Consider Donating

Donate using Liberapay Donate using Liberapay

Usage

In addition to the simple syntax of the original gem, which affected only the string to the left of the method call, the new "bang" syntax affects a string to the right. If the block or a method argument is provided, the contents is wrapped in the color, and the color is then reset back.

If no block or argument is provided, the color is left open-ended, and must be explicitly reset – when using the 'bang' notation.

Complete set of colors:

  • black
  • red
  • green
  • yellow
  • blue
  • magenta
  • cyan
  • white

Complete Set of Effects

Note: previous versions used method name clear instead of no_color, which clashed with many 3rd party frameworks that defined similarly named method in the global namespace. This highlights the dangers of introducing so many words into the String namespace.

  • no_color
  • bold
  • dark
  • italic
  • underlined
  • reversed
  • plain
  • normal

Usage in Other Classes

With this gem you can add color to not just strings, but to any other class. String class is automatically decorated as soon as require 'colored2' is parsed by the ruby interpreter. Note that future versions may refrain from auto-requiring colored2/strings, and rely on explicitly requiring components they need colorized, eg require 'colored2/numbers'.

To color numbers, require the following file, which automatically decorates Integer and Float. You can also add color methods to the Object. Finally, you can add the methods to any custom class by including the Colored2 Module.

Below is an IRB — session that shows a slightly more advanced usage.

Additional Helpers

There are several additional helpers tucked onto the String class.

  • #to_bol (to beginning of the line) will rewind the cursor back to the beginning of the current line.
  • #to_eol (to end of line)

Installation

Add this line to your application's Gemfile:

gem 'colored2'

And then execute:

$ bundle

Or install it yourself as:

$ gem install colored2

Development

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Support

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/kigster/colored2.

License

The gem is available as open source under the terms of the MIT License.