summaryrefslogtreecommitdiff
path: root/devel/anjuta/files/patch-libanjuta_anjuta-launcher.c
diff options
context:
space:
mode:
Diffstat (limited to 'devel/anjuta/files/patch-libanjuta_anjuta-launcher.c')
-rw-r--r--devel/anjuta/files/patch-libanjuta_anjuta-launcher.c80
1 files changed, 80 insertions, 0 deletions
diff --git a/devel/anjuta/files/patch-libanjuta_anjuta-launcher.c b/devel/anjuta/files/patch-libanjuta_anjuta-launcher.c
new file mode 100644
index 000000000000..73987d782cd5
--- /dev/null
+++ b/devel/anjuta/files/patch-libanjuta_anjuta-launcher.c
@@ -0,0 +1,80 @@
+--- libanjuta/anjuta-launcher.c.orig Mon Jun 11 13:22:08 2007
++++ libanjuta/anjuta-launcher.c Sun Jul 8 03:39:07 2007
+@@ -37,7 +37,7 @@
+ #include <signal.h>
+
+ #if !defined(__sun) && !defined(__NetBSD__)
+-# ifndef FREEBSD
++# if !defined(__FreeBSD__)
+ # include <pty.h>
+ # else
+ # include <libutil.h>
+@@ -713,7 +713,8 @@ anjuta_launcher_scan_output (GIOChannel
+ GError *err = NULL;
+ do
+ {
+- g_io_channel_read_chars (channel, buffer, FILE_BUFFER_SIZE-1, &n, &err);
++ GIOStatus status;
++ status = g_io_channel_read_chars (channel, buffer, FILE_BUFFER_SIZE-1, &n, &err);
+ if (n > 0 && !err) /* There is output */
+ {
+ gchar *utf8_chars;
+@@ -733,6 +734,13 @@ anjuta_launcher_scan_output (GIOChannel
+ anjuta_launcher_synchronize (launcher);
+ ret = FALSE;
+ }
++ else if (status == G_IO_STATUS_EOF)
++ {
++ launcher->priv->stdout_is_done = TRUE;
++ anjuta_launcher_synchronize (launcher);
++ ret = FALSE;
++ }
++
+ /* Read next chars if buffer was too small
+ * (the maximum length of one character is 6 bytes) */
+ } while (!err && (n > FILE_BUFFER_SIZE - 7));
+@@ -762,7 +770,8 @@ anjuta_launcher_scan_error (GIOChannel *
+ GError *err = NULL;
+ do
+ {
+- g_io_channel_read_chars (channel, buffer, FILE_BUFFER_SIZE-1, &n, &err);
++ GIOStatus status;
++ status = g_io_channel_read_chars (channel, buffer, FILE_BUFFER_SIZE-1, &n, &err);
+ if (n > 0 && !err) /* There is stderr output */
+ {
+ gchar *utf8_chars;
+@@ -782,6 +791,13 @@ anjuta_launcher_scan_error (GIOChannel *
+ anjuta_launcher_synchronize (launcher);
+ ret = FALSE;
+ }
++ else if (status == G_IO_STATUS_EOF)
++ {
++ launcher->priv->stderr_is_done = TRUE;
++ anjuta_launcher_synchronize (launcher);
++ ret = FALSE;
++ }
++
+ /* Read next chars if buffer was too small
+ * (the maximum length of one character is 6 bytes) */
+ } while (!err && (n > FILE_BUFFER_SIZE - 7));
+@@ -811,7 +827,8 @@ anjuta_launcher_scan_pty (GIOChannel *ch
+ GError *err = NULL;
+ do
+ {
+- g_io_channel_read_chars (channel, buffer, FILE_BUFFER_SIZE-1, &n, &err);
++ GIOStatus status;
++ status = g_io_channel_read_chars (channel, buffer, FILE_BUFFER_SIZE-1, &n, &err);
+ if (n > 0 && !err) /* There is stderr output */
+ {
+ gchar *utf8_chars;
+@@ -833,6 +850,10 @@ anjuta_launcher_scan_pty (GIOChannel *ch
+ else if (err && errno != EAGAIN && errno != EINTR)
+ {
+ g_warning (_("launcher.c: Error while reading child pty\n"));
++ ret = FALSE;
++ }
++ else if (status == G_IO_STATUS_EOF)
++ {
+ ret = FALSE;
+ }
+ /* Read next chars if buffer was too small