[Mono-bugs] [Bug 75470][Blo] New - Unexpected runtime exit when using Process redirection

bugzilla-daemon at bugzilla.ximian.com bugzilla-daemon at bugzilla.ximian.com
Tue Jul 5 06:53:55 EDT 2005


Please do not reply to this email- if you want to comment on the bug, go to the
URL shown below and enter your comments there.

Changed by colin at breame.net.

http://bugzilla.ximian.com/show_bug.cgi?id=75470

--- shadow/75470	2005-07-05 06:53:55.000000000 -0400
+++ shadow/75470.tmp.4312	2005-07-05 06:53:55.000000000 -0400
@@ -0,0 +1,94 @@
+Bug#: 75470
+Product: Mono: Class Libraries
+Version: 1.1
+OS: 
+OS Details: SuSE 9.2
+Status: NEW   
+Resolution: 
+Severity: 
+Priority: Blocker
+Component: CORLIB
+AssignedTo: mono-bugs at ximian.com                            
+ReportedBy: colin at breame.net               
+QAContact: mono-bugs at ximian.com
+TargetMilestone: ---
+URL: 
+Cc: 
+Summary: Unexpected runtime exit when using Process redirection
+
+Below is a program that on my system replicates an unexpected exit by the 
+mono  
+runtime. 
+ 
+The lines of interest are: 
+ 
+        stdout.WriteLine("1"); 
+        p.StandardInput.WriteLine("hello world!"); 
+        stdout.WriteLine("2"); 
+ 
+As the program runs, it prints '1' but exits before '2' is printed. 
+ 
+Any ideas what might be going on here?  Could this be SIGPIPE related? 
+ 
+--- 
+ 
+   
+using System;   
+using System.IO;   
+using System.Diagnostics;   
+   
+public class main_t {   
+   
+        public static void Main() {   
+                while (true) {   
+                        run();   
+                }   
+        }   
+   
+        public static void run() {   
+                Process p = null;   
+   
+                try {   
+                        p = new Process();   
+   
+                        string pipe = "echo hello";   
+   
+                        int i = pipe.IndexOf(' ');   
+                        if (i == -1) {   
+                                p.StartInfo.FileName = pipe;   
+                        } else {   
+                                p.StartInfo.FileName = pipe.Substring(0,   
+i);   
+                                p.StartInfo.Arguments =  
+pipe.Substring(i+1,  pipe.Length-i-1);   
+                        }   
+   
+                        p.StartInfo.UseShellExecute = false;   
+                        p.StartInfo.RedirectStandardInput = true;   
+                        try {   
+                                p.Start();   
+                        } catch (Exception e) {   
+                                Console.Error.WriteLine("could not  
+execute:  {0}", pipe);   
+                                goto init_error;   
+                        }   
+   
+                        TextWriter stdout = Console.Out;   
+                        Console.SetOut(p.StandardInput);   
+                        stdout.WriteLine("1");   
+                        p.StandardInput.WriteLine("hello world!");   
+                        stdout.WriteLine("2");   
+                        Console.SetOut(stdout);   
+   
+                        p.StandardInput.Close();   
+   
+                        if (p != null) {   
+                                p.WaitForExit();   
+                        }   
+   
+                } finally {   
+                        if (p != null) p.Close();   
+                }   
+        init_error:;   
+        }   
+}


More information about the mono-bugs mailing list