#ifndef INCLUDED_haxe_CppInt32__ #define INCLUDED_haxe_CppInt32__ #include namespace cpp { #define HX_I32_DEF_FUNC1(Name) \ static inline Dynamic __##Name(const Dynamic &a) { return Name(a); } \ static inline Dynamic Name##_dyn() { return hx::CreateStaticFunction1(#Name,&CppInt32__::__##Name); } #define HX_I32_DEF_FUNC2(Name) \ static inline Dynamic __##Name(const Dynamic &a, const Dynamic &b) { return Name(a,b); } \ static inline Dynamic Name##_dyn() { return hx::CreateStaticFunction2(#Name,&CppInt32__::__##Name); } class CppInt32__ { public: CppInt32__(int inX=0) : mValue(inX) { } CppInt32__(const null &inNull) : mValue(0) { } CppInt32__(const Dynamic &inD); operator int() const { return mValue; } template inline CppInt32__ &operator=(T inValue) { mValue = inValue; return *this; } static inline CppInt32__ make(int a,int b) { return CppInt32__( (a<<16) | b ); } static inline CppInt32__ ofInt(int a) { return CppInt32__( a ); } static inline int toInt(CppInt32__ a) { __hxcpp_check_overflow(a); return a.mValue; } static inline int toNativeInt(CppInt32__ a) { return a.mValue; } static inline CppInt32__ add(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue + b.mValue ); } static inline CppInt32__ sub(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue - b.mValue ); } static inline CppInt32__ mul(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue * b.mValue ); } static inline CppInt32__ div(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue / b.mValue ); } static inline CppInt32__ mod(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue % b.mValue ); } static inline CppInt32__ shl(CppInt32__ a,int b) { return CppInt32__( a.mValue << (b&31) ); } static inline CppInt32__ shr(CppInt32__ a,int b) { return CppInt32__( a.mValue >> (b&31) ); } static inline CppInt32__ ushr(CppInt32__ a,int b) { return CppInt32__( ((unsigned int)a.mValue) >> (b&31) ); } static inline CppInt32__ _and(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue & b.mValue ); } static inline CppInt32__ _or(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue | b.mValue ); } static inline CppInt32__ _xor(CppInt32__ a,CppInt32__ b) { return CppInt32__( a.mValue ^ b.mValue ); } static inline CppInt32__ neg(CppInt32__ a) { return CppInt32__( -a.mValue ); } static inline CppInt32__ complement(CppInt32__ a) { return CppInt32__( ~a.mValue ); } static inline int compare(CppInt32__ a,CppInt32__ b) { return ( a.mValue - b.mValue ); } static inline bool isNeg(CppInt32__ a) { return a.mValue < 0; } static inline bool isZero(CppInt32__ a) { return a.mValue == 0; } static inline int ucompare(CppInt32__ a,CppInt32__ b) { unsigned int am = a.mValue, bm = b.mValue; return (am == bm) ? 0 : ((am > bm) ? 1 : -1); } inline bool operator==(const CppInt32__ &inRHS) const { return mValue == inRHS.mValue; } inline int operator-(CppInt32__ b) { return mValue - b.mValue; } inline int operator+(CppInt32__ b) { return mValue + b.mValue; } inline int operator*(CppInt32__ b) { return mValue * b.mValue; } inline int operator/(CppInt32__ b) { return mValue / b.mValue; } inline int operator%(CppInt32__ b) { return mValue % b.mValue; } HX_I32_DEF_FUNC2(make) HX_I32_DEF_FUNC1(ofInt) HX_I32_DEF_FUNC1(toInt) HX_I32_DEF_FUNC1(toNativeInt) HX_I32_DEF_FUNC2(add) HX_I32_DEF_FUNC2(sub) HX_I32_DEF_FUNC2(mul) HX_I32_DEF_FUNC2(div) HX_I32_DEF_FUNC2(mod) HX_I32_DEF_FUNC2(shl) HX_I32_DEF_FUNC2(shr) HX_I32_DEF_FUNC2(ushr) HX_I32_DEF_FUNC2(_and) HX_I32_DEF_FUNC2(_or) HX_I32_DEF_FUNC2(_xor) HX_I32_DEF_FUNC1(neg) HX_I32_DEF_FUNC1(complement) HX_I32_DEF_FUNC2(compare) HX_I32_DEF_FUNC2(ucompare) HX_I32_DEF_FUNC1(isNeg) HX_I32_DEF_FUNC1(isZero) int mValue; }; typedef CppInt32__ CppInt32___obj; } #endif