#ifndef C_LIB_H_ #define C_LIB_H_ #include "MSL_C/math.h" #include "SSystem/SComponent/c_xyz.h" #include "dolphin/mtx/mtx.h" inline bool cLib_IsZero(f32 value) { return fabsf(value) < 8e-11f; } void cLib_memCpy(void* dst, const void* src, unsigned long size); void cLib_memSet(void* ptr, int value, unsigned long size); f32 cLib_addCalc(f32* o_value, f32 target, f32 scale, f32 maxStep, f32 minStep); void cLib_addCalc2(f32* o_value, f32 target, f32 scale, f32 maxStep); void cLib_addCalc0(f32* o_value, f32 scale, f32 maxStep); f32 cLib_addCalcPos(cXyz* o_value, cXyz const& target, f32 scale, f32 maxStep, f32 minStep); f32 cLib_addCalcPosXZ(cXyz* o_value, cXyz const& target, f32 scale, f32 maxStep, f32 minStep); void cLib_addCalcPos2(cXyz* o_value, cXyz const& target, f32 scale, f32 maxStep); void cLib_addCalcPosXZ2(cXyz* o_value, cXyz const& target, f32 scale, f32 maxStep); s16 cLib_addCalcAngleS(s16* o_value, s16 target, s16 scale, s16 maxStep, s16 minStep); void cLib_addCalcAngleS2(s16* o_value, s16 target, s16 scale, s16 maxStep); int cLib_chaseUC(u8* o_value, u8 target, u8 step); int cLib_chaseS(s16* o_value, s16 target, s16 step); int cLib_chaseF(f32* o_value, f32 target, f32 step); int cLib_chasePos(cXyz* o_value, cXyz const& target, f32 step); int cLib_chasePosXZ(cXyz* o_value, cXyz const& target, f32 step); int cLib_chaseAngleS(s16* o_value, s16 target, s16 step); s16 cLib_targetAngleY(const Vec* lhs, const Vec* rhs); s16 cLib_targetAngleY(const Vec& lhs, const Vec& rhs); s16 cLib_targetAngleX(const cXyz*, const cXyz*); void cLib_offsetPos(cXyz* pDest, cXyz const* pSrc, s16 angle, cXyz const* vec); s32 cLib_distanceAngleS(s16 x, s16 y); template inline void cLib_offBit(T& value, u8 bit) { value &= ~bit; } template inline void cLib_onBit(T& value, u8 bit) { value |= bit; } template inline T cLib_checkBit(T& value, u8 bit) { return value & bit; } template inline T cLib_minMaxLimit(T val, T min, T max) { T ret; T var_r30; if (val < min) { ret = min; } else { if (val > max) { var_r30 = max; } else { var_r30 = val; } ret = var_r30; } return (T)ret; } template T cLib_calcTimer(T* val); void MtxInit(void); void MtxTrans(f32, f32, f32, u8); void MtxScale(f32, f32, f32, u8); void MtxPosition(cXyz*, cXyz*); void MtxPush(void); Mtx* MtxPull(void); extern Mtx* calc_mtx; #endif