mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/shell/*: bug fix for Shell#system(command_line_string).
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5994 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
b9c8bcafdc
commit
06d1cbb926
4 changed files with 20 additions and 9 deletions
|
@ -1,3 +1,7 @@
|
|||
Sun Mar 21 21:11:16 2004 Keiju Ishitsuka <keiju@ishitsuka.com>
|
||||
|
||||
* lib/shell/*: bug fix for Shell#system(command_line_string).
|
||||
|
||||
Sun Mar 21 21:04:42 2004 WATANABE Hirofumi <eban@ruby-lang.org>
|
||||
|
||||
* ruby.1: add -width option to .Bl for old groff.
|
||||
|
|
|
@ -21,6 +21,7 @@ require "shell/builtin-command"
|
|||
|
||||
class Shell
|
||||
class CommandProcessor
|
||||
# include Error
|
||||
|
||||
#
|
||||
# initialize of Shell and related classes.
|
||||
|
@ -220,6 +221,13 @@ class Shell
|
|||
# sh.system("ls", "-l") | sh.head > STDOUT
|
||||
#
|
||||
def system(command, *opts)
|
||||
if opts.empty?
|
||||
if command =~ /\*|\?|\{|\}|\[|\]|<|>|\(|\)|~|&|\||\\|\$|;|'|`|"|\n/
|
||||
return SystemCommand.new(@shell, find_system_command("sh"), "-c", command)
|
||||
else
|
||||
command, *opts = command.split(/\s+/)
|
||||
end
|
||||
end
|
||||
SystemCommand.new(@shell, find_system_command(command), *opts)
|
||||
end
|
||||
|
||||
|
@ -277,7 +285,7 @@ class Shell
|
|||
when IO
|
||||
AppendIO.new(@shell, to, filter)
|
||||
else
|
||||
Shell.Fail CantApplyMethod, "append", to.class
|
||||
Shell.Fail Error::CantApplyMethod, "append", to.class
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -327,10 +335,10 @@ class Shell
|
|||
if exists?(path)
|
||||
return path
|
||||
else
|
||||
Shell.Fail CommandNotFound, command
|
||||
Shell.Fail Error::CommandNotFound, command
|
||||
end
|
||||
when false
|
||||
Shell.Fail CommandNotFound, command
|
||||
Shell.Fail Error::CommandNotFound, command
|
||||
end
|
||||
|
||||
for p in @shell.system_path
|
||||
|
@ -341,7 +349,7 @@ class Shell
|
|||
end
|
||||
end
|
||||
@system_commands[command] = false
|
||||
Shell.Fail CommandNotFound, command
|
||||
Shell.Fail Error::CommandNotFound, command
|
||||
end
|
||||
|
||||
#
|
||||
|
|
|
@ -18,7 +18,6 @@ class Shell
|
|||
#
|
||||
class Filter
|
||||
include Enumerable
|
||||
include Error
|
||||
|
||||
def initialize(sh)
|
||||
@shell = sh # parent shell
|
||||
|
@ -47,7 +46,7 @@ class Shell
|
|||
self.input = src
|
||||
self
|
||||
else
|
||||
Filter.Fail CantApplyMethod, "<", to.class
|
||||
Shell.Fail Error::CantApplyMethod, "<", to.class
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -63,7 +62,7 @@ class Shell
|
|||
when IO
|
||||
each(){|l| to << l}
|
||||
else
|
||||
Filter.Fail CantApplyMethod, ">", to.class
|
||||
Shell.Fail Error::CantApplyMethod, ">", to.class
|
||||
end
|
||||
self
|
||||
end
|
||||
|
@ -72,7 +71,7 @@ class Shell
|
|||
begin
|
||||
Shell.cd(@shell.pwd).append(to, self)
|
||||
rescue CantApplyMethod
|
||||
Shell.Fail CantApplyMethod, ">>", to.class
|
||||
Shell.Fail Error::CantApplyMethod, ">>", to.class
|
||||
end
|
||||
end
|
||||
|
||||
|
|
|
@ -16,7 +16,7 @@ class Shell
|
|||
class SystemCommand < Filter
|
||||
def initialize(sh, command, *opts)
|
||||
if t = opts.find{|opt| !opt.kind_of?(String) && opt.class}
|
||||
Shell.Fail TypeError, t.class, "String"
|
||||
Shell.Fail Error::TypeError, t.class, "String"
|
||||
end
|
||||
super(sh)
|
||||
@command = command
|
||||
|
|
Loading…
Reference in a new issue