run v0.7.0

A Crystal library for running commands in reusable contexts.

Crystal Run

A Crystal library for running commands in reusable contexts.

Build Status

Installation

Add this to your application's shard.yml:

dependencies:
  run:
    github: mosop/run

Code Samples

Smiley

cmd = Run::Command.new("echo", [":)"])
cmd.run.wait # prints ":)"

Additional Arguments

cmd = Run.command("echo", [":)"])
%w(hello goodbye).each do |i|
  cmd.run(args: [i]).wait
end

This prints:

:) hello
:) goodbye

Over and Over

cmd = Run.command("echo", [":)"])
100.times do
  cmd.run.wait
end

This prints 100 of :).

Multiple at Once

cg = Run.group
100.times do
  cg.command "echo", [":)"]
end
cg.run.wait

This prints 100 of :) too.

Nested Contexts

cg = Run.group(chdir: "path")
cg.command "pwd"
cg.command "pwd", chdir: "to"
cg.command "pwd", chdir: ".."
cg.run.wait

If the current directory is /Users/mosop, this code prints:

/Users/mosop/path
/Users/mosop/path/to
/Users/mosop

Parallel

cg = Run.group
cg.command "wget", %w(http://mosop.rocks)
cg.command "wget", %w(http://mosop.yoga)
cg.command "wget", %w(http://mosop.ninja)
process_group = cg.run(parallel: true)

# do other things

process_group.wait

Running Code Blocks

  • In a fiber
cg = Run.group
100.times do
  cg.future do
    puts ":)"
    0
  end
end
cg.run.wait
  • In a forked process
cg = Run.group
100.times do
  cg.fork do
    puts ":)"
    0
  end
end
cg.run.wait

Returning Data by Forked Processes

cg = Run.group
100.times do
  cg.fork do
    Run::ExitStatus.new(0, ":)").exit!
    0
  end
end

cg.run.wait do |process|
  if process = process.as?(Run::AsProcess)
    puts process.exit_status.data
  end
end

This prints 100 of :).

Usage

require "run"

And see:

Versioning Policy

See Wiki.

Release Notes

See Releases.

Repository

run

Owner
Statistic
  • 10
  • 1
  • 2
  • 0
  • 3
  • almost 8 years ago
  • November 24, 2016
License

MIT License

Links
Synced at

Tue, 21 Jan 2025 11:48:36 GMT

Languages