From 06d1cbb92691638db23984b32a8011c6dd602fdb Mon Sep 17 00:00:00 2001 From: keiju Date: Sun, 21 Mar 2004 12:21:11 +0000 Subject: * 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 --- lib/shell/command-processor.rb | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) (limited to 'lib/shell/command-processor.rb') diff --git a/lib/shell/command-processor.rb b/lib/shell/command-processor.rb index ce5102a9c4..6f8e5ffd09 100644 --- a/lib/shell/command-processor.rb +++ b/lib/shell/command-processor.rb @@ -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 # -- cgit v1.2.3