# HG changeset patch # User skidd13 # Date 1213461663 0 # Node ID e4ff3aea4acf604ae183362f5437e56be61d0935 # Parent 2649d7a316af76bf22b8ef88604658ffe78df446 (svn r13517) -Add: remaining used typesafe versions of the mem* functions from diff -r 2649d7a316af -r e4ff3aea4acf src/core/mem_func.hpp --- a/src/core/mem_func.hpp Sat Jun 14 16:23:08 2008 +0000 +++ b/src/core/mem_func.hpp Sat Jun 14 16:41:03 2008 +0000 @@ -22,6 +22,46 @@ } /** + * Type-safe version of memmove(). + * + * @param destination Pointer to the destination buffer + * @param source Pointer to the source buffer + * @param num number of items to be copied. (!not number of bytes!) + */ +template +FORCEINLINE void MemMoveT(T *destination, const T *source, uint num = 1) +{ + memmove(destination, source, num * sizeof(T)); +} + +/** + * Type-safe version of memset(). + * + * @param ptr Pointer to the destination buffer + * @param value Value to be set + * @param num number of items to be set (!not number of bytes!) + */ +template +FORCEINLINE void MemSetT(T *ptr, int value, uint num = 1) +{ + memset(ptr, value, num * sizeof(T)); +} + +/** + * Type-safe version of memcmp(). + * + * @param ptr1 Pointer to the first buffer + * @param ptr2 Pointer to the second buffer + * @param num Number of items to compare. (!not number of bytes!) + * @return an int value indicating the relationship between the content of the two buffers + */ +template +FORCEINLINE int MemCmpT(const T *ptr1, const T *ptr2, uint num = 1) +{ + return memcmp(ptr1, ptr2, num * sizeof(T)); +} + +/** * Type safe memory reverse operation. * Reverse a block of memory in steps given by the * type of the pointers.