Home My Page Projects Code Snippets Project Openings SML/NJ
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files

SCM Repository

[smlnj] View of /sml/trunk/src/runtime/c-libs/smlnj-runtime/setitimer.c
ViewVC logotype

View of /sml/trunk/src/runtime/c-libs/smlnj-runtime/setitimer.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 651 - (download) (as text) (annotate)
Thu Jun 1 18:34:03 2000 UTC (20 years ago) by monnier
File size: 1969 byte(s)
bring revisions from the vendor branch to the trunk
/* setitimer.c
 *
 * COPYRIGHT (c) 1995 AT&T Bell Laboratories.
 *
 * NOTE: this implementation is UNIX specific right now; I would like to
 * define an OS abstraction layer for interval timers, which would cover
 * both alarm timers and profiling, but I need to look at what other systems
 * do first.
 */

#include "ml-base.h"
#ifdef OPSYS_UNIX
#  include "ml-unixdep.h"
#  include <sys/time.h>
#elif defined(OPSYS_WIN32)
#  include "win32-timers.h"
#endif
#include "ml-c.h"
#include "ml-values.h"
#include "ml-objects.h"
#include "cfun-proto-list.h"

/* _ml_RunT_setitimer : (int * int) option -> unit
 *
 * Set the interval timer; NONE means disable the timer
 */
ml_val_t _ml_RunT_setitimer (ml_state_t *msp, ml_val_t arg)
{
#ifdef HAS_SETITIMER
    struct itimerval	new_itv;
    int			sts;
    ml_val_t		tmp;

    if (arg == OPTION_NONE) {
      /* turn the timer off */
	new_itv.it_interval.tv_sec	=
	new_itv.it_value.tv_sec		=
	new_itv.it_interval.tv_usec	=
	new_itv.it_value.tv_usec	= 0;
    }
    else {
      /* turn the timer on */
	tmp = OPTION_get(arg);
	new_itv.it_interval.tv_sec	=
	new_itv.it_value.tv_sec		= REC_SELINT32(tmp, 0);
	new_itv.it_interval.tv_usec	=
	new_itv.it_value.tv_usec	= REC_SELINT(tmp, 1);
    }

    sts = setitimer (ITIMER_REAL, &new_itv, NIL(struct itimerval *));

    CHK_RETURN_UNIT(msp, sts);

#elif defined(OPSYS_WIN32)
    if (arg == OPTION_NONE) {
	if (win32StopTimer())
	    return ML_unit;
	else
	    return RAISE_ERROR(msp,"win32 setitimer: couldn't stop timer");
    }
    else {
	ml_val_t	tmp = OPTION_get(arg);
	int		mSecs = REC_SELINT32(tmp,0) * 1000 + REC_SELINT(tmp,1) / 1000;

	if (mSecs <= 0)
	    return RAISE_ERROR(msp, "win32 setitimer: invalid resolution");
	else {
	    if (win32StartTimer(mSecs))
		return ML_unit;
	    else
		return RAISE_ERROR(msp,"win32 setitimer: couldn't start timer");
	}
    }
#else
    return RAISE_ERROR(msp, "setitimer not supported");
#endif

} /* end of _ml_RunT_setitimer */


root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0