blob: 8ad3242250f24b597d4253c59353bdef4823c4d2 (
plain)
1
2
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
/*
* Integer Rounding Functions
* (C) 1999-2007 Jack Lloyd
*
* Botan is released under the Simplified BSD License (see license.txt)
*/
#ifndef BOTAN_ROUNDING_H__
#define BOTAN_ROUNDING_H__
#include <botan/types.h>
#include <botan/assert.h>
namespace Botan {
/**
* Round up
* @param n a non-negative integer
* @param align_to the alignment boundary
* @return n rounded up to a multiple of align_to
*/
inline size_t round_up(size_t n, size_t align_to)
{
BOTAN_ASSERT(align_to != 0, "align_to must not be 0");
if(n % align_to)
n += align_to - (n % align_to);
return n;
}
/**
* Round down
* @param n an integer
* @param align_to the alignment boundary
* @return n rounded down to a multiple of align_to
*/
template<typename T>
inline T round_down(T n, T align_to)
{
if(align_to == 0)
return n;
return (n - (n % align_to));
}
/**
* Clamp
*/
inline size_t clamp(size_t n, size_t lower_bound, size_t upper_bound)
{
if(n < lower_bound)
return lower_bound;
if(n > upper_bound)
return upper_bound;
return n;
}
}
#endif
|