Skip to content

Swift helper for launching subprocesses and capturing their output.

Notifications You must be signed in to change notification settings

elegantchaos/Runner

Repository files navigation

Runner

Support for executing subprocesses, using Foundation.Process, and capturing their output asynchronously. Swift 6 ready.

Currently doesn't support a STDIN stream -- only STDOUT and STDERR -- but it should be easy enough to add when I (or someone else?) hit a use case.

Usage examples:

Run And Capture Stdout

let url = /* url to the executable */
let runner = Runner(for: url)

// execute with some arguments
let session = runner.run(["some", "arguments"])

// process the output asynchronously
for await l in session.stdout.lines {
  print(l)
}

Run In A Different Working Directory

// run in a different working directory
runner.cwd = /* url to the directory */
let _ = runner.run(["blah"])

Transfer Execution

// transfer execution to the subprocess
runner.exec(url)

Lookup Executable In Path

let runner = Runner(command: "git") /// we'll find git in $PATH if it's there
let session = runner.run("status")
print(await session.stdout.string)

Run And Wait For Termination

let url = /* url to the executable */
let runner = Runner(for: url)

// execute with some arguments
let session = runner.run(["some", "arguments"])

// wait for termination and read state
if await session.waitUntilExit() == .succeeded {
  print("all good")
}

Run Passing Stdout/Stderr Through

let url = /* url to the executable */
let runner = Runner(for: url)
let session = runner.run(stdoutMode: .forward, stderrMode: .forward)
let _ = session.waitUntilExit()

About

Swift helper for launching subprocesses and capturing their output.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published