From b623e245c05ce047ee512b53da5d6e493c09ac3d Mon Sep 17 00:00:00 2001
From: Wren Turkal <wt@penguintechs.org>
Date: Wed, 8 Jul 2020 05:43:01 -0700
Subject: [PATCH] Make freopen reset the stream orientation.

Signed-off-by: Wren Turkal <wt@penguintechs.org>
---
 src/header/stdio/mod.rs             |  1 +
 tests/expected/stdio/freopen.stdout |  2 ++
 tests/stdio/freopen.c               | 28 +++++++++++++++++++++++++++-
 3 files changed, 30 insertions(+), 1 deletion(-)

diff --git a/src/header/stdio/mod.rs b/src/header/stdio/mod.rs
index b6c9c916..73f1bba3 100644
--- a/src/header/stdio/mod.rs
+++ b/src/header/stdio/mod.rs
@@ -519,6 +519,7 @@ pub unsafe extern "C" fn freopen(
         stream.flags = (stream.flags & constants::F_PERM) | new.flags;
         fclose(new);
     }
+    stream.orientation = 0;
     funlockfile(stream);
     stream
 }
diff --git a/tests/expected/stdio/freopen.stdout b/tests/expected/stdio/freopen.stdout
index e965047a..1dd338fd 100644
--- a/tests/expected/stdio/freopen.stdout
+++ b/tests/expected/stdio/freopen.stdout
@@ -1 +1,3 @@
 Hello
+0
+0
diff --git a/tests/stdio/freopen.c b/tests/stdio/freopen.c
index 6c658435..3fb6069c 100644
--- a/tests/stdio/freopen.c
+++ b/tests/stdio/freopen.c
@@ -1,12 +1,38 @@
+#include <assert.h>
 #include <stdio.h>
+#include <wchar.h>
 
 #include "test_helpers.h"
 
-int main(void) {
+int test_reopen_opens_file(void) {
     FILE *f = freopen("stdio/stdio.in", "r", stdin);
     ERROR_IF(freopen, f, == NULL);
 
     char in[6];
     fgets(in, 6, stdin);
     printf("%s\n", in); // should print Hello
+    fclose(f);
+    return 0;
+}
+
+int test_reopen_resets_orientation(void) {
+    FILE *f = freopen("stdio/stdio.in", "r", stdin);
+    assert(fwide(f, 0) == 0);
+    assert(fwide(f, -1) == -1);
+
+    f = freopen("stdio/stdio.in", "r", stdin);
+    assert(fwide(f, 0) == 0);
+
+    fclose(f);
+    return 0;
+}
+
+int main(void) {
+    int(*tests[])(void) = {
+        &test_reopen_opens_file,
+        &test_reopen_resets_orientation,
+    };
+    for(int i=0; i<sizeof(tests)/sizeof(int(*)(void)); i++) {
+        printf("%d\n", (*tests[i])());
+    }
 }
-- 
GitLab