Project

sc-ansi

0.0
No commit activity in last 3 years
No release in over 3 years
Handles every aspect (that I could think of) of dealing with ANSI escape sequences.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 1.2.9

Runtime

>= 1.2.1
 Project Readme

sc-ansi¶ ↑

Handles every aspect (that I could think of) of dealing with ANSI escape sequences. You can produce ANSI codes easily enough:

require 'sc-ansi'                              # or just require 'ansi' if you prefer.

"a string!".red                                #=> a red string!
"a string!".blue                               #=> a blue string!
"a string!".red + "another string!".blue       #=> a red string and a blue string!

# or...
include ANSI

red  { "a string!" }                           #=> a red string!
blue { "a string!" }                           #=> a blue string!

red + "a string!" + blue + "another string!"   #=> a red string and a blue string!

Parsing ANSI Codes¶ ↑

The unique thing about sc-ansi is that it can also parse ANSI codes out of an input string. Useful if you’re writing your own console application and you want to interpret, say, the UP arrow for history recall.

include ANSI                                   # for the escape codes

string = move_up + " hello " + move_down       #=> "\e[A hello \e[B"
string.ansi_sequences                          #=> [ ANSI::CURSOR_UP, ANSI::CURSOR_DOWN ]

string.replace_ansi do |sequence|              # sequence is an instance of ANSI::Match
  case sequence
    when ANSI::CURSOR_UP                       # or ANSI::CUU
      "(up)"
    when ANSI::CURSOR_DOWN                     # or ANSI::CUD
      "(down)" 
  end
end
#=> "(up) hello (down)"

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.

Copyright © 2010 Colin MacKenzie IV. See LICENSE for details.