hambrook/clitaskrunner

Run a CLI command in the background and get updates via callbacks on events including buffer and line updates. You can subscribe to any writable stream and get callbacks triggered for new lines or on each buffer update.

dev-master 2015-10-19 22:58 UTC

This package is not auto-updated.

Last update: 2024-05-15 16:06:48 UTC


README

#CLITaskRunner

Build Status

Run a CLI command in the background and get updates via callbacks on events including buffer and line updates. You can subscribe to any writable stream and get callbacks triggered for new lines or on each buffer update.

##Example

$cmd = "mysqldump -uroot -proot -v dbname | mysql -uroot -proot dbname2";
$CLITR = new \Hambrook\CLITaskRunner\CLITaskRunner($cmd);
$CLITR->onLine(
	"stdErr",
	function($v) {
		echo "\nCopying table structure: ".$v
	},
	"/\-\- Retrieving table.*? ([^ ]+)\.\.\./"
);
$CLITR->onLine(
	"stdErr",
	function() {
		echo "\nCopying table rows..."
	},
	"/\-\- Retrieving rows/"
);
$CLITR->process();

##Who is it for? Probably mostly CLI application developers, but there will be usecases I haven't thought of.

####Why use this? I built this because I use mysqldump and rsync from within a CLI application and wanted to customise the output from those commands. It couldn't be done with a simple popen because mysqldump puts its verbose output into the stdErr stream instead of stdOut. Then, naturally, I made it as versatile as possible.

####When you could use this? When you need to run a CLI command and be notified when specific output occurs on a particular stream.

####What is this not? This library sits between your software and CLI commands that it runs. It does not sit between your software and the user. It doesn't do any user input management, argument management, output formatting, or anything of the sort. It helps your software get updates from long-ish running CLI commands.

##Functions ###__construct() CLITaskRunner __construct(string $command)

Create a new instance with a command ready to run

###onLine() bool onLine(string $stream, callable $callback, [bool|string $pattern=false])

Add a callback for when a new line is received, with optional regex pattern.

###onBuffer() bool onBuffer(string $stream, callable $callback, [bool|string $pattern=false])

Add a callback for when the buffer is received, with optional regex pattern.

###onSuccess() bool onSuccess(callable $callback)

Add a callback for when the command succeeds.

###onFailure() bool onFailure(callable $callback)

Add a callback for when the command fails.

###onComplete() bool onComplete(callable $callback)

Add a callback for when the process is complete. Gets called after onSuccess and onFailure.

###bufferSize() bool|int bufferSize([int $bufferSize=10])

Gets or sets the buffer size. Buffer size is currently common across all streams.

###streams() bool streams([array $streams=[]])

Get or set the array of streams. Each stream will use its array key as the stream key when adding callbacks.

##Testing Tests coming soon.

##Feedback Tell me if you loved it. Tell me if you hated it. Tell me if you used it and thought "meh". I'm keen to hear your feedback.

##Contributing Feel free to fork this project and submit pull requests, or even just request features via the issue tracker. Please be descriptive with pull requests and match the existing code style.

##Roadmap

  • Add support for pushing to the stdIn stream
  • Add type hinting for all functions
  • Add documentation
  • Add more examples
  • Add more unit tests
  • Add any other standard documentation that should be included
  • If you have an idea, let me know.

##License Copyright © 2015 Rick Hambrook

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.