OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CC_BASE_UTIL_H_ | 5 #ifndef CC_BASE_UTIL_H_ |
6 #define CC_BASE_UTIL_H_ | 6 #define CC_BASE_UTIL_H_ |
7 | 7 |
8 #include <limits> | 8 #include <limits> |
9 | 9 |
10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
11 | 11 |
| 12 // Declares an enum for which the values can be used to index an array. |
| 13 // In addition to the enum, this also declares 3 constants. enumname_MIN, |
| 14 // enumname_MAX and enumname_ARRAYSIZE. The last can be used to declare |
| 15 // an array that is large enough to allow indexing using all enum values. |
| 16 #define DEFINE_ENUM(name, ...) \ |
| 17 enum name { __VA_ARGS__ }; \ |
| 18 const name name ## _MIN = static_cast<name>(0); \ |
| 19 const name name ## _MAX = static_cast<name>( \ |
| 20 sizeof((int[]) { __VA_ARGS__ }) / sizeof(name ## _MIN) - 1); \ |
| 21 const int name ## _ARRAYSIZE = name ## _MAX + 1 |
| 22 |
12 namespace cc { | 23 namespace cc { |
13 | 24 |
14 template <typename T> T RoundUp(T n, T mul) { | 25 template <typename T> T RoundUp(T n, T mul) { |
15 COMPILE_ASSERT(std::numeric_limits<T>::is_integer, type_must_be_integral); | 26 COMPILE_ASSERT(std::numeric_limits<T>::is_integer, type_must_be_integral); |
16 return (n > 0) ? ((n + mul - 1) / mul) * mul | 27 return (n > 0) ? ((n + mul - 1) / mul) * mul |
17 : (n / mul) * mul; | 28 : (n / mul) * mul; |
18 } | 29 } |
19 | 30 |
20 template <typename T> T RoundDown(T n, T mul) { | 31 template <typename T> T RoundDown(T n, T mul) { |
21 COMPILE_ASSERT(std::numeric_limits<T>::is_integer, type_must_be_integral); | 32 COMPILE_ASSERT(std::numeric_limits<T>::is_integer, type_must_be_integral); |
22 return (n > 0) ? (n / mul) * mul | 33 return (n > 0) ? (n / mul) * mul |
23 : (n == 0) ? 0 | 34 : (n == 0) ? 0 |
24 : ((n - mul + 1) / mul) * mul; | 35 : ((n - mul + 1) / mul) * mul; |
25 } | 36 } |
26 | 37 |
27 } // namespace cc | 38 } // namespace cc |
28 | 39 |
29 #endif // CC_BASE_UTIL_H_ | 40 #endif // CC_BASE_UTIL_H_ |
OLD | NEW |