Arbitrary Command Output Colourer 0.7.1
Details
| Size: | 43K |
| Last Update: | 2008-04-19 23:33:00 |
| OS Support: | Linux |
| License/Program Type: | GPL (GNU General Public License) |
| Publisher: | Ian Macdonald |
| Price: | $0.00 |
Description:
Arbitrary Command Output Colourer 0.7.1 is console fonts software developed by Ian Macdonald.
acoc is a regular-expression based colour formatter for programs that display output on the command-line. It works as a wrapper around the target program, executing it and capturing the stdout stream. Optionally, stderr can be redirected to stdout, so that it, too, can be manipulated. acoc then applies matching rules to patterns in the output and applies colours to those matches.
Ever wondered why the output of your favourite UNIX/Linux commands is still displayed in black-and-white after all these years?
Ever had to search back through your scroll-buffer in search of gcc errors and salient information to tell you what went wrong with your program's execution?
acoc is a regular expression based colour formatter for programs that display output on the command-line. It works as a wrapper around the target program, executing it and capturing the stdout stream. Optionally, stderr can be redirected to stdout, so that it, too, can be manipulated.
acoc then applies matching rules to patterns in the output and applies colour sets to those matches. A picture is worth a thousand words, so look at the sample screenshots in the next section.
Configuration
The configuration files used by the program are /usr/local/etc/acoc.conf, /etc/acoc.conf and ~/acoc.conf. One or more of these must exist. A sample /etc/acoc.conf is supplied with some example matching rules.
Blank lines and those that begin with a are ignored.
A program configuration stanza is introduced as follows:
[program_spec]
The square brackets are mandatory literal characters. Alternatively, the @ symbol may be used, to allow [ and ] to retain their usual semantics in program specs comprising a regular expression:
@program_spec@
program_spec is defined as one or more instances of the following component, separated by a comma:
invocation[/flags]
where invocation consists of the program's name (not including its directory path component) plus any initial arguments.
Alternatively, invocation may be a regular expression, which can be used to match multiple programs and/or command-line arguments in arbitrary order. Regular expressions are automatically anchored to the beginning of the command line.
flags, if present, is separated from 'invocation' by a slash and consists of one or more of the following characters:
a
continue to attempt to find matching patterns after the first match has been found. By default, acoc will stop processing a line and display it after the first match has been found.
e
redirect the target program's stderr to stdout, allowing it, too, to be matched by rules
p
allocate a pseudo-terminal in which to run the target program
Some programs, such as ls(1), behave differently when their stdout is not connected to a tty. Use of this option will fool the target program into believing it is outputting to a tty, rather than a pipe to acoc.
Use of this flag requires Masahiro Tomita's Ruby/TPty library to be installed. Otherwise, the flag is silently ignored.
Note that the pseudo-terminal communication enabled by this flag is one-way only, from the target program to acoc. It is thus not possible to use acoc in combination with interactive programs, such as the interactive Ruby interpreter (irb).
t
apply colour formatting even if stdout is not a tty. By default, formatting is not applied if the output stream is not attached to a terminal.
Here's an example of a line that introduces a configuration stanza:
[rpm/ae,rpmbuild/ae]
which says to apply the following rules to the rpm and rpmbuild commands, attempt to apply all matching rules, and also apply those rules to the programs' stderr stream.
Another example:
[ls/p]
This says to allocate a pseudo-terminal to ls(1), fooling it into believing that its output is being sent to a regular terminal instead of a pipe to acoc.
With this flag, the effect will be this:
$ ls
file1 file2 file3 file4 file5 file6
Without it, ls will detect that its stdout is connected to a pipe and behave accordingly:
$ ls
file1
file2
file3
file4
file5
file6
A third example:
[diff/t,rcsdiff/t,cvs diff/t,p4 diff/t]
This says that the rules that follow should be applied to all invocations of diff(1) and rcsdiff(1), as well as those invocations of cvs(1) and p4 that are followed by the argument diff.
Additionally, colouring should be applied even when stdout is not connected to a tty, so that the colours still show up when the output is displayed in a pager such as more(1) or less(1).
Yet another example:
/ps -.(e.f|f.e)/
In this example, the ps(1) command will be matched, as long as the e and f options are both passed in either order.
An alternative way to write the above spec is:
@ps -.[ef].[ef]@
There are two things to note in this alternative:
1. @ has been used to delimit the spec, because [ and ] are required for the character lists in the regular expression.
2. While this form is less specific (in that it allows matches against duplicated command line options), it makes for considerably shorter specs if one wishes to test for the inclusion of a set of more than 2 or 3 command line flags. In the original form, one must manually list all of the possible permutations, which is equal to x! (factorial). For 3 command line flags, this is 6 permutations; for 4, it is 24, etc.
Here's one more example:
[tcpdump/r]
If this were placed in ~/.acoc.conf, it would remove any matching rules that had been installed for the diff command by either /etc/acoc.conf or /usr/local/etc/acoc.conf.
After defining the program name and operational flags, matching rules can be defined. These take the following form:
/regex/[flags] colour_spec
where regex is a Ruby-compatible regular expression. The delimiting / characters can be any character, as long as that character is not present in the regular expression itself. flags, if present, consists of one or more characters from the following list:
g
find every match on the line, not just the first. When using this flag, 'regex' should not include parentheses.
colour_spec is defined as a comma-separated list of one or more colour_groups, which are defined as a plus-separated (+) list of one or more of the following:
black
blink
blue
bold
clear
concealed
cyan
dark
green
italic
magenta
negative
on_black
on_blue
on_cyan
on_green
on_magenta
on_red
on_white
on_yellow
rapid_blink
red
reset
strikethrough
underline
underscore
white
yellow
Examples of a colour_group are white+bold, black+on_white, etc. A complete colour_spec might look like this:
red+bold,white,yellow+bold,black+on_green
Except when using the g flag, each component of the regex that you wish to colour should be placed in parentheses. Text outside parentheses will be used for matching, but will not be coloured.
For example, examine the following:
/^(d+)foos(w+)/
This will match a line that starts with more or one digits, followed by the string foo and any amount of white space, followed by one or more word characters. However, only the initial group of digits and the group of word characters will be coloured. The string foo and the white space that follows it will be used for matching, but will not be coloured.
Separated from the regex by white space is the colour_spec. Usually, you will include in this as many colours (separated by commas) as you have parenthesised expressions in the regex. However, it's also permissible to have fewer. If, for example, you have three parenthesised expressions in the regex, but only two colours listed in the colour_spec, then the second colour will be used for colouring both the second and third matches.
If you have more colours listed in the colour_spec than there are parenthesised expressions in the regex, the surplus colours are ignored.
When using the g flag to perform a global match on the line, you may list as many colours as you want. The same rules apply here. If there are more matches than colours, the remaining matches will be coloured using the last colour listed. Surplus colours are ignored.
Requirements:
Term::ANSIColor module
Arbitrary Command Output Colourer 0.7.1 supports english interface languages and works with Linux.
Downloading Arbitrary Command Output Colourer 0.7.1 will take several seconds if you use fast ADSL connection.
0 comments
Add to
Arbitrary Command Output Colourer 0.7.1 Version History
Related Software
|
|
From category: Networking |
| ASN RADIUS Admin 0.5 is networking software developed by Dawid Ci&281;&380;arkiewicz. ARA&039;s goal is to create simple but convenient solution for managing the FreeRADIUS server. ARA is... |
|
|
From category: Operating-Systems |
| Mandriva Linux is the operating system of choice for users keen on all things advanced.... |
|
|
From category: Backup |
| Box Backup 0.10 is backup software developed by Ben Summers. Box Backup is an FREE, completely automatic on-line backup system for UNIX. Here are some key features of \"Box Backup\": All backe... |
|
|
From category: Recovery |
| anyfs-tools 0.84.10 is recovery software developed by Nikolaj Krivchenkov. anyfs-tools is a unix-way toolset for recovering and converting filesystems. SYNOPSIS build_it [-qvV] direct... |
|
|
From category: Operating-Systems-Linux-Distri |
| DemoLinux 3.01 is operating systems linux distri software developed by DemoLinux. The DemoLinux CD allow to use Linux without installation, disk partitioning or any other complex manipulation that... |
|
|
From category: Networking |
| BrazilFW 2.29.4 is networking software developed by Claudio Roberto. Brazilfw is a mini-distribution designed for setting up network utility services such as Internet connection sharing, firewallin... |
|
|
From category: Shells |
| bLogbook 01 is shells software developed by Fernand Boudreau. bLogbook is a shell script that makes it easy to keep notes. bLogbook project uses the file system to manage a hierarchical set of \"fo... |
|
|
From category: Benchmarks |
| bonnie++ is a hard drive/filesystem benchmark program.... |
|
|
From category: System-Administration |
| Asterisk::LDAP 0.6.0 is system administration software developed by Ben Klang. Asterisk::LDAP is a perl module for generating Asterisk 1.0 compatible configuration files from an LDAP directory tree... |
|
|
From category: System-Administration |
| CTShaper 1.1.1 is system administration software developed by Carlos Rodrigues. CTShaper is a shell-script that helps setting up a traffic shaper, using Linux\'s built-in network QoS (Quality of Se... |
|
|
From category: Filesystems |
| E2fsprogs 1.38 is filesystems software developed by Theodore Ts\'o. The Ext2 Filesystem Utilities (e2fsprogs) contain all of the standard utilities for creating, fixing, configuring , and debugging... |
|
|
From category: Networking |
| Firewall Admin 0.4 is networking software developed by Vinicius M. de Souza. Firewall Admin is not a firewall generator. This tool allows network administrators to manage iptables rules from anywhe... |
|
|
From category: Operating-Systems-Linux-Distri |
| AUSTRUMI 1.3.1 is operating systems linux distri software developed by AUSTRUMI Team. AUSTRUMI is a bootable Live CD Linux distribution with a business card size (50MB). Imagine the ability to boot... |
|
|
From category: Benchmarks |
| bonnie++ 1.03a is benchmarks software developed by Russell Coker. Bonnie++ is a benchmark suite that is aimed at performing a number of simple tests of hard drive and file system performance.... |
|
|
From category: Networking |
| Anemon Dhcp Server 0.1a is networking software developed by Mathieu Ignacio. Anemon Dhcp Server\'s goal is to create an implementation of the DHCP protocol under GPL and a lot of stuff around to f... |
Leave a comment