/* * This file is part of libbluray * Copyright (C) 2009-2010 Obliter0n * Copyright (C) 2009-2010 John Stebbins * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see * . */ #ifndef MACRO_H_ #define MACRO_H_ #include /* free() */ #define MKINT_BE16(X) ( (X)[0] << 8 | (X)[1] ) #define MKINT_BE24(X) ( (X)[0] << 16 | (X)[1] << 8 | (X)[2] ) #define MKINT_BE32(X) ( (X)[0] << 24 | (X)[1] << 16 | (X)[2] << 8 | (X)[3] ) #define X_FREE(X) ( free(X), X = NULL ) #define BD_MIN(a,b) ((a)<(b)?(a):(b)) #define BD_MAX(a,b) ((a)>(b)?(a):(b)) /* * */ // endian safe fetch #define FETCH4(X) (uint32_t)(((X)[0]<<24)|(X)[1]<<16|(X)[2]<<8|(X)[3]) #define FETCHU2(X) (uint32_t)((uint16_t)(((X)[0]<<8)|(X)[1])) // Sign extended version #define FETCHS2(X) (int32_t)((int16_t)(((X)[0]<<8)|(X)[1])) #define STORE8(X, Y) (X)[7]=((Y)&0xff);(X)[6]=(((Y)>>8)&0xff);(X)[5]=(((Y)>>16)&0xff);(X)[4]=(((Y)>>24)&0xff);(X)[3]=(((Y)>>32)&0xff);(X)[2]=(((Y)>>40)&0xff);(X)[1]=(((Y)>>48)&0xff);(X)[0]=(((Y)>>56)&0xff); #define STORE4(X, Y) (X)[3]=((Y)&0xff);(X)[2]=(((Y)>>8)&0xff);(X)[1]=(((Y)>>16)&0xff);(X)[0]=(((Y)>>24)&0xff); #define STORE2(X, Y) (X)[1]=(((Y))&0xff);(X)[0]=(((Y)>>8)&0xff); /* * automatic cast from void* (malloc/calloc/realloc) */ #ifdef __cplusplus template class auto_cast_wrapper { public: template friend auto_cast_wrapper auto_cast(const R& x); template operator U() { return static_cast(p); } private: auto_cast_wrapper(const T& x) : p(x) {} auto_cast_wrapper(const auto_cast_wrapper& o) : p(o.p) {} auto_cast_wrapper& operator=(const auto_cast_wrapper&); const T& p; }; template auto_cast_wrapper auto_cast(const R& x) { return auto_cast_wrapper(x); } # define calloc(n,s) auto_cast(calloc(n,s)) # define malloc(s) auto_cast(malloc(s)) # define realloc(p,s) auto_cast(realloc(p,s)) # define refcnt_realloc(p,s) auto_cast(refcnt_realloc(p,s)) #endif /* __cplusplus */ #endif /* MACRO_H_ */