Blame SOURCES/sharutils-4.13.3-Do-not-open-and-dev-stdout.patch

c9392b
From 49857a3ee79226ce870607104f7ef28bacae3f57 Mon Sep 17 00:00:00 2001
c9392b
From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= <ppisar@redhat.com>
c9392b
Date: Wed, 23 Jan 2013 14:06:50 +0100
c9392b
Subject: [PATCH] Do not open - and /dev/stdout
c9392b
c9392b
Ported from 4.13.4pre2.
c9392b
<https://bugzilla.redhat.com/show_bug.cgi?id=901895>
c9392b
c9392b
I have duplicated the autogen code to C because the build system does
c9392b
not run autogen.
c9392b
---
c9392b
 src/uudecode-opts.c   | 17 ++++++++++++++++-
c9392b
 src/uudecode-opts.def | 17 ++++++++++++++++-
c9392b
 2 files changed, 32 insertions(+), 2 deletions(-)
c9392b
c9392b
diff --git a/src/uudecode-opts.c b/src/uudecode-opts.c
c9392b
index 19f4ee1..33ebe2f 100644
c9392b
--- a/src/uudecode-opts.c
c9392b
+++ b/src/uudecode-opts.c
c9392b
@@ -385,7 +385,22 @@ doOptOutput_File(tOptions* pOptions, tOptDesc* pOptDesc)
c9392b
      * reset its state.
c9392b
      */
c9392b
     /* extracted from uudecode-opts.def, line 60 */
c9392b
-  FILE * fp = freopen (pOptDesc->optArg.argString, "w", stdout);
c9392b
+  FILE * fp;
c9392b
+  switch (*pOptDesc->optArg.argString)
c9392b
+    {
c9392b
+    case '-':
c9392b
+      if (pOptDesc->optArg.argString[1] == '\0')
c9392b
+        return;
c9392b
+      break;
c9392b
+
c9392b
+    case '/':
c9392b
+      if (strcmp (pOptDesc->optArg.argString + 1, "dev/stdout") == 0)
c9392b
+        return;
c9392b
+
c9392b
+    default:
c9392b
+      break;
c9392b
+    }
c9392b
+  fp = freopen (pOptDesc->optArg.argString, "w", stdout);
c9392b
   if (fp != stdout)
c9392b
     {
c9392b
       error (0, errno, "%s", pOptDesc->optArg.argString);
c9392b
diff --git a/src/uudecode-opts.def b/src/uudecode-opts.def
c9392b
index ae11b0a..419387b 100644
c9392b
--- a/src/uudecode-opts.def
c9392b
+++ b/src/uudecode-opts.def
c9392b
@@ -57,7 +57,22 @@ flag = {
c9392b
     arg-name    = file;
c9392b
     descrip     = 'direct output to @file{file}';
c9392b
     flag-code   = <<- _EOCode_
c9392b
-	  FILE * fp = freopen (pOptDesc->optArg.argString, "w", stdout);
c9392b
+      FILE * fp;
c9392b
+      switch (*pOptDesc->optArg.argString)
c9392b
+        {
c9392b
+        case '-':
c9392b
+          if (pOptDesc->optArg.argString[1] == '\0')
c9392b
+            return;
c9392b
+          break;
c9392b
+
c9392b
+        case '/':
c9392b
+          if (strcmp (pOptDesc->optArg.argString + 1, "dev/stdout") == 0)
c9392b
+            return;
c9392b
+
c9392b
+        default:
c9392b
+          break;
c9392b
+        }
c9392b
+	  fp = freopen (pOptDesc->optArg.argString, "w", stdout);
c9392b
 	  if (fp != stdout)
c9392b
 	    {
c9392b
 	      error (0, errno, "%s", pOptDesc->optArg.argString);
c9392b
-- 
c9392b
1.8.1
c9392b