dummy-link

Shell

Run shell commands becomes easy in Julia!

Readme

Shell

Build Status Build status

julia> using Shell

julia> Shell.run("ls")
appveyor.yml  LICENSE.md  README.md  REQUIRE  src  test

Now you can run string commands in Julia!

Supports cmd, powershell and wsl in Windows!

WARN: The implementation basically put the string into a script file and run that file. So it is error prone because you have to deal with all the subtle stuff like escaping spaces, quotes, etc. This tool is good for running simple things like ls, echo, etc. But do not use this in your serious scripts unless you have double checked its correctness.

Usage

julia> using Shell

julia> Shell.run(raw"echo $SHELL", capture=true)
"/bin/zsh"

julia> Shell.run(raw"for i in dust junk; do echo $i; done")
dust
junk

julia> files = ["temp file 1", "temp file 2"]
2-element Array{String,1}:
 "temp file 1"
 "temp file 2"

julia> filelist = esc`$files.txt`
"'temp file 1.txt' 'temp file 2.txt'"

julia> Shell.run("touch $filelist")

julia> Shell.run("touch $(esc`$files.$["txt","md"]`)", dryrun=true)
touch 'temp file 1.txt' 'temp file 1.md' 'temp file 2.txt' 'temp file 2.md'

julia> Shell.run("ls > 'temp file 0.txt'")

julia> Shell.run("cat 'temp file 0.txt' | grep temp")
temp file 0.txt
temp file 1.txt
temp file 2.txt

julia> Shell.run("rm 'temp file'*")

Installation

julia> Pkg.clone("https://github.com/innerlee/Shell.jl")

Notes

  • use esc`your string` to help you escape (not working for cmd in Windows).
  • use dryrun=true to check the command to be run without actually running.
  • Change default shell by calling Shell.setshell("powershell").
  • The output chomps by default. Change this by calling Shell.setchomp(false).
  • In Windows, the code page may be changed to 65001 after running.

More Notes

See the discussions here. (You can use esc`your argmuments` to take advantage of the built-in escaping of Cmd objects, though.) A "better" way is to learn the Cmd object and perhaps the Glob.jl package as pointed out here.

First Commit

09/30/2017

Last Touched

10 months ago

Commits

93 commits

Requires:

Used By: