Blame gnulib-tests/dtotimespec.c

Packit 33f14e
/* Convert double to timespec.
Packit 33f14e
Packit 33f14e
   Copyright (C) 2011-2017 Free Software Foundation, Inc.
Packit 33f14e
Packit 33f14e
   This program is free software: you can redistribute it and/or modify
Packit 33f14e
   it under the terms of the GNU General Public License as published by
Packit 33f14e
   the Free Software Foundation; either version 3 of the License, or
Packit 33f14e
   (at your option) any later version.
Packit 33f14e
Packit 33f14e
   This program is distributed in the hope that it will be useful,
Packit 33f14e
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 33f14e
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 33f14e
   GNU General Public License for more details.
Packit 33f14e
Packit 33f14e
   You should have received a copy of the GNU General Public License
Packit 33f14e
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit 33f14e
Packit 33f14e
/* written by Paul Eggert */
Packit 33f14e
Packit 33f14e
/* Convert the double value SEC to a struct timespec.  Round toward
Packit 33f14e
   positive infinity.  On overflow, return an extremal value.  */
Packit 33f14e
Packit 33f14e
#include <config.h>
Packit 33f14e
Packit 33f14e
#include "timespec.h"
Packit 33f14e
Packit 33f14e
#include "intprops.h"
Packit 33f14e
Packit 33f14e
struct timespec
Packit 33f14e
dtotimespec (double sec)
Packit 33f14e
{
Packit 33f14e
  if (! (TYPE_MINIMUM (time_t) < sec))
Packit 33f14e
    return make_timespec (TYPE_MINIMUM (time_t), 0);
Packit 33f14e
  else if (! (sec < 1.0 + TYPE_MAXIMUM (time_t)))
Packit 33f14e
    return make_timespec (TYPE_MAXIMUM (time_t), TIMESPEC_RESOLUTION - 1);
Packit 33f14e
  else
Packit 33f14e
    {
Packit 33f14e
      time_t s = sec;
Packit 33f14e
      double frac = TIMESPEC_RESOLUTION * (sec - s);
Packit 33f14e
      long ns = frac;
Packit 33f14e
      ns += ns < frac;
Packit 33f14e
      s += ns / TIMESPEC_RESOLUTION;
Packit 33f14e
      ns %= TIMESPEC_RESOLUTION;
Packit 33f14e
Packit 33f14e
      if (ns < 0)
Packit 33f14e
        {
Packit 33f14e
          s--;
Packit 33f14e
          ns += TIMESPEC_RESOLUTION;
Packit 33f14e
        }
Packit 33f14e
Packit 33f14e
      return make_timespec (s, ns);
Packit 33f14e
    }
Packit 33f14e
}