duration.cc 5.66 KB
Newer Older
1
/*
2
 * Copyright (c) 2014-2015, Siemens AG. All rights reserved.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

#include <embb/base/c/internal/unused.h>
#include <embb/base/duration.h>
#include <embb/base/c/duration.h>
#include <embb/base/exceptions.h>
#include <embb/base/c/internal/platform.h>
#include <limits>
#include <cassert>

namespace embb {
namespace base {

38
void internal::Tick::CheckExceptions(int status, const char* msg) {
39 40 41 42 43 44 45 46
  switch (status) {
  case EMBB_SUCCESS: return;
  case EMBB_OVERFLOW: EMBB_THROW(OverflowException, msg);
  case EMBB_UNDERFLOW: EMBB_THROW(UnderflowException, msg);
  default: EMBB_THROW(ErrorException, msg);
  }
}

47
int internal::Seconds::Set(embb_duration_t& duration,
48
                           unsigned long long ticks) {
49 50 51
  return embb_duration_set_seconds(&duration, ticks);
}

52
void internal::Seconds::SetAndCheck(embb_duration_t& duration,
53
                                   unsigned long long ticks) {
54 55 56 57
  int status = Set(duration, ticks);
  CheckExceptions(status, "Setting duration from seconds");
}

58
unsigned long long internal::Seconds::Get(const embb_duration_t& duration) {
59 60 61 62 63 64 65
  unsigned long long ticks = 0;
  int status = embb_duration_as_seconds(&duration, &ticks);
  assert(status == EMBB_SUCCESS);
  EMBB_UNUSED_IN_RELEASE(status);
  return ticks;
}

66
unsigned long long internal::Seconds::Min() {
67 68 69
  return 1;
}

70
unsigned long long internal::Seconds::Max() {
71 72 73
  return EMBB_DURATION_MAX_SECONDS;
}

74
int internal::Milliseconds::Set(embb_duration_t& duration,
75
                                unsigned long long ticks) {
76 77 78
  return embb_duration_set_milliseconds(&duration, ticks);
}

79
void internal::Milliseconds::SetAndCheck(
80 81 82 83 84
  embb_duration_t& duration, unsigned long long ticks) {
  int status = Set(duration, ticks);
  CheckExceptions(status, "Setting duration from milliseconds");
}

85 86
unsigned long long internal::Milliseconds::Get(
    const embb_duration_t& duration) {
87 88 89 90 91 92 93
  unsigned long long ticks = 0;
  int status = embb_duration_as_milliseconds(&duration, &ticks);
  assert(status == EMBB_SUCCESS);
  EMBB_UNUSED_IN_RELEASE(status);
  return ticks;
}

94
unsigned long long internal::Milliseconds::Min() {
95 96 97 98 99 100 101
#if EMBB_DURATION_MIN_NANOSECONDS > 1000000
  assert(EMBB_DURATION_MIN_NANOSECONDS % 1000000 == 0);
  return EMBB_DURATION_MIN_NANOSECONDS / 1000000;
#endif
  return 1;
}

102
unsigned long long internal::Milliseconds::Max() {
103 104 105 106 107 108 109
#if EMBB_DURATION_MAX_SECONDS < ULLONG_MAX / 1000
  return ULLONG_MAX;
#else
  return EMBB_DURATION_MAX_SECONDS * 1000;
#endif
}

110
int internal::Microseconds::Set(embb_duration_t& duration,
111
                                unsigned long long ticks) {
112 113 114
  return embb_duration_set_microseconds(&duration, ticks);
}

115
void internal::Microseconds::SetAndCheck(
116 117 118 119 120
  embb_duration_t& duration, unsigned long long ticks) {
  int status = Set(duration, ticks);
  CheckExceptions(status, "Setting duration from microseconds");
}

121 122
unsigned long long internal::Microseconds::Get(
    const embb_duration_t& duration) {
123 124 125 126 127 128 129 130 131
  unsigned long long ticks = 0;

  int status = embb_duration_as_microseconds(&duration, &ticks);

  assert(status == EMBB_SUCCESS);
  EMBB_UNUSED_IN_RELEASE(status);
  return ticks;
}

132
unsigned long long internal::Microseconds::Min() {
133 134 135 136 137 138 139
#if EMBB_DURATION_MIN_NANOSECONDS > 1000
  assert(EMBB_DURATION_MIN_NANOSECONDS % 1000 == 0);
  return EMBB_DURATION_MIN_NANOSECONDS / 1000;
#endif
  return 1;
}

140
unsigned long long internal::Microseconds::Max() {
141 142 143 144 145 146 147
#if EMBB_DURATION_MAX_SECONDS < ULLONG_MAX / 1000000
  return ULLONG_MAX;
#else
  return EMBB_DURATION_MAX_SECONDS * 1000000;
#endif
}

148
int internal::Nanoseconds::Set(embb_duration_t& duration,
149
                               unsigned long long ticks) {
150 151 152
  return embb_duration_set_nanoseconds(&duration, ticks);
}

153
void internal::Nanoseconds::SetAndCheck(
154 155 156 157 158
  embb_duration_t& duration, unsigned long long ticks) {
  int status = Set(duration, ticks);
  CheckExceptions(status, "Setting duration from microseconds");
}

159
unsigned long long internal::Nanoseconds::Get(const embb_duration_t& duration) {
160 161 162 163 164 165 166
  unsigned long long ticks = 0;
  int status = embb_duration_as_nanoseconds(&duration, &ticks);
  assert(status == EMBB_SUCCESS);
  EMBB_UNUSED_IN_RELEASE(status);
  return ticks;
}

167
unsigned long long internal::Nanoseconds::Min() {
168 169 170
  return EMBB_DURATION_MIN_NANOSECONDS;
}

171
unsigned long long internal::Nanoseconds::Max() {
172 173 174 175 176 177 178 179 180
#if EMBB_DURATION_MAX_SECONDS < ULLONG_MAX / 1000000000
  return ULLONG_MAX;
#else
  return EMBB_DURATION_MAX_SECONDS * 1000000000;
#endif
}

} // namespace base
} // namespace embb