mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	* lib/shell: commit miss(support for ruby 1.9(YARV) thread model).
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12124 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
		
							parent
							
								
									0ce0d4a596
								
							
						
					
					
						commit
						69b8b645b5
					
				
					 4 changed files with 48 additions and 52 deletions
				
			
		| 
						 | 
				
			
			@ -1,3 +1,7 @@
 | 
			
		|||
Fri Mar 23 00:24:52 2007  Keiju Ishitsuka <keiju@ruby-lang.org>
 | 
			
		||||
	
 | 
			
		||||
	* lib/shell: commit miss(support for ruby 1.9(YARV) thread model).
 | 
			
		||||
 | 
			
		||||
Thu Mar 22 13:32:17 2007  NAKAMURA Usaku  <usa@ruby-lang.org>
 | 
			
		||||
 | 
			
		||||
	* win32/Makefile.sub (LIBS): remove an unnecessary library.
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -475,7 +475,7 @@ class Shell
 | 
			
		|||
		 end]
 | 
			
		||||
	Shell.notify "Define #{meth}(#{arg_str})", Shell.debug?
 | 
			
		||||
	Shell.notify("Definition of #{meth}: ", d, 
 | 
			
		||||
	     Shell.debug.kind_of?(Integer) && Shell.debug > 1)
 | 
			
		||||
		     Shell.debug.kind_of?(Integer) && Shell.debug > 1)
 | 
			
		||||
	eval d
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
| 
						 | 
				
			
			@ -589,24 +589,24 @@ class Shell
 | 
			
		|||
      def_builtin_commands(FileTest, 
 | 
			
		||||
		   FileTest.singleton_methods(false).collect{|m| [m, ["FILENAME"]]})
 | 
			
		||||
 | 
			
		||||
      # method related ftools
 | 
			
		||||
      normal_delegation_ftools_methods = [
 | 
			
		||||
	["syscopy", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
	["copy", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
	["move", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
	["compare", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
	["safe_unlink", ["*FILENAMES"]],
 | 
			
		||||
	["makedirs", ["*FILENAMES"]],
 | 
			
		||||
	#    ["chmod", ["mode", "*FILENAMES"]],
 | 
			
		||||
	["install", ["FILENAME_FROM", "FILENAME_TO", "mode"]],
 | 
			
		||||
      ]
 | 
			
		||||
      def_builtin_commands(File,
 | 
			
		||||
		   normal_delegation_ftools_methods)
 | 
			
		||||
      alias_method :cmp, :compare
 | 
			
		||||
      alias_method :mv, :move
 | 
			
		||||
      alias_method :cp, :copy
 | 
			
		||||
      alias_method :rm_f, :safe_unlink
 | 
			
		||||
      alias_method :mkpath, :makedirs
 | 
			
		||||
#       # method related ftools
 | 
			
		||||
#       normal_delegation_ftools_methods = [
 | 
			
		||||
# 	["syscopy", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
# 	["copy", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
# 	["move", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
# 	["compare", ["FILENAME_FROM", "FILENAME_TO"]],
 | 
			
		||||
# 	["safe_unlink", ["*FILENAMES"]],
 | 
			
		||||
# 	["makedirs", ["*FILENAMES"]],
 | 
			
		||||
# 	#    ["chmod", ["mode", "*FILENAMES"]],
 | 
			
		||||
# 	["install", ["FILENAME_FROM", "FILENAME_TO", "mode"]],
 | 
			
		||||
#       ]
 | 
			
		||||
#       def_builtin_commands(File,
 | 
			
		||||
# 		   normal_delegation_ftools_methods)
 | 
			
		||||
#       alias_method :cmp, :compare
 | 
			
		||||
#       alias_method :mv, :move
 | 
			
		||||
#       alias_method :cp, :copy
 | 
			
		||||
#       alias_method :rm_f, :safe_unlink
 | 
			
		||||
#       alias_method :mkpath, :makedirs
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,9 +1,9 @@
 | 
			
		|||
#
 | 
			
		||||
#   shell/filter.rb - 
 | 
			
		||||
#   	$Release Version: 0.6.0 $
 | 
			
		||||
#   	$Release Version: 0.7 $
 | 
			
		||||
#   	$Revision$
 | 
			
		||||
#   	$Date$
 | 
			
		||||
#   	by Keiju ISHITSUKA(Nihon Rational Software Co.,Ltd)
 | 
			
		||||
#   	by Keiju ISHITSUKA(keiju@ruby-lang.org)
 | 
			
		||||
#
 | 
			
		||||
# --
 | 
			
		||||
#
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -47,12 +47,15 @@ class Shell
 | 
			
		|||
    end
 | 
			
		||||
 | 
			
		||||
    def start
 | 
			
		||||
      notify([@command, *@opts].join(" "))
 | 
			
		||||
 | 
			
		||||
      @pid, @pipe_in, @pipe_out = @shell.process_controller.sfork(self) {
 | 
			
		||||
	Dir.chdir @shell.pwd
 | 
			
		||||
	$0 = @command
 | 
			
		||||
	exec(@command, *@opts)
 | 
			
		||||
      }
 | 
			
		||||
      if @input
 | 
			
		||||
	start_export
 | 
			
		||||
 	start_export
 | 
			
		||||
      end
 | 
			
		||||
      start_import
 | 
			
		||||
    end
 | 
			
		||||
| 
						 | 
				
			
			@ -78,17 +81,12 @@ class Shell
 | 
			
		|||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    def start_import
 | 
			
		||||
#      Thread.critical = true
 | 
			
		||||
      notify "Job(%id) start imp-pipe.", @shell.debug?
 | 
			
		||||
      rs = @shell.record_separator unless rs
 | 
			
		||||
      _eop = true
 | 
			
		||||
#      Thread.critical = false
 | 
			
		||||
      th = Thread.start {
 | 
			
		||||
	Thread.critical = true
 | 
			
		||||
	begin
 | 
			
		||||
	  Thread.critical = false
 | 
			
		||||
	  while l = @pipe_in.gets
 | 
			
		||||
	    @input_queue.push l
 | 
			
		||||
	  end
 | 
			
		||||
| 
						 | 
				
			
			@ -96,19 +94,15 @@ class Shell
 | 
			
		|||
	rescue Errno::EPIPE
 | 
			
		||||
	  _eop = false
 | 
			
		||||
	ensure
 | 
			
		||||
	  if _eop
 | 
			
		||||
	  if !ProcessController::USING_AT_EXIT_WHEN_PROCESS_EXIT and _eop
 | 
			
		||||
	    notify("warn: Process finishing...",
 | 
			
		||||
		   "wait for Job[%id] to finish pipe importing.",
 | 
			
		||||
		   "You can use Shell#transact or Shell#check_point for more safe execution.")
 | 
			
		||||
#	    Tracer.on
 | 
			
		||||
	    Thread.current.run
 | 
			
		||||
	    redo
 | 
			
		||||
	  end
 | 
			
		||||
	  Thread.exclusive do
 | 
			
		||||
	    notify "job(%id}) close imp-pipe.", @shell.debug?
 | 
			
		||||
	    @input_queue.push :EOF
 | 
			
		||||
	    @pipe_in.close
 | 
			
		||||
	  end
 | 
			
		||||
	  notify "job(%id}) close imp-pipe.", @shell.debug?
 | 
			
		||||
	  @input_queue.push :EOF
 | 
			
		||||
	  @pipe_in.close
 | 
			
		||||
	end
 | 
			
		||||
      }
 | 
			
		||||
    end
 | 
			
		||||
| 
						 | 
				
			
			@ -117,25 +111,24 @@ class Shell
 | 
			
		|||
      notify "job(%id) start exp-pipe.", @shell.debug?
 | 
			
		||||
      _eop = true
 | 
			
		||||
      th = Thread.start{
 | 
			
		||||
	Thread.critical = true
 | 
			
		||||
	begin
 | 
			
		||||
	  Thread.critical = false
 | 
			
		||||
	  @input.each{|l| @pipe_out.print l}
 | 
			
		||||
	  @input.each do |l|
 | 
			
		||||
	    ProcessController::block_output_synchronize do
 | 
			
		||||
	      @pipe_out.print l
 | 
			
		||||
	    end
 | 
			
		||||
	  end
 | 
			
		||||
	  _eop = false
 | 
			
		||||
	rescue Errno::EPIPE
 | 
			
		||||
	rescue Errno::EPIPE, Errno::EIO
 | 
			
		||||
	  _eop = false
 | 
			
		||||
	ensure
 | 
			
		||||
	  if _eop
 | 
			
		||||
	  if !ProcessController::USING_AT_EXIT_WHEN_PROCESS_EXIT and _eop
 | 
			
		||||
	    notify("shell: warn: Process finishing...",
 | 
			
		||||
		   "wait for Job(%id) to finish pipe exporting.",
 | 
			
		||||
		   "You can use Shell#transact or Shell#check_point for more safe execution.")
 | 
			
		||||
#	    Tracer.on
 | 
			
		||||
	    redo
 | 
			
		||||
	  end
 | 
			
		||||
	  Thread.exclusive do
 | 
			
		||||
	    notify "job(%id) close exp-pipe.", @shell.debug?
 | 
			
		||||
	    @pipe_out.close
 | 
			
		||||
	  end
 | 
			
		||||
	  notify "job(%id) close exp-pipe.", @shell.debug?
 | 
			
		||||
	  @pipe_out.close
 | 
			
		||||
	end
 | 
			
		||||
      }
 | 
			
		||||
    end
 | 
			
		||||
| 
						 | 
				
			
			@ -154,14 +147,13 @@ class Shell
 | 
			
		|||
    #	    mes: "job(%id) close pipe-out."
 | 
			
		||||
    #    yorn: Boolean(@shell.debug? or @shell.verbose?)
 | 
			
		||||
    def notify(*opts, &block)
 | 
			
		||||
      Thread.exclusive do
 | 
			
		||||
	@shell.notify(*opts) {|mes|
 | 
			
		||||
	  yield mes if iterator?
 | 
			
		||||
      @shell.notify(*opts) do |mes|
 | 
			
		||||
	yield mes if iterator?
 | 
			
		||||
 | 
			
		||||
	  mes.gsub!("%id", "#{@command}:##{@pid}")
 | 
			
		||||
	  mes.gsub!("%name", "#{@command}")
 | 
			
		||||
	  mes.gsub!("%pid", "#{@pid}")
 | 
			
		||||
	}
 | 
			
		||||
	mes.gsub!("%id", "#{@command}:##{@pid}")
 | 
			
		||||
	mes.gsub!("%name", "#{@command}")
 | 
			
		||||
	mes.gsub!("%pid", "#{@pid}")
 | 
			
		||||
	mes
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue