X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/3a45cd9275dc9279e133deb0932402ae5f4d0b5f..ad34d43426a49a050c807a9fffcda0ccf8bb23d2:/stglibs/common.lib/common.cpp diff --git a/stglibs/common.lib/common.cpp b/stglibs/common.lib/common.cpp index 606f057a..3361adb3 100644 --- a/stglibs/common.lib/common.cpp +++ b/stglibs/common.lib/common.cpp @@ -64,6 +64,7 @@ #include #include #include +#include #endif #include @@ -996,7 +997,6 @@ if (0 == strncasecmp(str.c_str(), "no", 2)) return -1; } -inline int ParseInt(const std::string & str, int * val) { if (str2x(str, *val)) @@ -1004,7 +1004,6 @@ if (str2x(str, *val)) return 0; } -inline int ParseUnsigned(const string & str, unsigned * val) { if (str2x(str, *val)) @@ -1034,3 +1033,27 @@ if (*val < min || *val > max) return 0; } + +bool WaitPackets(int sd) +{ +fd_set rfds; +FD_ZERO(&rfds); +FD_SET(sd, &rfds); + +struct timeval tv; +tv.tv_sec = 0; +tv.tv_usec = 500000; + +int res = select(sd + 1, &rfds, NULL, NULL, &tv); +if (res == -1) // Error + { + if (errno != EINTR) + printfd(__FILE__, "Error on select: '%s'\n", strerror(errno)); + return false; + } + +if (res == 0) // Timeout + return false; + +return true; +}