diff options
author | Johannes Hofmann <johannes.hofmann@gmx.de> | 2016-12-03 14:07:08 +0100 |
---|---|---|
committer | Johannes Hofmann <johannes.hofmann@gmx.de> | 2016-12-03 14:07:08 +0100 |
commit | 95188edf6fe63ee3fe8341b1b5c2e7b92beb3415 (patch) | |
tree | b3e09fe1cadd846881f1616c0bc7010cc95dc2be /lib/pure/osproc.nim | |
parent | b453a8e616f489e077f8edcd95623b07484e7b8b (diff) | |
download | Nim-95188edf6fe63ee3fe8341b1b5c2e7b92beb3415.tar.gz |
make sure first call to running() after process exit returns false
Diffstat (limited to 'lib/pure/osproc.nim')
-rw-r--r-- | lib/pure/osproc.nim | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/lib/pure/osproc.nim b/lib/pure/osproc.nim index f597bf773..1d43bb321 100644 --- a/lib/pure/osproc.nim +++ b/lib/pure/osproc.nim @@ -965,10 +965,16 @@ elif not defined(useNimRtl): var ret : int var status : cint = 1 ret = waitpid(p.id, status, WNOHANG) - if ret == int(p.id) and WIFEXITED(status): - p.exitStatus = status - if ret == 0: return true # Can't establish status. Assume running. - result = ret == int(p.id) + if ret == int(p.id): + if WIFEXITED(status): + p.exitStatus = status + return false + else: + return true + elif ret == 0: + return true # Can't establish status. Assume running. + else: + return false proc terminate(p: Process) = if kill(p.id, SIGTERM) != 0'i32: |