]> git.xonotic.org Git - xonotic/darkplaces.git/commitdiff
deduplicate Sys_ConsoleInput()
authorbones_was_here <bones_was_here@xonotic.au>
Tue, 2 Jan 2024 09:31:51 +0000 (19:31 +1000)
committerbones_was_here <bones_was_here@xonotic.au>
Wed, 3 Jan 2024 00:14:07 +0000 (10:14 +1000)
Fixes multiline stdin not working in the SDL client, but working in the
dedicated server.

Signed-off-by: bones_was_here <bones_was_here@xonotic.au>
sys_sdl.c
sys_shared.c
sys_unix.c

index df25ae6a05ddfda7a3873fa1ff4f1f3c17564e8f..4ce2d75e0d3d2734ce2ffa5308eac483f1447b13 100644 (file)
--- a/sys_sdl.c
+++ b/sys_sdl.c
@@ -1,6 +1,5 @@
 #ifdef WIN32
 #include <io.h> // Include this BEFORE darkplaces.h because it uses strncpy which trips DP_STATIC_ASSERT
-#include "conio.h"
 #else
 #include <unistd.h>
 #include <fcntl.h>
@@ -107,63 +106,6 @@ void Sys_Print(const char *text)
 #endif
 }
 
-char *Sys_ConsoleInput(void)
-{
-       static char text[MAX_INPUTLINE];
-       int len = 0;
-#ifdef WIN32
-       int c;
-
-       // read a line out
-       while (_kbhit ())
-       {
-               c = _getch ();
-               _putch (c);
-               if (c == '\r')
-               {
-                       text[len] = 0;
-                       _putch ('\n');
-                       len = 0;
-                       return text;
-               }
-               if (c == 8)
-               {
-                       if (len)
-                       {
-                               _putch (' ');
-                               _putch (c);
-                               len--;
-                               text[len] = 0;
-                       }
-                       continue;
-               }
-               text[len] = c;
-               len++;
-               text[len] = 0;
-               if (len == sizeof (text))
-                       len = 0;
-       }
-#else
-       fd_set fdset;
-       struct timeval timeout;
-       FD_ZERO(&fdset);
-       FD_SET(0, &fdset); // stdin
-       timeout.tv_sec = 0;
-       timeout.tv_usec = 0;
-       if (select (1, &fdset, NULL, NULL, &timeout) != -1 && FD_ISSET(0, &fdset))
-       {
-               len = read (0, text, sizeof(text));
-               if (len >= 1)
-               {
-                       // rip off the \n and terminate
-                       text[len-1] = 0;
-                       return text;
-               }
-       }
-#endif
-       return NULL;
-}
-
 char *Sys_GetClipboardData (void)
 {
        char *data = NULL;
index 0bb69c2576d2cffc77006a1743cb9e831d46cac9..7b33f3a32a8acaa419cdc0fee89db15bd7d43678 100644 (file)
@@ -15,6 +15,7 @@
 # include <windows.h>
 # include <mmsystem.h> // timeGetTime
 # include <time.h> // localtime
+# include <conio.h> // _kbhit, _getch, _putch
 #ifdef _MSC_VER
 #pragma comment(lib, "winmm.lib")
 #endif
@@ -554,6 +555,66 @@ void Sys_Printf(const char *fmt, ...)
        Sys_Print(msg);
 }
 
+char *Sys_ConsoleInput(void)
+{
+       static char text[MAX_INPUTLINE];
+       static unsigned int len = 0;
+#ifdef WIN32
+       int c;
+
+       // read a line out
+       while (_kbhit ())
+       {
+               c = _getch ();
+               if (c == '\r')
+               {
+                       text[len] = '\0';
+                       _putch ('\n');
+                       len = 0;
+                       return text;
+               }
+               if (c == '\b')
+               {
+                       if (len)
+                       {
+                               _putch (c);
+                               _putch (' ');
+                               _putch (c);
+                               len--;
+                       }
+                       continue;
+               }
+               if (len < sizeof (text) - 1)
+               {
+                       _putch (c);
+                       text[len] = c;
+                       len++;
+               }
+       }
+#else
+       fd_set fdset;
+       struct timeval timeout;
+       FD_ZERO(&fdset);
+       FD_SET(0, &fdset); // stdin
+       timeout.tv_sec = 0;
+       timeout.tv_usec = 0;
+       if (select (1, &fdset, NULL, NULL, &timeout) != -1 && FD_ISSET(0, &fdset))
+       {
+               len = read (0, text, sizeof(text) - 1);
+               if (len >= 1)
+               {
+                       // rip off the \n and terminate
+                       // div0: WHY? console code can deal with \n just fine
+                       // this caused problems with pasting stuff into a terminal window
+                       // so, not ripping off the \n, but STILL keeping a NUL terminator
+                       text[len] = 0;
+                       return text;
+               }
+       }
+#endif
+       return NULL;
+}
+
 #ifndef WIN32
 static const char *Sys_FindInPATH(const char *name, char namesep, const char *PATH, char pathsep, char *buf, size_t bufsize)
 {
index 49990f1f377a5ebf20af3e15c7a424bbc1c2aa8a..d7b2ad9e7382510a01e94f2558f74adb7928a427 100644 (file)
@@ -3,7 +3,6 @@
 #include <windows.h>
 #include <mmsystem.h>
 #include <io.h>
-#include "conio.h"
 #else
 #include <sys/time.h>
 #include <unistd.h>
@@ -71,66 +70,6 @@ void Sys_Print(const char *text)
        //fprintf(stdout, "%s", text);
 }
 
-char *Sys_ConsoleInput(void)
-{
-       static char text[MAX_INPUTLINE];
-       static unsigned int len = 0;
-#ifdef WIN32
-       int c;
-
-       // read a line out
-       while (_kbhit ())
-       {
-               c = _getch ();
-               if (c == '\r')
-               {
-                       text[len] = '\0';
-                       _putch ('\n');
-                       len = 0;
-                       return text;
-               }
-               if (c == '\b')
-               {
-                       if (len)
-                       {
-                               _putch (c);
-                               _putch (' ');
-                               _putch (c);
-                               len--;
-                       }
-                       continue;
-               }
-               if (len < sizeof (text) - 1)
-               {
-                       _putch (c);
-                       text[len] = c;
-                       len++;
-               }
-       }
-#else
-       fd_set fdset;
-       struct timeval timeout;
-       FD_ZERO(&fdset);
-       FD_SET(0, &fdset); // stdin
-       timeout.tv_sec = 0;
-       timeout.tv_usec = 0;
-       if (select (1, &fdset, NULL, NULL, &timeout) != -1 && FD_ISSET(0, &fdset))
-       {
-               len = read (0, text, sizeof(text) - 1);
-               if (len >= 1)
-               {
-                       // rip off the \n and terminate
-                       // div0: WHY? console code can deal with \n just fine
-                       // this caused problems with pasting stuff into a terminal window
-                       // so, not ripping off the \n, but STILL keeping a NUL terminator
-                       text[len] = 0;
-                       return text;
-               }
-       }
-#endif
-       return NULL;
-}
-
 char *Sys_GetClipboardData (void)
 {
        return NULL;