www.digitalmars.com         C & C++   DMDScript  

digitalmars.D.learn - What's the equivalent of sleep(), wait(), or pause()

reply Charles D Hixson <charleshixsn earthlink.net> writes:
Alternatively, where in the documentation can I find it.

What I want to do is to wait for a couple of seconds with a
message on the screen before continuing.  I thought I knew
the answer (sleep(2) ), but that was the bash
command...what's the D equivalent?  Or do I just need to
build a do-nothing loop with a LONG countdown?  (That would
be a bad answer, because I don't really want to eat system
resources just because I'm waiting.)
Jul 08 2006
next sibling parent reply James Pelcis <jpelcis gmail.com> writes:
In this case, the best solution would likely be std.c.time.









I don't know of any pure D ways to do this in Phobos.  The closest I 
could think of is in std.thread and is specifically prohibited...









I don't know why that is though.  My guess would be it's to cover up 
limitations in the operating system thread implementations.  Can anyone 
confirm that?

Charles D Hixson wrote:
 Alternatively, where in the documentation can I find it.
 
 What I want to do is to wait for a couple of seconds with a
 message on the screen before continuing.  I thought I knew
 the answer (sleep(2) ), but that was the bash
 command...what's the D equivalent?  Or do I just need to
 build a do-nothing loop with a LONG countdown?  (That would
 be a bad answer, because I don't really want to eat system
 resources just because I'm waiting.)
Jul 08 2006
next sibling parent reply Dave <Dave_member pathlink.com> writes:
James Pelcis wrote:
 In this case, the best solution would likely be std.c.time.
 







 
 I don't know of any pure D ways to do this in Phobos.  The closest I 
 could think of is in std.thread and is specifically prohibited...
 







 
 I don't know why that is though.  My guess would be it's to cover up 
 limitations in the operating system thread implementations.  Can anyone 
 confirm that?
There is a possibility in each of the phobos implementations (Windows and Linux) for an indefinite wait to happen, so an if(this is getThis()) { error(...); } check is done. It looks like that potential is there to make these safe and still allow for the calling thread to call wait(uint) on itself though. But, I think a general purpose & portable 'sleep, msleep and/or usleep' is a good idea. sleep doesn't have > 1 sec. resolution, std.c.time.msleep is not in the std. C RT lib. on Linux systems, and usleep is deprecated on Linux, so the need is there for one. Where in Phobos should this go?
 Charles D Hixson wrote:
 Alternatively, where in the documentation can I find it.

 What I want to do is to wait for a couple of seconds with a
 message on the screen before continuing.  I thought I knew
 the answer (sleep(2) ), but that was the bash
 command...what's the D equivalent?  Or do I just need to
 build a do-nothing loop with a LONG countdown?  (That would
 be a bad answer, because I don't really want to eat system
 resources just because I'm waiting.)
Jul 08 2006
next sibling parent reply "Regan Heath" <regan netwin.co.nz> writes:
On Sat, 08 Jul 2006 19:06:13 -0500, Dave <Dave_member pathlink.com> wrote:
 sleep doesn't have > 1 sec. resolution, std.c.time.msleep is not in the  
 std. C RT lib. on Linux systems, and usleep is deprecated on Linux, so  
 the need is there for one.
FYI; There exists a function called "nanosleep" on some unix OS's. Regan
Jul 08 2006
parent Dave <Dave_member pathlink.com> writes:
Regan Heath wrote:
 On Sat, 08 Jul 2006 19:06:13 -0500, Dave <Dave_member pathlink.com> wrote:
 sleep doesn't have > 1 sec. resolution, std.c.time.msleep is not in 
 the std. C RT lib. on Linux systems, and usleep is deprecated on 
 Linux, so the need is there for one.
FYI; There exists a function called "nanosleep" on some unix OS's. Regan
Yep, that's what I'd use to implement the guts of portable and signal consistent 's/ms/usleep' functions on Linux.
Jul 08 2006
prev sibling parent Sean Kelly <sean f4.ca> writes:
Dave wrote:
 James Pelcis wrote:
 In this case, the best solution would likely be std.c.time.









 I don't know of any pure D ways to do this in Phobos.  The closest I 
 could think of is in std.thread and is specifically prohibited...









 I don't know why that is though.  My guess would be it's to cover up 
 limitations in the operating system thread implementations.  Can 
 anyone confirm that?
There is a possibility in each of the phobos implementations (Windows and Linux) for an indefinite wait to happen, so an if(this is getThis()) { error(...); } check is done. It looks like that potential is there to make these safe and still allow for the calling thread to call wait(uint) on itself though. But, I think a general purpose & portable 'sleep, msleep and/or usleep' is a good idea. sleep doesn't have > 1 sec. resolution, std.c.time.msleep is not in the std. C RT lib. on Linux systems, and usleep is deprecated on Linux, so the need is there for one. Where in Phobos should this go?
As a static function in the Thread class. See Ares for an example. Sean
Jul 08 2006
prev sibling parent reply Mike Parker <aldacron71 yahoo.com> writes:
James Pelcis wrote:

 
 I don't know of any pure D ways to do this in Phobos.  The closest I 
 could think of is in std.thread and is specifically prohibited...
 







 
 I don't know why that is though.  My guess would be it's to cover up 
 limitations in the operating system thread implementations.  Can anyone 
 confirm that?
Thread.wait() is not a sleep method - it's what is sometimes called a join (as in Java) - it waits for a thread to finish execution. A thread cannot wait for itself to finish, hence the error. We have a static Thread.yield() method and I don't know why there's no Thread.sleep(). It would be nice to have as a cross-platform solution.
Jul 09 2006
parent James Pelcis <jpelcis gmail.com> writes:
  > Thread.wait() is not a sleep method - it's what is sometimes called a
 join (as in Java) - it waits for a thread to finish execution. A thread 
 cannot wait for itself to finish, hence the error.
Thread.wait() is indeed that. If, however, you pass an integer, it will wait until it is either terminated or that number of milliseconds has passed. I think the check should be removed for that version.
 We have a static Thread.yield() method and I don't know why there's no 
 Thread.sleep(). It would be nice to have as a cross-platform solution.
I agree.
Jul 09 2006
prev sibling parent Derek Parnell <derek nomail.afraid.org> writes:
Valium();  <G>


-- 
Derek
(skype: derek.j.parnell)
Melbourne, Australia
"Down with mediocrity!"
10/07/2006 11:16:54 AM
Jul 09 2006