summaryrefslogtreecommitdiff
path: root/src/cmd_helper.h
diff options
context:
space:
mode:
authorfrosch <frosch@openttd.org>2010-04-11 15:44:16 +0000
committerfrosch <frosch@openttd.org>2010-04-11 15:44:16 +0000
commit0d4e6c46ff4af97205823014e0b4300c7a2c3044 (patch)
treebe9825c3e22820b5a09cc8d31daa9be6b9127979 /src/cmd_helper.h
parent03c609f019f437f4fb7e252a2345d4b62ab930e8 (diff)
downloadopenttd-0d4e6c46ff4af97205823014e0b4300c7a2c3044.tar.xz
(svn r19605) -Codechange: Merge ExtractBits into EnumPropsT.
Diffstat (limited to 'src/cmd_helper.h')
-rw-r--r--src/cmd_helper.h19
1 files changed, 4 insertions, 15 deletions
diff --git a/src/cmd_helper.h b/src/cmd_helper.h
index 8c9c789ca..a034f1217 100644
--- a/src/cmd_helper.h
+++ b/src/cmd_helper.h
@@ -12,25 +12,14 @@
#ifndef CMD_HELPER_H
#define CMD_HELPER_H
-#include "direction_type.h"
-#include "road_type.h"
-
-
-template<uint N> static inline void ExtractValid();
-template<> inline void ExtractValid<1>() {}
-
-
-template<typename T> struct ExtractBits;
-template<> struct ExtractBits<Axis> { static const uint Count = 1; };
-template<> struct ExtractBits<DiagDirection> { static const uint Count = 2; };
-template<> struct ExtractBits<RoadBits> { static const uint Count = 4; };
-
+#include "core/enum_type.hpp"
template<typename T, uint N, typename U> static inline T Extract(U v)
{
/* Check if there are enough bits in v */
- ExtractValid<N + ExtractBits<T>::Count <= sizeof(U) * 8>();
- return (T)GB(v, N, ExtractBits<T>::Count);
+ assert_tcompile(N + EnumPropsT<T>::num_bits <= sizeof(U) * 8);
+ assert_tcompile(EnumPropsT<T>::end <= (1 << EnumPropsT<T>::num_bits));
+ return (T)GB(v, N, EnumPropsT<T>::num_bits);
}
#endif