Shell implements an idiomatic Ruby interface for common UNIX shell commands.
It provides users the ability to execute commands with filters and pipes,
like sh
/csh
by using native facilities of Ruby.
Examples
Temp file creation
In this example we will create three tmpFile
's in three
different folders under the /tmp
directory.
sh = Shell.cd("/tmp") # Change to the /tmp directory
sh.mkdir "shell-test-1" unless sh.exists?("shell-test-1")
# make the 'shell-test-1' directory if it doesn't already exist
sh.cd("shell-test-1") # Change to the /tmp/shell-test-1 directory
for dir in ["dir1", "dir3", "dir5"]
if !sh.exists?(dir)
sh.mkdir dir # make dir if it doesnt' already exist
sh.cd(dir) do
# change to the `dir` directory
f = sh.open("tmpFile", "w") # open a new file in write mode
f.print "TEST\n" # write to the file
f.close # close the file handler
end
print sh.pwd # output the process working directory
end
end
Temp file creationg with self
This example is identical to the first, except we're using Shell::CommandProcessor#transact.
Shell::CommandProcessor#transact
executes the given block against self, in this case sh
; our Shell object. Within the block we can substitute
sh.cd
to cd
, because the scope within the block
uses sh
already.
sh = Shell.cd("/tmp")
sh.transact do
mkdir "shell-test-1" unless exists?("shell-test-1")
cd("shell-test-1")
for dir in ["dir1", "dir3", "dir5"]
if !exists?(dir)
mkdir dir
cd(dir) do
f = open("tmpFile", "w")
f.print "TEST\n"
f.close
end
print pwd
end
end
end
Pipe /etc/printcap into a file
In this example we will read the operating system file
/etc/printcap
, generated by cupsd
, and then
output it to a new file relative to the pwd
of
sh
.
sh = Shell.new
sh.cat("/etc/printcap") | sh.tee("tee1") > "tee2"
(sh.cat < "/etc/printcap") | sh.tee("tee11") > "tee12"
sh.cat("/etc/printcap") | sh.tee("tee1") >> "tee2"
(sh.cat < "/etc/printcap") | sh.tee("tee11") >> "tee12"
- MODULE Shell::Error
- CLASS Shell::AppendFile
- CLASS Shell::AppendIO
- CLASS Shell::BuiltInCommand
- CLASS Shell::Cat
- CLASS Shell::CommandProcessor
- CLASS Shell::Concat
- CLASS Shell::Echo
- CLASS Shell::Filter
- CLASS Shell::Glob
- CLASS Shell::ProcessController
- CLASS Shell::SystemCommand
- CLASS Shell::Tee
- CLASS Shell::Void
- A
- C
- D
- E
- I
- J
- K
- N
- P
- S
- U
[RW] | cascade | |
[RW] | debug | |
[RW] | debug? | |
[RW] | verbose | |
[RW] | verbose? | |
[R] | command_processor | |
[R] | cwd | Returns the current working directory. |
[RW] | debug | |
[RW] | debug? | |
[R] | dir | Returns the current working directory. |
[R] | dir_stack | |
[R] | dirs | |
[R] | getwd | Returns the current working directory. |
[R] | process_controller | |
[R] | pwd | Returns the current working directory. |
[RW] | record_separator | |
[R] | system_path | Returns the command search path in an array |
[RW] | umask | Returns the umask |
[RW] | verbose | |
[RW] | verbose? |
Convenience method for Shell::CommandProcessor.alias_command
Convenience method for Shell::CommandProcessor.def_system_command
Convenience method for Shell::CommandProcessor.install_system_commands
Creates a Shell object which current directory is
set to the process current directory, unless otherwise specified by the
pwd
argument.
# File lib/shell.rb, line 185 def initialize(pwd = Dir.pwd, umask = nil) @cwd = File.expand_path(pwd) @dir_stack = [] @umask = umask @system_path = Shell.default_system_path @record_separator = Shell.default_record_separator @command_processor = CommandProcessor.new(self) @process_controller = ProcessController.new(self) @verbose = Shell.verbose @debug = Shell.debug end
# File lib/shell.rb, line 392 def self.notify(*opts) Shell::debug_output_synchronize do if opts[-1].kind_of?(String) yorn = verbose? else yorn = opts.pop end return unless yorn if @debug_display_thread_id if @debug_display_process_id prefix = "shell(##{Process.pid}:#{Thread.current.to_s.sub("Thread", "Th")}): " else prefix = "shell(#{Thread.current.to_s.sub("Thread", "Th")}): " end else prefix = "shell: " end _head = true STDERR.print opts.collect{|mes| mes = mes.dup yield mes if iterator? if _head _head = false # "shell" " + mes prefix + mes else " "* prefix.size + mes end }.join("\n")+"\n" end end
Convenience method for Shell::CommandProcessor.unalias_command
Convenience method for Shell::CommandProcessor.undef_system_command
Creates a Shell object which current directory is
set to path
.
If a block is given, it restores the current directory when the block ends.
If called as iterator, it restores the current directory when the block ends.
# File lib/shell.rb, line 262 def chdir(path = nil, verbose = @verbose) check_point if iterator? notify("chdir(with block) #{path}") if verbose cwd_old = @cwd begin chdir(path, nil) yield ensure chdir(cwd_old, nil) end else notify("chdir #{path}") if verbose path = "~" unless path @cwd = expand_path(path) notify "current dir: #{@cwd}" rehash Void.new(self) end end
Returns the directories in the current shell's PATH environment variable as an array of directory names. This sets the #system_path for all instances of Shell.
Example: If in your current shell, you did:
$ echo $PATH
/usr/bin:/bin:/usr/local/bin
Running this method in the above shell would then return:
["/usr/bin", "/bin", "/usr/local/bin"]
Sets the #system_path that new instances of Shell should have as their initial system_path.
path
should be an array of directory name strings.
Returns a list of scheduled jobs.
Sends the given signal
to the given job
Pops a directory from the directory stack, and sets the current directory to it.
Pushes the current directory to the directory stack, changing the current
directory to path
.
If path
is omitted, it exchanges its current directory and the
top of its directory stack.
If a block is given, it restores the current directory when the block ends.
# File lib/shell.rb, line 296 def pushdir(path = nil, verbose = @verbose) check_point if iterator? notify("pushdir(with block) #{path}") if verbose pushdir(path, nil) begin yield ensure popdir end elsif path notify("pushdir #{path}") if verbose @dir_stack.push @cwd chdir(path, nil) notify "dir stack: [#{@dir_stack.join ', '}]" self else notify("pushdir") if verbose if pop = @dir_stack.pop @dir_stack.push @cwd chdir pop notify "dir stack: [#{@dir_stack.join ', '}]" self else Shell.Fail DirStackEmpty end end Void.new(self) end