npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

pipe-boy

v2.1.0

Published

Interactive CLI to pass output from one command as input to another

Downloads

12

Readme

pipe-boy

Interactive CLI to pass output from one command as input to another

Node 7+ required!

$ npm install --global pipe-boy

Demos

Example of previewing output from several different commands

phase 1

Example of chaining two commands together

phase 2

Example of setting up custom functions

custom functions

Example of running command (vim) inheriting terminal stdio

vim

Example of scroll bars appearing with long output

scroll bars

Example of changing config at runtime

runtime config

Help screen

$ pipe-boy --help
 ______ __               ______
|   __ \__|.-----.-----.|   __ \.-----.--.--.
|    __/  ||  _  |  -__||   __ <|  _  |  |  |
|___|  |__||   __|_____||______/|_____|___  |
          |__|                       |_____|

DESCRIPTION
    This command allows you to take output from one command, modify it, then
use it as input into another command.

    PROCESS
    Phase 1) If no arguments are passed, this phase is entered and you are
prompted to enter a command. The output of this command will be used as input
for the next. You can preview this output by pressing tab to preview on-screen,
or shift+tab to preview inside less. Once finished, press enter to move on to
phase 2.
    Phase 2) This is phase is entered once phase 1 is complete, or if any
arguments are passed when initially running this command. In this phase you are
prompted to enter another command, where the input from the previous phase is
available as $1. You can navigate each line of the output by using the arrow
keys. If a line is selected, that line will be available as $1.
    By default, the $1 string is not escaped. You can escape it by passing the
:escaped flag (see pipe-boy --controls for more info) or by setting the
alwaysEscapeInput config option (see pipe-boy config --help for more info). If
it is escaped, newlines will be replaced by spaces.

    COLORS
    Unfortunately many commands remove colored output when it's not printed
directly to a terminal. You may have to enable colors for these commands
case-by-case. You can also setup custom functions to alias commands that force
colorized output. See below.

    CUSTOM FUNCTIONS
    One drawback of this tool is that any custom aliases or functions on your
terminal are lost when executing commands. One possible solution to this is to
redefine any custom functions inside the config file
{{HOME}}/.pipe-boy/functions.sh. Every time a command is run with this tool,
these definitions will be prepended to the command string.
    Note: setting alias-es will not work, as they only take effect in
interactive shells (all commands are run inside Node's child_process, which is
not interactive).

    OPTIONS
    -c, --controls   Print controls screen.
    -h, --help       Print this help screen.
    -v, --version    Print the version of this package.

    RUNTIME CONFIG
    Providing config keys and values as CLI options can change the config
object on a per-run basis. This will not overwrite the config file. Nested keys
can be separated by a period (.). See pipe-boy config for a list of available
options.

    pipe-boy --banner.color red # runs as usual changing the banner to red

Controls screen

$ pipe-boy --controls
KEYS
     ENTER -- confirm/proceed
     TAB -- preview on-screen (if on phase 2, previews inside less)
     SHIFT+tab -- preview inside less
     ↑/↓ (up/down) -- select individual lines out of $1 *
     SHIFT+↑/↓ (up/down) -- scroll output horizontally/vertically. Hold ctrl to
scroll a half-page
     ESC cancel individual line selection *
     CTRL+r refresh/redraw
     CTRL+e erase and reset any input and output (does not change phases)

COMMANDS
     :h, :help -- print help screen
     :c, :controls -- print controls screen
     :back -- go back to phase 1 *

KEYWORDS/FLAGS
     $1 -- input from previous command or currently selected line *
     :e, :E, :escaped -- escapes input string when populating $1 *+
     :i, :I, :interactive -- inherit terminal stdio when running commands +

* -- available in phase 2
+ -- must be appended in a comment at the end of the command

Config screen

$ pipe-boy config --help
DESCRIPTION
     Command line API to manage the configuration file(s).

USAGE
     $ pipe-boy config <command> <args> ...

EXAMPLES
     $ pipe-boy config help                  # show this help screen
     $ pipe-boy config get                   # print entire config
     $ pipe-boy config get <key> ...         # print key/value pair(s)
     $ pipe-boy config set <key> <value> ... # set key/value pair(s)
     $ pipe-boy config reset                 # reset entire config file back to
defaults
     $ pipe-boy config reset <key> ...       # reset key(s) back to defaults
     $ pipe-boy config check                 # scan config for superfluous keys
     $ pipe-boy config path                  # print path to config file

OPTIONS
     FORCE_COLOR -- sets the $FORCE_COLOR environment variable when executing
commands. Defaults to true.
     setCwdOnCd -- attempts to detect when cd is present and sets the working
directory for sub commands (used during phase 2). Defaults to true.
     alwaysEscapeInput -- escapes input string when populating $1. Defaults to
false.
     banner.text -- the text used as the banner. Defaults to PipeBoy.
     banner.font -- the font used as the banner. Defaults to chunky.
     banner.color -- the color used as the banner. Defaults to green.
     banner.horizontalLayout -- the horizontalLayout used as the banner.
Defaults to default.
     banner.verticalLayout -- the verticalLayout used as the banner. Defaults
to default.

NOTE ABOUT BANNER
     PipeBoy makes use of the amazing figlet npm package to make the banner.
For more information on banner options or to see a full list of available
fonts, see https://www.npmjs.com/package/figlet.