Merge pull request #837 from Guldoman/process_running_poll

Update process status when calling `process:running`
This commit is contained in:
Jefferson González 2022-02-08 16:36:18 -04:00 committed by GitHub
commit dc5888bc07
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 7 additions and 6 deletions

View File

@ -2,6 +2,7 @@
#include <string.h> #include <string.h>
#include <stdbool.h> #include <stdbool.h>
#include <stdint.h>
#include <stdlib.h> #include <stdlib.h>
#include <SDL.h> #include <SDL.h>
@ -67,9 +68,10 @@ typedef enum {
static bool poll_process(process_t* proc, int timeout) { static bool poll_process(process_t* proc, int timeout) {
if (!proc->running) if (!proc->running)
return false; return false;
unsigned int ticks = SDL_GetTicks(); uint32_t ticks = SDL_GetTicks();
if (timeout == WAIT_DEADLINE) if (timeout == WAIT_DEADLINE)
timeout = proc->deadline; timeout = proc->deadline;
do { do {
#ifdef _WIN32 #ifdef _WIN32
DWORD exit_code = -1; DWORD exit_code = -1;
@ -90,9 +92,8 @@ static bool poll_process(process_t* proc, int timeout) {
if (timeout) if (timeout)
SDL_Delay(5); SDL_Delay(5);
} while (timeout == WAIT_INFINITE || SDL_GetTicks() - ticks < timeout); } while (timeout == WAIT_INFINITE || SDL_GetTicks() - ticks < timeout);
if (!proc->running)
return false; return proc->running;
return true;
} }
static bool signal_process(process_t* proc, signal_e sig) { static bool signal_process(process_t* proc, signal_e sig) {
@ -433,8 +434,8 @@ static int f_gc(lua_State* L) {
} }
static int f_running(lua_State* L) { static int f_running(lua_State* L) {
process_t* self = (process_t*)luaL_checkudata(L, 1, API_TYPE_PROCESS); process_t* self = (process_t*)luaL_checkudata(L, 1, API_TYPE_PROCESS);
lua_pushboolean(L, self->running); lua_pushboolean(L, poll_process(self, WAIT_NONE));
return 1; return 1;
} }