Project

subshell

0.0
No commit activity in last 3 years
No release in over 3 years
Flexible library for running subshell commands with reasonable defaults.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.13
~> 5.0
~> 10.0
 Project Readme

Subshell

This gem makes it easy to run shell commands from within ruby. It will raise an exception if the command fails with an unexpected exit status. By default it automatically redirects STDERR to STDOUT when executing the command. The return value is the output of the command with whitespace automatically stripped.

Example usage:

Subshell.exec 'echo hello world'                          # => "hello world"
Subshell.exec 'echo hello world', strip_whitespace: false # => "hello world\n"
Subshell.exec 'exit 1'                                    # => raises RuntimeError

Options

Option Default Description
redirect_stderr_to_stdout true append 2>&1 to the command
expected_status 0 raise if the exit status of the command does not equal this value
strip_whitespace true strip whitespace from the command's output
logger Rails logger (if available) or nil log debug info, if set
debug false print debug info to STDOUT. does not affect logger output
quiet false disable logger and STDOUT logging. useful to suppress sensitive or verbose data from being logged

These options can be set per call. For convenience, the defaults can be changed with a call to Subshell.set_defaults:

Subshell.set_defaults(strip_whitespace: false)
Subshell.exec 'echo hello world'                 # => 'hello world\n'

Installation

Add this line to your application's Gemfile:

gem 'subshell'

And then execute:

$ bundle

Or install it yourself as:

$ gem install subshell

Development

After checking out the repo, run bin/setup to install dependencies. Then, run rake test to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/falconed/subshell. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

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