mirror of https://github.com/zeldaret/tp.git
JUtility / JSupport / misc cleanup
This commit is contained in:
parent
090dcee012
commit
eae9455a7d
|
@ -22,7 +22,7 @@ public:
|
||||||
u32 getGraphMemory() const { return mGraphMemoryPtr; }
|
u32 getGraphMemory() const { return mGraphMemoryPtr; }
|
||||||
u32 getGraphMemSize() const { return mGraphMemorySize; }
|
u32 getGraphMemSize() const { return mGraphMemorySize; }
|
||||||
|
|
||||||
private:
|
//private:
|
||||||
/* 0x00 */ // vtable
|
/* 0x00 */ // vtable
|
||||||
/* 0x04 */ // JKRThread
|
/* 0x04 */ // JKRThread
|
||||||
/* 0x7C */ u32 mAudioMemoryPtr;
|
/* 0x7C */ u32 mAudioMemoryPtr;
|
||||||
|
|
|
@ -38,12 +38,18 @@ extern TAtanTable atanTable_;
|
||||||
extern TAsinAcosTable asinAcosTable_;
|
extern TAsinAcosTable asinAcosTable_;
|
||||||
}; // namespace JMath
|
}; // namespace JMath
|
||||||
|
|
||||||
inline f32 JMASSin(s16 s) {
|
inline f32 JMASCosShort(s16 v) {
|
||||||
return JMath::sincosTable_.sinShort(s);
|
return JMath::sincosTable_.cosShort(v);
|
||||||
|
}
|
||||||
|
inline f32 JMASinShort(s16 v) {
|
||||||
|
return JMath::sincosTable_.sinShort(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline f32 JMASCos(s16 s) {
|
inline f32 JMASCos(s16 v) {
|
||||||
return JMath::sincosTable_.cosShort(s);
|
return JMASCosShort(v);
|
||||||
|
}
|
||||||
|
inline f32 JMASSin(s16 v) {
|
||||||
|
return JMASinShort(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* JMATRIGONOMETRIC_H */
|
#endif /* JMATRIGONOMETRIC_H */
|
||||||
|
|
|
@ -23,14 +23,13 @@
|
||||||
#define JUT_PANIC(...)
|
#define JUT_PANIC(...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// TODO: make it a namespace
|
namespace JUTAssertion {
|
||||||
struct JUTAssertion {
|
/* 802E495C */ void create();
|
||||||
/* 802E495C */ static void create();
|
/* 802E4960 */ u32 flush_subroutine();
|
||||||
/* 802E4960 */ static u32 flush_subroutine();
|
/* 802E499C */ void flushMessage();
|
||||||
/* 802E499C */ static void flushMessage();
|
/* 802E4A54 */ void flushMessage_dbPrint();
|
||||||
/* 802E4A54 */ static void flushMessage_dbPrint();
|
/* 802E4C34 */ void setVisible(bool);
|
||||||
/* 802E4C34 */ static void setVisible(bool);
|
/* 802E4C3C */ void setMessageCount(int);
|
||||||
/* 802E4C3C */ static void setMessageCount(int);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern bool sAssertVisible;
|
extern bool sAssertVisible;
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
class JUTCacheFont : public JUTResFont {
|
class JUTCacheFont : public JUTResFont {
|
||||||
public:
|
public:
|
||||||
struct TGlyphCacheInfo {
|
struct TGlyphCacheInfo {
|
||||||
/* 0x0 */ TGlyphCacheInfo* field_0x0;
|
/* 0x0 */ TGlyphCacheInfo* mPrev;
|
||||||
/* 0x4 */ TGlyphCacheInfo** field_0x4;
|
/* 0x4 */ TGlyphCacheInfo* mNext;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct TCachePage {
|
struct TCachePage {
|
||||||
|
@ -64,7 +64,7 @@ private:
|
||||||
/* 0x84 */ void* field_0x84;
|
/* 0x84 */ void* field_0x84;
|
||||||
/* 0x88 */ u32 mMaxSheetSize;
|
/* 0x88 */ u32 mMaxSheetSize;
|
||||||
/* 0x8C */ EPagingType mPagingType;
|
/* 0x8C */ EPagingType mPagingType;
|
||||||
/* 0x90 */ void** mCacheBuffer;
|
/* 0x90 */ void* mCacheBuffer;
|
||||||
/* 0x94 */ int field_0x94;
|
/* 0x94 */ int field_0x94;
|
||||||
/* 0x98 */ u32 mCachePage;
|
/* 0x98 */ u32 mCachePage;
|
||||||
/* 0x9C */ TGlyphCacheInfo* field_0x9c;
|
/* 0x9C */ TGlyphCacheInfo* field_0x9c;
|
||||||
|
|
|
@ -148,5 +148,6 @@ extern "C" JUTConsole* JUTGetWarningConsole();
|
||||||
extern "C" void JUTReportConsole_f_va(const char*, va_list);
|
extern "C" void JUTReportConsole_f_va(const char*, va_list);
|
||||||
extern "C" void JUTReportConsole_f(const char*, ...);
|
extern "C" void JUTReportConsole_f(const char*, ...);
|
||||||
extern "C" void JUTWarningConsole(const char* message);
|
extern "C" void JUTWarningConsole(const char* message);
|
||||||
|
extern "C" void JUTReportConsole(const char* message);
|
||||||
|
|
||||||
#endif /* JUTCONSOLE_H */
|
#endif /* JUTCONSOLE_H */
|
||||||
|
|
|
@ -55,6 +55,7 @@ struct ResFONT {
|
||||||
/* 0x08 */ u32 filesize;
|
/* 0x08 */ u32 filesize;
|
||||||
/* 0x0C */ u32 numBlocks;
|
/* 0x0C */ u32 numBlocks;
|
||||||
/* 0x10 */ u8 padding[0x10];
|
/* 0x10 */ u8 padding[0x10];
|
||||||
|
/* 0x20 */ u8 data[];
|
||||||
};
|
};
|
||||||
|
|
||||||
class JUTFont {
|
class JUTFont {
|
||||||
|
|
|
@ -3,9 +3,13 @@
|
||||||
|
|
||||||
#include "JSystem/JKernel/JKRHeap.h"
|
#include "JSystem/JKernel/JKRHeap.h"
|
||||||
#include "JSystem/JUtility/JUTFont.h"
|
#include "JSystem/JUtility/JUTFont.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
typedef bool (*IsLeadByte)(int);
|
typedef bool (*IsLeadByte_func)(int);
|
||||||
|
|
||||||
|
struct BlockHeader {
|
||||||
|
u32 magic;
|
||||||
|
u32 size;
|
||||||
|
};
|
||||||
|
|
||||||
class JUTResFont : public JUTFont {
|
class JUTResFont : public JUTFont {
|
||||||
public:
|
public:
|
||||||
|
@ -43,7 +47,7 @@ public:
|
||||||
initialize_state();
|
initialize_state();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void* const saoAboutEncoding_[3];
|
static IsLeadByte_func const saoAboutEncoding_[3];
|
||||||
|
|
||||||
// some types uncertain, may need to be fixed
|
// some types uncertain, may need to be fixed
|
||||||
/* 0x1C */ int mWidth;
|
/* 0x1C */ int mWidth;
|
||||||
|
@ -61,7 +65,7 @@ public:
|
||||||
/* 0x64 */ u16 mMap1BlockNum;
|
/* 0x64 */ u16 mMap1BlockNum;
|
||||||
/* 0x66 */ u16 field_0x66;
|
/* 0x66 */ u16 field_0x66;
|
||||||
/* 0x68 */ u16 mMaxCode;
|
/* 0x68 */ u16 mMaxCode;
|
||||||
/* 0x6C */ IsLeadByte* mIsLeadByte;
|
/* 0x6C */ IsLeadByte_func* mIsLeadByte;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* JUTRESFONT_H */
|
#endif /* JUTRESFONT_H */
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "JSystem/JMath/JMath.h"
|
#include "JSystem/JMath/JMath.h"
|
||||||
|
#include "JSystem/JMath/JMATrigonometric.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
|
@ -29,6 +29,21 @@ extern "C" u8 sincosTable___5JMath[65536];
|
||||||
|
|
||||||
/* 80339878-80339938 3341B8 00C0+00 0/0 11/11 2/2 .text JMAEulerToQuat__FsssP10Quaternion
|
/* 80339878-80339938 3341B8 00C0+00 0/0 11/11 2/2 .text JMAEulerToQuat__FsssP10Quaternion
|
||||||
*/
|
*/
|
||||||
|
#ifdef NONMATCHING
|
||||||
|
void JMAEulerToQuat(s16 x, s16 y, s16 z, Quaternion* quat) {
|
||||||
|
f32 cosX = JMASCos(x / 2);
|
||||||
|
f32 cosY = JMASCos(y / 2);
|
||||||
|
f32 cosZ = JMASCos(z / 2);
|
||||||
|
f32 sinX = JMASSin(x / 2);
|
||||||
|
f32 sinY = JMASSin(y / 2);
|
||||||
|
f32 sinZ = JMASSin(z / 2);
|
||||||
|
|
||||||
|
quat->w = cosX * (cosY * cosZ) + sinX * (sinY * sinZ);
|
||||||
|
quat->x = sinX * (cosY * cosZ) - cosX * (sinY * sinZ);
|
||||||
|
quat->y = cosZ * (cosX * sinY) + sinZ * (sinX * cosY);
|
||||||
|
quat->z = sinZ * (cosX * cosY) - cosZ * (sinX * sinY);
|
||||||
|
}
|
||||||
|
#else
|
||||||
#pragma push
|
#pragma push
|
||||||
#pragma optimization_level 0
|
#pragma optimization_level 0
|
||||||
#pragma optimizewithasm off
|
#pragma optimizewithasm off
|
||||||
|
@ -37,24 +52,40 @@ asm void JMAEulerToQuat(s16 param_0, s16 param_1, s16 param_2, Quaternion* param
|
||||||
#include "asm/JSystem/JMath/JMath/JMAEulerToQuat__FsssP10Quaternion.s"
|
#include "asm/JSystem/JMath/JMath/JMAEulerToQuat__FsssP10Quaternion.s"
|
||||||
}
|
}
|
||||||
#pragma pop
|
#pragma pop
|
||||||
|
#endif
|
||||||
/* ############################################################################################## */
|
|
||||||
/* 804564C8-804564D0 004AC8 0008+00 1/1 0/0 0/0 .sdata2 @376 */
|
|
||||||
SECTION_SDATA2 static u8 lit_376[8] = {
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
};
|
|
||||||
|
|
||||||
/* 80339938-80339A30 334278 00F8+00 0/0 5/5 0/0 .text
|
/* 80339938-80339A30 334278 00F8+00 0/0 5/5 0/0 .text
|
||||||
* JMAQuatLerp__FPC10QuaternionPC10QuaternionfP10Quaternion */
|
* JMAQuatLerp__FPC10QuaternionPC10QuaternionfP10Quaternion */
|
||||||
#pragma push
|
void JMAQuatLerp(register const Quaternion* p, register const Quaternion* q, f32 t,
|
||||||
#pragma optimization_level 0
|
Quaternion* dst) {
|
||||||
#pragma optimizewithasm off
|
register f32 pxy, pzw, qxy, qzw;
|
||||||
asm void JMAQuatLerp(Quaternion const* param_0, Quaternion const* param_1, f32 param_2,
|
register f32 dp;
|
||||||
Quaternion* param_3) {
|
__asm // compute dot product
|
||||||
nofralloc
|
{
|
||||||
#include "asm/JSystem/JMath/JMath/JMAQuatLerp__FPC10QuaternionPC10QuaternionfP10Quaternion.s"
|
psq_l pxy, 0(p), 0, 0
|
||||||
|
psq_l qxy, 0(q), 0, 0
|
||||||
|
ps_mul dp, pxy, qxy
|
||||||
|
|
||||||
|
psq_l pzw, 8(p), 0, 0
|
||||||
|
psq_l qzw, 8(q), 0, 0
|
||||||
|
ps_madd dp, pzw, qzw, dp
|
||||||
|
|
||||||
|
ps_sum0 dp, dp, dp, dp
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dp < 0.0) {
|
||||||
|
dst->x = -t * (p->x + q->x) + p->x;
|
||||||
|
dst->y = -t * (p->y + q->y) + p->y;
|
||||||
|
dst->z = -t * (p->z + q->z) + p->z;
|
||||||
|
dst->w = -t * (p->w + q->w) + p->w;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
dst->x = -t * (p->x - q->x) + p->x;
|
||||||
|
dst->y = -t * (p->y - q->y) + p->y;
|
||||||
|
dst->z = -t * (p->z - q->z) + p->z;
|
||||||
|
dst->w = -t * (p->w - q->w) + p->w;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#pragma pop
|
|
||||||
|
|
||||||
/* 80339A30-80339A5C 334370 002C+00 0/0 1/1 0/0 .text JMAFastVECNormalize__FPC3VecP3Vec
|
/* 80339A30-80339A5C 334370 002C+00 0/0 1/1 0/0 .text JMAFastVECNormalize__FPC3VecP3Vec
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -4,12 +4,6 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "JSystem/JMath/random.h"
|
#include "JSystem/JMath/random.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
|
||||||
// Declarations:
|
|
||||||
//
|
|
||||||
|
|
||||||
/* 80339AE4-80339AEC -00001 0008+00 0/0 0/0 0/0 .text __ct__Q25JMath13TRandom_fast_FUl */
|
/* 80339AE4-80339AEC -00001 0008+00 0/0 0/0 0/0 .text __ct__Q25JMath13TRandom_fast_FUl */
|
||||||
JMath::TRandom_fast_::TRandom_fast_(u32 param_0) {
|
JMath::TRandom_fast_::TRandom_fast_(u32 param_0) {
|
||||||
|
|
|
@ -4,12 +4,6 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "JSystem/JSupport/JSUFileStream.h"
|
#include "JSystem/JSupport/JSUFileStream.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
|
||||||
// Declarations:
|
|
||||||
//
|
|
||||||
|
|
||||||
/* 802DC638-802DC67C 2D6F78 0044+00 0/0 1/1 0/0 .text __ct__18JSUFileInputStreamFP7JKRFile */
|
/* 802DC638-802DC67C 2D6F78 0044+00 0/0 1/1 0/0 .text __ct__18JSUFileInputStreamFP7JKRFile */
|
||||||
JSUFileInputStream::JSUFileInputStream(JKRFile* pFile) {
|
JSUFileInputStream::JSUFileInputStream(JKRFile* pFile) {
|
||||||
|
@ -22,11 +16,10 @@ JSUFileInputStream::JSUFileInputStream(JKRFile* pFile) {
|
||||||
u32 JSUFileInputStream::readData(void* pBuffer, s32 length) {
|
u32 JSUFileInputStream::readData(void* pBuffer, s32 length) {
|
||||||
s32 lenRead = 0;
|
s32 lenRead = 0;
|
||||||
if (mFile->isAvailable()) {
|
if (mFile->isAvailable()) {
|
||||||
// TODO: the function probably returns u32
|
|
||||||
// there are probably more functions that return u32 instead of s32
|
|
||||||
if (mPosition + length > (u32)mFile->getFileSize()) {
|
if (mPosition + length > (u32)mFile->getFileSize()) {
|
||||||
length = mFile->getFileSize() - mPosition;
|
length = mFile->getFileSize() - mPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (length > 0) {
|
if (length > 0) {
|
||||||
lenRead = mFile->readData(pBuffer, length, mPosition);
|
lenRead = mFile->readData(pBuffer, length, mPosition);
|
||||||
if (lenRead < 0) {
|
if (lenRead < 0) {
|
||||||
|
@ -36,6 +29,7 @@ u32 JSUFileInputStream::readData(void* pBuffer, s32 length) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return lenRead;
|
return lenRead;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,6 +37,7 @@ u32 JSUFileInputStream::readData(void* pBuffer, s32 length) {
|
||||||
* seekPos__18JSUFileInputStreamFl17JSUStreamSeekFrom */
|
* seekPos__18JSUFileInputStreamFl17JSUStreamSeekFrom */
|
||||||
s32 JSUFileInputStream::seekPos(s32 pos, JSUStreamSeekFrom seekFrom) {
|
s32 JSUFileInputStream::seekPos(s32 pos, JSUStreamSeekFrom seekFrom) {
|
||||||
s32 oldPos = mPosition;
|
s32 oldPos = mPosition;
|
||||||
|
|
||||||
switch (seekFrom) {
|
switch (seekFrom) {
|
||||||
case JSUStreamSeekFrom_SET:
|
case JSUStreamSeekFrom_SET:
|
||||||
mPosition = pos;
|
mPosition = pos;
|
||||||
|
@ -54,12 +49,15 @@ s32 JSUFileInputStream::seekPos(s32 pos, JSUStreamSeekFrom seekFrom) {
|
||||||
mPosition += pos;
|
mPosition += pos;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mPosition < 0) {
|
if (mPosition < 0) {
|
||||||
mPosition = 0;
|
mPosition = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mPosition > mFile->getFileSize()) {
|
if (mPosition > mFile->getFileSize()) {
|
||||||
mPosition = mFile->getFileSize();
|
mPosition = mFile->getFileSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
return mPosition - oldPos;
|
return mPosition - oldPos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,37 +5,19 @@
|
||||||
|
|
||||||
#include "JSystem/JSupport/JSUInputStream.h"
|
#include "JSystem/JSupport/JSUInputStream.h"
|
||||||
#include "JSystem/JSupport/JSURandomInputStream.h"
|
#include "JSystem/JSupport/JSURandomInputStream.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "global.h"
|
|
||||||
|
|
||||||
//
|
|
||||||
// Types:
|
|
||||||
//
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
//
|
//
|
||||||
|
|
||||||
extern "C" void __dt__14JSUInputStreamFv();
|
|
||||||
extern "C" void read__14JSUInputStreamFPvl();
|
|
||||||
extern "C" void skip__14JSUInputStreamFl();
|
|
||||||
extern "C" void align__20JSURandomInputStreamFl();
|
|
||||||
extern "C" void skip__20JSURandomInputStreamFl();
|
extern "C" void skip__20JSURandomInputStreamFl();
|
||||||
extern "C" void peek__20JSURandomInputStreamFPvl();
|
|
||||||
extern "C" void seek__20JSURandomInputStreamFl17JSUStreamSeekFrom();
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// External References:
|
// External References:
|
||||||
//
|
//
|
||||||
|
|
||||||
extern "C" void __dt__20JSURandomInputStreamFv();
|
extern "C" void __dt__20JSURandomInputStreamFv();
|
||||||
extern "C" void __dl__FPv();
|
|
||||||
extern "C" void getAvailable__20JSURandomInputStreamCFv();
|
extern "C" void getAvailable__20JSURandomInputStreamCFv();
|
||||||
extern "C" void _savegpr_28();
|
|
||||||
extern "C" void _savegpr_29();
|
|
||||||
extern "C" void _restgpr_28();
|
|
||||||
extern "C" void _restgpr_29();
|
|
||||||
extern "C" extern void* __vt__10JSUIosBase[3];
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Declarations:
|
// Declarations:
|
||||||
|
@ -43,7 +25,7 @@ extern "C" extern void* __vt__10JSUIosBase[3];
|
||||||
|
|
||||||
/* ############################################################################################## */
|
/* ############################################################################################## */
|
||||||
/* 803CC4B0-803CC4D4 0295D0 0024+00 0/0 7/7 0/0 .data __vt__20JSURandomInputStream */
|
/* 803CC4B0-803CC4D4 0295D0 0024+00 0/0 7/7 0/0 .data __vt__20JSURandomInputStream */
|
||||||
SECTION_DATA extern void* __vt__20JSURandomInputStream[9] = {
|
extern void* __vt__20JSURandomInputStream[9] = {
|
||||||
(void*)NULL /* RTTI */,
|
(void*)NULL /* RTTI */,
|
||||||
(void*)NULL,
|
(void*)NULL,
|
||||||
(void*)__dt__20JSURandomInputStreamFv,
|
(void*)__dt__20JSURandomInputStreamFv,
|
||||||
|
@ -55,26 +37,14 @@ SECTION_DATA extern void* __vt__20JSURandomInputStream[9] = {
|
||||||
(void*)NULL,
|
(void*)NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* 803CC4D4-803CC4F0 0295F4 0018+04 1/1 4/4 0/0 .data __vt__14JSUInputStream */
|
|
||||||
SECTION_DATA extern void* __vt__14JSUInputStream[6 + 1 /* padding */] = {
|
|
||||||
(void*)NULL /* RTTI */,
|
|
||||||
(void*)NULL,
|
|
||||||
(void*)__dt__14JSUInputStreamFv,
|
|
||||||
(void*)NULL,
|
|
||||||
(void*)skip__14JSUInputStreamFl,
|
|
||||||
(void*)NULL,
|
|
||||||
/* padding */
|
|
||||||
NULL,
|
|
||||||
};
|
|
||||||
|
|
||||||
/* 802DC23C-802DC298 2D6B7C 005C+00 1/0 6/6 0/0 .text __dt__14JSUInputStreamFv */
|
/* 802DC23C-802DC298 2D6B7C 005C+00 1/0 6/6 0/0 .text __dt__14JSUInputStreamFv */
|
||||||
JSUInputStream::~JSUInputStream() {}
|
JSUInputStream::~JSUInputStream() {}
|
||||||
|
|
||||||
/* 802DC298-802DC2F0 2D6BD8 0058+00 1/1 20/20 0/0 .text read__14JSUInputStreamFPvl */
|
/* 802DC298-802DC2F0 2D6BD8 0058+00 1/1 20/20 0/0 .text read__14JSUInputStreamFPvl */
|
||||||
s32 JSUInputStream::read(void* buffer, s32 numBytes) {
|
s32 JSUInputStream::read(void* buffer, s32 numBytes) {
|
||||||
s32 bytesRead = this->readData(buffer, numBytes);
|
s32 bytesRead = readData(buffer, numBytes);
|
||||||
if (bytesRead != numBytes) {
|
if (bytesRead != numBytes) {
|
||||||
this->setState(IOS_STATE_1);
|
setState(IOS_STATE_1);
|
||||||
}
|
}
|
||||||
return bytesRead;
|
return bytesRead;
|
||||||
}
|
}
|
||||||
|
@ -84,7 +54,7 @@ s32 JSUInputStream::skip(s32 count) {
|
||||||
s32 skipCount = 0;
|
s32 skipCount = 0;
|
||||||
u8 buffer[1];
|
u8 buffer[1];
|
||||||
while (count > skipCount) {
|
while (count > skipCount) {
|
||||||
if (this->readData(&buffer, 1) != 1) {
|
if (readData(&buffer, 1) != 1) {
|
||||||
setState(IOS_STATE_1);
|
setState(IOS_STATE_1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -95,15 +65,15 @@ s32 JSUInputStream::skip(s32 count) {
|
||||||
|
|
||||||
/* 802DC370-802DC3FC 2D6CB0 008C+00 0/0 1/1 0/0 .text align__20JSURandomInputStreamFl */
|
/* 802DC370-802DC3FC 2D6CB0 008C+00 0/0 1/1 0/0 .text align__20JSURandomInputStreamFl */
|
||||||
s32 JSURandomInputStream::align(s32 alignment) {
|
s32 JSURandomInputStream::align(s32 alignment) {
|
||||||
s32 currentPos = this->getPosition();
|
s32 currentPos = getPosition();
|
||||||
s32 offset = (alignment + currentPos);
|
s32 offset = (alignment + currentPos);
|
||||||
offset -= 1;
|
offset -= 1;
|
||||||
offset &= ~(alignment - 1);
|
offset &= ~(alignment - 1);
|
||||||
s32 alignmentOffset = offset - currentPos;
|
s32 alignmentOffset = offset - currentPos;
|
||||||
if (alignmentOffset != 0) {
|
if (alignmentOffset != 0) {
|
||||||
s32 seekLen = this->seekPos(offset, JSUStreamSeekFrom_SET);
|
s32 seekLen = seekPos(offset, JSUStreamSeekFrom_SET);
|
||||||
if (seekLen != alignmentOffset) {
|
if (seekLen != alignmentOffset) {
|
||||||
this->setState(IOS_STATE_1);
|
setState(IOS_STATE_1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return alignmentOffset;
|
return alignmentOffset;
|
||||||
|
@ -111,19 +81,19 @@ s32 JSURandomInputStream::align(s32 alignment) {
|
||||||
|
|
||||||
/* 802DC3FC-802DC458 2D6D3C 005C+00 1/0 2/0 0/0 .text skip__20JSURandomInputStreamFl */
|
/* 802DC3FC-802DC458 2D6D3C 005C+00 1/0 2/0 0/0 .text skip__20JSURandomInputStreamFl */
|
||||||
s32 JSURandomInputStream::skip(s32 param_0) {
|
s32 JSURandomInputStream::skip(s32 param_0) {
|
||||||
s32 val = this->seekPos(param_0, JSUStreamSeekFrom_CUR);
|
s32 val = seekPos(param_0, JSUStreamSeekFrom_CUR);
|
||||||
if (val != param_0) {
|
if (val != param_0) {
|
||||||
this->setState(IOS_STATE_1);
|
setState(IOS_STATE_1);
|
||||||
}
|
}
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802DC458-802DC4DC 2D6D98 0084+00 0/0 8/8 0/0 .text peek__20JSURandomInputStreamFPvl */
|
/* 802DC458-802DC4DC 2D6D98 0084+00 0/0 8/8 0/0 .text peek__20JSURandomInputStreamFPvl */
|
||||||
s32 JSURandomInputStream::peek(void* buffer, s32 numBytes) {
|
s32 JSURandomInputStream::peek(void* buffer, s32 numBytes) {
|
||||||
s32 oldPos = this->getPosition();
|
s32 oldPos = getPosition();
|
||||||
s32 bytesRead = this->read(buffer, numBytes);
|
s32 bytesRead = read(buffer, numBytes);
|
||||||
if (bytesRead != 0) {
|
if (bytesRead != 0) {
|
||||||
this->seekPos(oldPos, JSUStreamSeekFrom_SET);
|
seekPos(oldPos, JSUStreamSeekFrom_SET);
|
||||||
}
|
}
|
||||||
return bytesRead;
|
return bytesRead;
|
||||||
}
|
}
|
||||||
|
@ -131,7 +101,7 @@ s32 JSURandomInputStream::peek(void* buffer, s32 numBytes) {
|
||||||
/* 802DC4DC-802DC520 2D6E1C 0044+00 0/0 16/16 0/0 .text
|
/* 802DC4DC-802DC520 2D6E1C 0044+00 0/0 16/16 0/0 .text
|
||||||
* seek__20JSURandomInputStreamFl17JSUStreamSeekFrom */
|
* seek__20JSURandomInputStreamFl17JSUStreamSeekFrom */
|
||||||
s32 JSURandomInputStream::seek(s32 param_0, JSUStreamSeekFrom param_1) {
|
s32 JSURandomInputStream::seek(s32 param_0, JSUStreamSeekFrom param_1) {
|
||||||
s32 seekResult = this->seekPos(param_0, param_1);
|
s32 seekResult = seekPos(param_0, param_1);
|
||||||
this->clrState(IOS_STATE_1);
|
clrState(IOS_STATE_1);
|
||||||
return seekResult;
|
return seekResult;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,32 +4,30 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "JSystem/JSupport/JSUList.h"
|
#include "JSystem/JSupport/JSUList.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
JSUPtrLink::JSUPtrLink(void* object) {
|
JSUPtrLink::JSUPtrLink(void* object) {
|
||||||
this->mList = NULL;
|
mList = NULL;
|
||||||
this->mObject = object;
|
mObject = object;
|
||||||
this->mPrev = NULL;
|
mPrev = NULL;
|
||||||
this->mNext = NULL;
|
mNext = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
JSUPtrLink::~JSUPtrLink() {
|
JSUPtrLink::~JSUPtrLink() {
|
||||||
if (this->mList != NULL) {
|
if (mList != NULL) {
|
||||||
this->mList->remove(this);
|
mList->remove(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
JSUPtrList::JSUPtrList(bool init) {
|
JSUPtrList::JSUPtrList(bool init) {
|
||||||
if (init) {
|
if (init) {
|
||||||
this->initiate();
|
initiate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
JSUPtrList::~JSUPtrList() {
|
JSUPtrList::~JSUPtrList() {
|
||||||
JSUPtrLink* node = this->mHead;
|
JSUPtrLink* node = mHead;
|
||||||
s32 removed = 0;
|
s32 removed = 0;
|
||||||
while (this->mLength > removed) {
|
while (mLength > removed) {
|
||||||
node->mList = NULL;
|
node->mList = NULL;
|
||||||
node = node->getNext();
|
node = node->getNext();
|
||||||
removed += 1;
|
removed += 1;
|
||||||
|
@ -37,18 +35,18 @@ JSUPtrList::~JSUPtrList() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void JSUPtrList::initiate() {
|
void JSUPtrList::initiate() {
|
||||||
this->mHead = NULL;
|
mHead = NULL;
|
||||||
this->mTail = NULL;
|
mTail = NULL;
|
||||||
this->mLength = 0;
|
mLength = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void JSUPtrList::setFirst(JSUPtrLink* first) {
|
void JSUPtrList::setFirst(JSUPtrLink* first) {
|
||||||
first->mList = this;
|
first->mList = this;
|
||||||
first->mPrev = NULL;
|
first->mPrev = NULL;
|
||||||
first->mNext = NULL;
|
first->mNext = NULL;
|
||||||
this->mTail = first;
|
mTail = first;
|
||||||
this->mHead = first;
|
mHead = first;
|
||||||
this->mLength = 1;
|
mLength = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool JSUPtrList::append(JSUPtrLink* ptr) {
|
bool JSUPtrList::append(JSUPtrLink* ptr) {
|
||||||
|
@ -59,15 +57,15 @@ bool JSUPtrList::append(JSUPtrLink* ptr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result) {
|
if (result) {
|
||||||
if (this->mLength == 0) {
|
if (mLength == 0) {
|
||||||
this->setFirst(ptr);
|
setFirst(ptr);
|
||||||
} else {
|
} else {
|
||||||
ptr->mList = this;
|
ptr->mList = this;
|
||||||
ptr->mPrev = this->mTail;
|
ptr->mPrev = mTail;
|
||||||
ptr->mNext = NULL;
|
ptr->mNext = NULL;
|
||||||
this->mTail->mNext = ptr;
|
mTail->mNext = ptr;
|
||||||
this->mTail = ptr;
|
mTail = ptr;
|
||||||
this->mLength++;
|
mLength++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,15 +80,15 @@ bool JSUPtrList::prepend(JSUPtrLink* ptr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result) {
|
if (result) {
|
||||||
if (this->mLength == 0) {
|
if (mLength == 0) {
|
||||||
this->setFirst(ptr);
|
setFirst(ptr);
|
||||||
} else {
|
} else {
|
||||||
ptr->mList = this;
|
ptr->mList = this;
|
||||||
ptr->mPrev = NULL;
|
ptr->mPrev = NULL;
|
||||||
ptr->mNext = this->mHead;
|
ptr->mNext = mHead;
|
||||||
this->mHead->mPrev = ptr;
|
mHead->mPrev = ptr;
|
||||||
this->mHead = ptr;
|
mHead = ptr;
|
||||||
this->mLength++;
|
mLength++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,10 +96,10 @@ bool JSUPtrList::prepend(JSUPtrLink* ptr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool JSUPtrList::insert(JSUPtrLink* before, JSUPtrLink* ptr) {
|
bool JSUPtrList::insert(JSUPtrLink* before, JSUPtrLink* ptr) {
|
||||||
if (before == this->mHead) {
|
if (before == mHead) {
|
||||||
return this->prepend(ptr);
|
return prepend(ptr);
|
||||||
} else if (before == NULL) {
|
} else if (before == NULL) {
|
||||||
return this->append(ptr);
|
return append(ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (before->mList != this) {
|
if (before->mList != this) {
|
||||||
|
@ -120,7 +118,7 @@ bool JSUPtrList::insert(JSUPtrLink* before, JSUPtrLink* ptr) {
|
||||||
ptr->mNext = before;
|
ptr->mNext = before;
|
||||||
prev->mNext = ptr;
|
prev->mNext = ptr;
|
||||||
before->mPrev = ptr;
|
before->mPrev = ptr;
|
||||||
this->mLength++;
|
mLength++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
@ -129,33 +127,33 @@ bool JSUPtrList::insert(JSUPtrLink* before, JSUPtrLink* ptr) {
|
||||||
bool JSUPtrList::remove(JSUPtrLink* ptr) {
|
bool JSUPtrList::remove(JSUPtrLink* ptr) {
|
||||||
bool is_parent = (ptr->mList == this);
|
bool is_parent = (ptr->mList == this);
|
||||||
if (is_parent) {
|
if (is_parent) {
|
||||||
if (this->mLength == 1) {
|
if (mLength == 1) {
|
||||||
this->mHead = NULL;
|
mHead = NULL;
|
||||||
this->mTail = NULL;
|
mTail = NULL;
|
||||||
} else if (ptr == this->mHead) {
|
} else if (ptr == mHead) {
|
||||||
ptr->mNext->mPrev = NULL;
|
ptr->mNext->mPrev = NULL;
|
||||||
this->mHead = ptr->mNext;
|
mHead = ptr->mNext;
|
||||||
} else if (ptr == this->mTail) {
|
} else if (ptr == mTail) {
|
||||||
ptr->mPrev->mNext = NULL;
|
ptr->mPrev->mNext = NULL;
|
||||||
this->mTail = ptr->mPrev;
|
mTail = ptr->mPrev;
|
||||||
} else {
|
} else {
|
||||||
ptr->mPrev->mNext = ptr->mNext;
|
ptr->mPrev->mNext = ptr->mNext;
|
||||||
ptr->mNext->mPrev = ptr->mPrev;
|
ptr->mNext->mPrev = ptr->mPrev;
|
||||||
}
|
}
|
||||||
|
|
||||||
ptr->mList = NULL;
|
ptr->mList = NULL;
|
||||||
this->mLength--;
|
mLength--;
|
||||||
}
|
}
|
||||||
|
|
||||||
return is_parent;
|
return is_parent;
|
||||||
}
|
}
|
||||||
|
|
||||||
JSUPtrLink* JSUPtrList::getNthLink(u32 index) const {
|
JSUPtrLink* JSUPtrList::getNthLink(u32 index) const {
|
||||||
if (index >= this->mLength) {
|
if (index >= mLength) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
JSUPtrLink* node = this->mHead;
|
JSUPtrLink* node = mHead;
|
||||||
for (u32 i = 0; i < index; i++) {
|
for (u32 i = 0; i < index; i++) {
|
||||||
node = node->getNext();
|
node = node->getNext();
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,12 +5,6 @@
|
||||||
|
|
||||||
#include "JSystem/JSupport/JSUMemoryStream.h"
|
#include "JSystem/JSupport/JSUMemoryStream.h"
|
||||||
#include "MSL_C/MSL_Common/Src/string.h"
|
#include "MSL_C/MSL_Common/Src/string.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
|
||||||
// Declarations:
|
|
||||||
//
|
|
||||||
|
|
||||||
/* 802DC520-802DC534 2D6E60 0014+00 0/0 3/3 0/0 .text setBuffer__20JSUMemoryInputStreamFPCvl */
|
/* 802DC520-802DC534 2D6E60 0014+00 0/0 3/3 0/0 .text setBuffer__20JSUMemoryInputStreamFPCvl */
|
||||||
void JSUMemoryInputStream::setBuffer(void const* pBuffer, s32 length) {
|
void JSUMemoryInputStream::setBuffer(void const* pBuffer, s32 length) {
|
||||||
|
@ -24,10 +18,12 @@ u32 JSUMemoryInputStream::readData(void* pData, s32 length) {
|
||||||
if (mPosition + length > mLength) {
|
if (mPosition + length > mLength) {
|
||||||
length = mLength - mPosition;
|
length = mLength - mPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (length > 0) {
|
if (length > 0) {
|
||||||
memcpy(pData, (void*)((s32)mBuffer + mPosition), length);
|
memcpy(pData, (void*)((s32)mBuffer + mPosition), length);
|
||||||
mPosition += length;
|
mPosition += length;
|
||||||
}
|
}
|
||||||
|
|
||||||
return length;
|
return length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,6 +31,7 @@ u32 JSUMemoryInputStream::readData(void* pData, s32 length) {
|
||||||
* seekPos__20JSUMemoryInputStreamFl17JSUStreamSeekFrom */
|
* seekPos__20JSUMemoryInputStreamFl17JSUStreamSeekFrom */
|
||||||
s32 JSUMemoryInputStream::seekPos(s32 pos, JSUStreamSeekFrom seekFrom) {
|
s32 JSUMemoryInputStream::seekPos(s32 pos, JSUStreamSeekFrom seekFrom) {
|
||||||
s32 oldPos = mPosition;
|
s32 oldPos = mPosition;
|
||||||
|
|
||||||
switch (seekFrom) {
|
switch (seekFrom) {
|
||||||
case JSUStreamSeekFrom_SET:
|
case JSUStreamSeekFrom_SET:
|
||||||
mPosition = pos;
|
mPosition = pos;
|
||||||
|
@ -46,12 +43,15 @@ s32 JSUMemoryInputStream::seekPos(s32 pos, JSUStreamSeekFrom seekFrom) {
|
||||||
mPosition += pos;
|
mPosition += pos;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mPosition < 0) {
|
if (mPosition < 0) {
|
||||||
mPosition = 0;
|
mPosition = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mPosition > mLength) {
|
if (mPosition > mLength) {
|
||||||
mPosition = mLength;
|
mPosition = mLength;
|
||||||
}
|
}
|
||||||
|
|
||||||
return mPosition - oldPos;
|
return mPosition - oldPos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,27 +6,30 @@
|
||||||
#include "JSystem/JUtility/JUTAssert.h"
|
#include "JSystem/JUtility/JUTAssert.h"
|
||||||
#include "JSystem/JUtility/JUTDbPrint.h"
|
#include "JSystem/JUtility/JUTDbPrint.h"
|
||||||
#include "JSystem/JUtility/JUTDirectPrint.h"
|
#include "JSystem/JUtility/JUTDirectPrint.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
#include "dolphin/vi/vi.h"
|
#include "dolphin/vi/vi.h"
|
||||||
|
|
||||||
//
|
namespace JUTAssertion {
|
||||||
// Declarations:
|
|
||||||
//
|
|
||||||
|
|
||||||
/* 802E495C-802E4960 2DF29C 0004+00 0/0 1/1 0/0 .text create__12JUTAssertionFv */
|
/* 802E495C-802E4960 2DF29C 0004+00 0/0 1/1 0/0 .text create__12JUTAssertionFv */
|
||||||
void JUTAssertion::create() {
|
void create() {}
|
||||||
/* empty function */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ############################################################################################## */
|
namespace {
|
||||||
/* 80451530-80451538 000A30 0004+04 2/2 0/0 0/0 .sbss
|
/* 80451530-80451538 000A30 0004+04 2/2 0/0 0/0 .sbss
|
||||||
* sMessageLife__Q212JUTAssertion23@unnamed@JUTAssert_cpp@ */
|
* sMessageLife__Q212JUTAssertion23@unnamed@JUTAssert_cpp@ */
|
||||||
static u32 sMessageLife;
|
static u32 sMessageLife;
|
||||||
|
|
||||||
|
/* 80434870-804348B0 061590 0040+00 2/2 0/0 0/0 .bss
|
||||||
|
* sMessageFileLine__Q212JUTAssertion23@unnamed@JUTAssert_cpp@ */
|
||||||
|
static char sMessageFileLine[64];
|
||||||
|
|
||||||
|
/* 804348B0-804349B0 0615D0 0100+00 2/2 0/0 0/0 .bss
|
||||||
|
* sMessageString__Q212JUTAssertion23@unnamed@JUTAssert_cpp@ */
|
||||||
|
static char sMessageString[256];
|
||||||
|
}; // namespace
|
||||||
|
|
||||||
/* 802E4960-802E499C 2DF2A0 003C+00 2/2 0/0 0/0 .text flush_subroutine__12JUTAssertionFv
|
/* 802E4960-802E499C 2DF2A0 003C+00 2/2 0/0 0/0 .text flush_subroutine__12JUTAssertionFv
|
||||||
*/
|
*/
|
||||||
u32 JUTAssertion::flush_subroutine() {
|
u32 flush_subroutine() {
|
||||||
if (sMessageLife == 0) {
|
if (sMessageLife == 0) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -38,20 +41,12 @@ u32 JUTAssertion::flush_subroutine() {
|
||||||
if (sMessageLife >= 5) {
|
if (sMessageLife >= 5) {
|
||||||
return sMessageLife;
|
return sMessageLife;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ############################################################################################## */
|
|
||||||
/* 80434870-804348B0 061590 0040+00 2/2 0/0 0/0 .bss
|
|
||||||
* sMessageFileLine__Q212JUTAssertion23@unnamed@JUTAssert_cpp@ */
|
|
||||||
static char sMessageFileLine[64];
|
|
||||||
|
|
||||||
/* 804348B0-804349B0 0615D0 0100+00 2/2 0/0 0/0 .bss
|
|
||||||
* sMessageString__Q212JUTAssertion23@unnamed@JUTAssert_cpp@ */
|
|
||||||
static char sMessageString[256];
|
|
||||||
|
|
||||||
/* 802E499C-802E4A54 2DF2DC 00B8+00 0/0 1/1 0/0 .text flushMessage__12JUTAssertionFv */
|
/* 802E499C-802E4A54 2DF2DC 00B8+00 0/0 1/1 0/0 .text flushMessage__12JUTAssertionFv */
|
||||||
void JUTAssertion::flushMessage() {
|
void flushMessage() {
|
||||||
if (flush_subroutine() && sAssertVisible == true) {
|
if (flush_subroutine() && sAssertVisible == true) {
|
||||||
JUTDirectPrint* manager = JUTDirectPrint::getManager();
|
JUTDirectPrint* manager = JUTDirectPrint::getManager();
|
||||||
JUtility::TColor color = manager->getCharColor();
|
JUtility::TColor color = manager->getCharColor();
|
||||||
|
@ -63,7 +58,7 @@ void JUTAssertion::flushMessage() {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802E4A54-802E4C34 2DF394 01E0+00 0/0 1/1 0/0 .text flushMessage_dbPrint__12JUTAssertionFv */
|
/* 802E4A54-802E4C34 2DF394 01E0+00 0/0 1/1 0/0 .text flushMessage_dbPrint__12JUTAssertionFv */
|
||||||
void JUTAssertion::flushMessage_dbPrint() {
|
void flushMessage_dbPrint() {
|
||||||
if (flush_subroutine() && sAssertVisible == true && JUTDbPrint::getManager() != NULL) {
|
if (flush_subroutine() && sAssertVisible == true && JUTDbPrint::getManager() != NULL) {
|
||||||
JUTFont* font = JUTDbPrint::getManager()->getFont();
|
JUTFont* font = JUTDbPrint::getManager()->getFont();
|
||||||
if (font != NULL) {
|
if (font != NULL) {
|
||||||
|
@ -77,12 +72,14 @@ void JUTAssertion::flushMessage_dbPrint() {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802E4C34-802E4C3C 2DF574 0008+00 0/0 2/2 0/0 .text setVisible__12JUTAssertionFb */
|
/* 802E4C34-802E4C3C 2DF574 0008+00 0/0 2/2 0/0 .text setVisible__12JUTAssertionFb */
|
||||||
void JUTAssertion::setVisible(bool visible) {
|
void setVisible(bool visible) {
|
||||||
sAssertVisible = visible;
|
sAssertVisible = visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802E4C3C-802E4C54 2DF57C 0018+00 0/0 2/2 0/0 .text setMessageCount__12JUTAssertionFi
|
/* 802E4C3C-802E4C54 2DF57C 0018+00 0/0 2/2 0/0 .text setMessageCount__12JUTAssertionFi
|
||||||
*/
|
*/
|
||||||
void JUTAssertion::setMessageCount(int msg_count) {
|
void setMessageCount(int msg_count) {
|
||||||
sMessageLife = msg_count <= 0 ? 0 : msg_count;
|
sMessageLife = msg_count <= 0 ? 0 : msg_count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}; // namespace JUTAssertion
|
||||||
|
|
|
@ -4,16 +4,8 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "JSystem/JUtility/JUTCacheFont.h"
|
#include "JSystem/JUtility/JUTCacheFont.h"
|
||||||
|
#include "JSystem/JUtility/JUTException.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
|
||||||
// Types:
|
|
||||||
//
|
|
||||||
|
|
||||||
struct JUTException {
|
|
||||||
/* 802E21FC */ void panic_f(char const*, int, char const*, ...);
|
|
||||||
};
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
|
@ -164,8 +156,8 @@ struct BlockHeader {
|
||||||
};
|
};
|
||||||
|
|
||||||
int JUTCacheFont::getMemorySize(ResFONT const* p_font, u16* o_widCount, u32* o_widSize,
|
int JUTCacheFont::getMemorySize(ResFONT const* p_font, u16* o_widCount, u32* o_widSize,
|
||||||
u16* o_glyCount, u32* o_glySize, u16* o_mapCount, u32* o_mapSize,
|
u16* o_glyCount, u32* o_glySize, u16* o_mapCount, u32* o_mapSize,
|
||||||
u32* o_glyTexSize) {
|
u32* o_glyTexSize) {
|
||||||
if (p_font == NULL) {
|
if (p_font == NULL) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -235,7 +227,7 @@ int JUTCacheFont::getMemorySize(ResFONT const* p_font, u16* o_widCount, u32* o_w
|
||||||
if (o_glyTexSize != NULL) {
|
if (o_glyTexSize != NULL) {
|
||||||
*o_glyTexSize = maxGlyTexSize;
|
*o_glyTexSize = maxGlyTexSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -243,8 +235,8 @@ int JUTCacheFont::getMemorySize(ResFONT const* p_font, u16* o_widCount, u32* o_w
|
||||||
#pragma optimization_level 0
|
#pragma optimization_level 0
|
||||||
#pragma optimizewithasm off
|
#pragma optimizewithasm off
|
||||||
asm int JUTCacheFont::getMemorySize(ResFONT const* param_0, u16* param_1, u32* param_2,
|
asm int JUTCacheFont::getMemorySize(ResFONT const* param_0, u16* param_1, u32* param_2,
|
||||||
u16* param_3, u32* param_4, u16* param_5, u32* param_6,
|
u16* param_3, u32* param_4, u16* param_5, u32* param_6,
|
||||||
u32* param_7) {
|
u32* param_7) {
|
||||||
nofralloc
|
nofralloc
|
||||||
#include "asm/JSystem/JUtility/JUTCacheFont/getMemorySize__12JUTCacheFontFPC7ResFONTPUsPUlPUsPUlPUsPUlPUl.s"
|
#include "asm/JSystem/JUtility/JUTCacheFont/getMemorySize__12JUTCacheFontFPC7ResFONTPUsPUlPUsPUlPUsPUlPUl.s"
|
||||||
}
|
}
|
||||||
|
@ -253,8 +245,7 @@ asm int JUTCacheFont::getMemorySize(ResFONT const* param_0, u16* param_1, u32* p
|
||||||
|
|
||||||
/* 802DD4EC-802DD54C 2D7E2C 0060+00 1/1 0/0 0/0 .text
|
/* 802DD4EC-802DD54C 2D7E2C 0060+00 1/1 0/0 0/0 .text
|
||||||
* initiate__12JUTCacheFontFPC7ResFONTPvUlP7JKRHeap */
|
* initiate__12JUTCacheFontFPC7ResFONTPvUlP7JKRHeap */
|
||||||
int JUTCacheFont::initiate(ResFONT const* p_fontRes, void* param_1, u32 param_2,
|
int JUTCacheFont::initiate(ResFONT const* p_fontRes, void* param_1, u32 param_2, JKRHeap* p_heap) {
|
||||||
JKRHeap* p_heap) {
|
|
||||||
if (!internal_initiate(p_fontRes, param_1, param_2, p_heap)) {
|
if (!internal_initiate(p_fontRes, param_1, param_2, p_heap)) {
|
||||||
deleteMemBlocks_CacheFont();
|
deleteMemBlocks_CacheFont();
|
||||||
deleteMemBlocks_ResFont();
|
deleteMemBlocks_ResFont();
|
||||||
|
@ -269,20 +260,21 @@ int JUTCacheFont::initiate(ResFONT const* p_fontRes, void* param_1, u32 param_2,
|
||||||
/* 802DD54C-802DD650 2D7E8C 0104+00 1/1 0/0 0/0 .text
|
/* 802DD54C-802DD650 2D7E8C 0104+00 1/1 0/0 0/0 .text
|
||||||
* internal_initiate__12JUTCacheFontFPC7ResFONTPvUlP7JKRHeap */
|
* internal_initiate__12JUTCacheFontFPC7ResFONTPvUlP7JKRHeap */
|
||||||
bool JUTCacheFont::internal_initiate(ResFONT const* p_fontRes, void* param_1, u32 param_2,
|
bool JUTCacheFont::internal_initiate(ResFONT const* p_fontRes, void* param_1, u32 param_2,
|
||||||
JKRHeap* param_3) {
|
JKRHeap* param_3) {
|
||||||
deleteMemBlocks_CacheFont();
|
deleteMemBlocks_CacheFont();
|
||||||
initialize_state();
|
initialize_state();
|
||||||
deleteMemBlocks_ResFont();
|
deleteMemBlocks_ResFont();
|
||||||
JUTResFont::initialize_state();
|
JUTResFont::initialize_state();
|
||||||
JUTFont::initialize_state();
|
JUTFont::initialize_state();
|
||||||
|
|
||||||
if (p_fontRes == NULL) {
|
if (p_fontRes == NULL) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
mResFont = p_fontRes;
|
mResFont = p_fontRes;
|
||||||
mValid = true;
|
mValid = true;
|
||||||
getMemorySize(p_fontRes, &mWid1BlockNum, &mTotalWidSize, &mGly1BlockNum, &mTotalGlySize, &mMap1BlockNum, &mTotalMapSize, &mMaxSheetSize);
|
getMemorySize(p_fontRes, &mWid1BlockNum, &mTotalWidSize, &mGly1BlockNum, &mTotalGlySize,
|
||||||
|
&mMap1BlockNum, &mTotalMapSize, &mMaxSheetSize);
|
||||||
|
|
||||||
if (!allocArea(param_1, param_2, param_3)) {
|
if (!allocArea(param_1, param_2, param_3)) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -295,14 +287,60 @@ bool JUTCacheFont::internal_initiate(ResFONT const* p_fontRes, void* param_1, u3
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802DD650-802DD804 2D7F90 01B4+00 1/1 0/0 0/0 .text allocArea__12JUTCacheFontFPvUlP7JKRHeap */
|
/* 802DD650-802DD804 2D7F90 01B4+00 1/1 0/0 0/0 .text allocArea__12JUTCacheFontFPvUlP7JKRHeap */
|
||||||
#pragma push
|
bool JUTCacheFont::allocArea(void* param_0, u32 param_1, JKRHeap* heap) {
|
||||||
#pragma optimization_level 0
|
mInf1Ptr = (ResFONT::INF1*)new (heap, 0) ResFONT();
|
||||||
#pragma optimizewithasm off
|
if (mInf1Ptr == NULL) {
|
||||||
asm bool JUTCacheFont::allocArea(void* param_0, u32 param_1, JKRHeap* param_2) {
|
return false;
|
||||||
nofralloc
|
}
|
||||||
#include "asm/JSystem/JUtility/JUTCacheFont/allocArea__12JUTCacheFontFPvUlP7JKRHeap.s"
|
|
||||||
|
if (mTotalWidSize != 0) {
|
||||||
|
field_0x7c = new (heap, 0) u8[mTotalWidSize];
|
||||||
|
if (field_0x7c == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mGly1BlockNum != 0) {
|
||||||
|
field_0x80 = new (heap, 0) ResFONT::GLY1[mGly1BlockNum];
|
||||||
|
if (field_0x80 == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
field_0xac = JKRAram::getManager()->mAramHeap->alloc(
|
||||||
|
mTotalGlySize - (mGly1BlockNum * sizeof(ResFONT::GLY1)), JKRAramHeap::HEAD);
|
||||||
|
if (field_0xac == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mTotalMapSize != 0) {
|
||||||
|
field_0x84 = new (heap, 0) u8[mTotalMapSize];
|
||||||
|
if (field_0x84 == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
field_0x94 = mMaxSheetSize + 0x40;
|
||||||
|
mCachePage = param_1 / field_0x94;
|
||||||
|
u32 v1 = field_0x94 * mCachePage;
|
||||||
|
if (mCachePage == 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (param_0 != NULL) {
|
||||||
|
mCacheBuffer = param_0;
|
||||||
|
field_0xb0 = 0;
|
||||||
|
} else {
|
||||||
|
mCacheBuffer = new (heap, 0x20) u8[v1];
|
||||||
|
if (mCacheBuffer == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
field_0xb0 = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
invalidiateAllCache();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
#pragma pop
|
|
||||||
|
|
||||||
/* 802DD804-802DD8EC 2D8144 00E8+00 1/1 0/0 0/0 .text allocArray__12JUTCacheFontFP7JKRHeap */
|
/* 802DD804-802DD8EC 2D8144 00E8+00 1/1 0/0 0/0 .text allocArray__12JUTCacheFontFP7JKRHeap */
|
||||||
#pragma push
|
#pragma push
|
||||||
|
@ -399,25 +437,34 @@ asm void JUTCacheFont::invalidiateAllCache() {
|
||||||
|
|
||||||
/* 802DDF68-802DDFAC 2D88A8 0044+00 2/2 0/0 0/0 .text
|
/* 802DDF68-802DDFAC 2D88A8 0044+00 2/2 0/0 0/0 .text
|
||||||
* unlink__12JUTCacheFontFPQ212JUTCacheFont15TGlyphCacheInfo */
|
* unlink__12JUTCacheFontFPQ212JUTCacheFont15TGlyphCacheInfo */
|
||||||
#pragma push
|
void JUTCacheFont::unlink(JUTCacheFont::TGlyphCacheInfo* cacheInfo) {
|
||||||
#pragma optimization_level 0
|
if (cacheInfo->mPrev == NULL) {
|
||||||
#pragma optimizewithasm off
|
field_0x9c = cacheInfo->mNext;
|
||||||
asm void JUTCacheFont::unlink(JUTCacheFont::TGlyphCacheInfo* param_0) {
|
} else {
|
||||||
nofralloc
|
cacheInfo->mPrev->mNext = cacheInfo->mNext;
|
||||||
#include "asm/JSystem/JUtility/JUTCacheFont/unlink__12JUTCacheFontFPQ212JUTCacheFont15TGlyphCacheInfo.s"
|
}
|
||||||
|
|
||||||
|
if (cacheInfo->mNext == NULL) {
|
||||||
|
field_0xa0 = cacheInfo->mPrev;
|
||||||
|
} else {
|
||||||
|
cacheInfo->mNext->mPrev = cacheInfo->mPrev;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#pragma pop
|
|
||||||
|
|
||||||
/* 802DDFAC-802DDFD8 2D88EC 002C+00 2/2 0/0 0/0 .text
|
/* 802DDFAC-802DDFD8 2D88EC 002C+00 2/2 0/0 0/0 .text
|
||||||
* prepend__12JUTCacheFontFPQ212JUTCacheFont15TGlyphCacheInfo */
|
* prepend__12JUTCacheFontFPQ212JUTCacheFont15TGlyphCacheInfo */
|
||||||
#pragma push
|
void JUTCacheFont::prepend(JUTCacheFont::TGlyphCacheInfo* cacheInfo) {
|
||||||
#pragma optimization_level 0
|
TGlyphCacheInfo* oldHead = field_0x9c;
|
||||||
#pragma optimizewithasm off
|
field_0x9c = cacheInfo;
|
||||||
asm void JUTCacheFont::prepend(JUTCacheFont::TGlyphCacheInfo* param_0) {
|
cacheInfo->mPrev = NULL;
|
||||||
nofralloc
|
cacheInfo->mNext = oldHead;
|
||||||
#include "asm/JSystem/JUtility/JUTCacheFont/prepend__12JUTCacheFontFPQ212JUTCacheFont15TGlyphCacheInfo.s"
|
|
||||||
|
if (oldHead == NULL) {
|
||||||
|
field_0xa0 = cacheInfo;
|
||||||
|
} else {
|
||||||
|
oldHead->mPrev = cacheInfo;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#pragma pop
|
|
||||||
|
|
||||||
/* 802DDFD8-802DDFE0 2D8918 0008+00 1/0 1/0 0/0 .text getResFont__10JUTResFontCFv */
|
/* 802DDFD8-802DDFE0 2D8918 0008+00 1/0 1/0 0/0 .text getResFont__10JUTResFontCFv */
|
||||||
#pragma push
|
#pragma push
|
||||||
|
@ -488,5 +535,3 @@ asm s32 JUTResFont::getHeight() const {
|
||||||
#include "asm/JSystem/JUtility/JUTCacheFont/getHeight__10JUTResFontCFv.s"
|
#include "asm/JSystem/JUtility/JUTCacheFont/getHeight__10JUTResFontCFv.s"
|
||||||
}
|
}
|
||||||
#pragma pop
|
#pragma pop
|
||||||
|
|
||||||
/* 8039D2F0-8039D2F0 029950 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */
|
|
||||||
|
|
|
@ -10,7 +10,6 @@
|
||||||
#include "JSystem/JUtility/JUTVideo.h"
|
#include "JSystem/JUtility/JUTVideo.h"
|
||||||
#include "MSL_C/MSL_Common/Src/printf.h"
|
#include "MSL_C/MSL_Common/Src/printf.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
|
@ -315,10 +314,12 @@ void JUTConsole::scroll(int scrollAmnt) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
field_0x30 += scrollAmnt;
|
field_0x30 += scrollAmnt;
|
||||||
if (field_0x30 < 0) {
|
if (field_0x30 < 0) {
|
||||||
field_0x30 += mMaxLines;
|
field_0x30 += mMaxLines;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (field_0x30 >= mMaxLines) {
|
if (field_0x30 >= mMaxLines) {
|
||||||
field_0x30 -= mMaxLines;
|
field_0x30 -= mMaxLines;
|
||||||
}
|
}
|
||||||
|
@ -346,6 +347,7 @@ JUTConsoleManager* JUTConsoleManager::createManager(JKRHeap* pHeap) {
|
||||||
if (pHeap == NULL) {
|
if (pHeap == NULL) {
|
||||||
pHeap = JKRHeap::sCurrentHeap;
|
pHeap = JKRHeap::sCurrentHeap;
|
||||||
}
|
}
|
||||||
|
|
||||||
JUTConsoleManager* manager = new (pHeap, 0) JUTConsoleManager();
|
JUTConsoleManager* manager = new (pHeap, 0) JUTConsoleManager();
|
||||||
sManager = manager;
|
sManager = manager;
|
||||||
return manager;
|
return manager;
|
||||||
|
@ -457,7 +459,8 @@ extern "C" void JUTReportConsole_f_va(const char* fmt, va_list args) {
|
||||||
if (JUTGetReportConsole() == NULL) {
|
if (JUTGetReportConsole() == NULL) {
|
||||||
vsnprintf(buf, sizeof(buf), fmt, args);
|
vsnprintf(buf, sizeof(buf), fmt, args);
|
||||||
} else if (JUTGetReportConsole()->getOutput() &
|
} else if (JUTGetReportConsole()->getOutput() &
|
||||||
(JUTConsole::OUTPUT_CONSOLE | JUTConsole::OUTPUT_OSREPORT)) {
|
(JUTConsole::OUTPUT_CONSOLE | JUTConsole::OUTPUT_OSREPORT))
|
||||||
|
{
|
||||||
vsnprintf(buf, sizeof(buf), fmt, args);
|
vsnprintf(buf, sizeof(buf), fmt, args);
|
||||||
JUTGetReportConsole()->print(buf);
|
JUTGetReportConsole()->print(buf);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,8 +8,6 @@
|
||||||
#include "JSystem/JUtility/JUTVideo.h"
|
#include "JSystem/JUtility/JUTVideo.h"
|
||||||
#include "MSL_C/MSL_Common/Src/printf.h"
|
#include "MSL_C/MSL_Common/Src/printf.h"
|
||||||
#include "MSL_C/MSL_Common/Src/string.h"
|
#include "MSL_C/MSL_Common/Src/string.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
/* 802E0148-802E0190 2DAA88 0048+00 1/1 0/0 0/0 .text __ct__10JUTDbPrintFP7JUTFontP7JKRHeap */
|
/* 802E0148-802E0190 2DAA88 0048+00 1/1 0/0 0/0 .text __ct__10JUTDbPrintFP7JUTFontP7JKRHeap */
|
||||||
JUTDbPrint::JUTDbPrint(JUTFont* pFont, JKRHeap* pHeap) {
|
JUTDbPrint::JUTDbPrint(JUTFont* pFont, JKRHeap* pHeap) {
|
||||||
|
@ -32,6 +30,7 @@ JUTDbPrint* JUTDbPrint::start(JUTFont* pFont, JKRHeap* pHeap) {
|
||||||
}
|
}
|
||||||
sDebugPrint = new JUTDbPrint(pFont, pHeap);
|
sDebugPrint = new JUTDbPrint(pFont, pHeap);
|
||||||
}
|
}
|
||||||
|
|
||||||
return sDebugPrint;
|
return sDebugPrint;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -81,6 +80,7 @@ void JUTDbPrint::flush(int param_0, int param_1, int param_2, int param_3) {
|
||||||
if (mVisible) {
|
if (mVisible) {
|
||||||
this->drawString(cur->unk_0x04, cur->unk_0x06, cur->unk_0x0A, (u8*)cur->unk_0x0C);
|
this->drawString(cur->unk_0x04, cur->unk_0x06, cur->unk_0x0A, (u8*)cur->unk_0x0C);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (--cur->unk_0x08 <= 0) {
|
if (--cur->unk_0x08 <= 0) {
|
||||||
unk_print* next = cur->mNext;
|
unk_print* next = cur->mNext;
|
||||||
JKRFreeToHeap(mHeap, cur);
|
JKRFreeToHeap(mHeap, cur);
|
||||||
|
@ -105,9 +105,11 @@ void JUTDbPrint::drawString(int param_0, int param_1, int param_2, u8 const* par
|
||||||
void JUTReport(int param_0, int param_1, char const* fmt, ...) {
|
void JUTReport(int param_0, int param_1, char const* fmt, ...) {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
|
|
||||||
char buf[0x100];
|
char buf[0x100];
|
||||||
int ret = vsnprintf(buf, 0x100, fmt, args);
|
int ret = vsnprintf(buf, 0x100, fmt, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -118,9 +120,11 @@ void JUTReport(int param_0, int param_1, char const* fmt, ...) {
|
||||||
void JUTReport(int param_0, int param_1, int param_2, char const* fmt, ...) {
|
void JUTReport(int param_0, int param_1, int param_2, char const* fmt, ...) {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
|
|
||||||
char buf[0x100];
|
char buf[0x100];
|
||||||
int ret = vsnprintf(buf, 0x100, fmt, args);
|
int ret = vsnprintf(buf, 0x100, fmt, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
#include "Runtime.PPCEABI.H/__va_arg.h"
|
#include "Runtime.PPCEABI.H/__va_arg.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/os/OSCache.h"
|
#include "dolphin/os/OSCache.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -5,13 +5,12 @@
|
||||||
|
|
||||||
#include "JSystem/JUtility/JUTException.h"
|
#include "JSystem/JUtility/JUTException.h"
|
||||||
#include "JSystem/JUtility/JUTConsole.h"
|
#include "JSystem/JUtility/JUTConsole.h"
|
||||||
#include "JSystem/JUtility/JUTDirectPrint.h"
|
|
||||||
#include "JSystem/JUtility/JUTDirectFile.h"
|
#include "JSystem/JUtility/JUTDirectFile.h"
|
||||||
|
#include "JSystem/JUtility/JUTDirectPrint.h"
|
||||||
#include "MSL_C/MSL_Common/Src/float.h"
|
#include "MSL_C/MSL_Common/Src/float.h"
|
||||||
#include "MSL_C/MSL_Common/Src/printf.h"
|
#include "MSL_C/MSL_Common/Src/printf.h"
|
||||||
#include "Runtime.PPCEABI.H/__va_arg.h"
|
#include "Runtime.PPCEABI.H/__va_arg.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
|
@ -110,7 +109,7 @@ OSErrorHandler JUTException::sPostUserCallback;
|
||||||
|
|
||||||
/* 802E1D5C-802E1E40 2DC69C 00E4+00 1/1 0/0 0/0 .text __ct__12JUTExceptionFP14JUTDirectPrint */
|
/* 802E1D5C-802E1E40 2DC69C 00E4+00 1/1 0/0 0/0 .text __ct__12JUTExceptionFP14JUTDirectPrint */
|
||||||
JUTException::JUTException(JUTDirectPrint* directPrint)
|
JUTException::JUTException(JUTDirectPrint* directPrint)
|
||||||
: JKRThread(0x1C00 /* 0x4000 in DEBUG */, 0x10, 0), mDirectPrint(directPrint) {
|
: JKRThread(0x1C00, 0x10, 0), mDirectPrint(directPrint) {
|
||||||
OSSetErrorHandler(EXCEPTION_DSI, errorHandler);
|
OSSetErrorHandler(EXCEPTION_DSI, errorHandler);
|
||||||
OSSetErrorHandler(EXCEPTION_ISI, errorHandler);
|
OSSetErrorHandler(EXCEPTION_ISI, errorHandler);
|
||||||
OSSetErrorHandler(EXCEPTION_PROGRAM, errorHandler);
|
OSSetErrorHandler(EXCEPTION_PROGRAM, errorHandler);
|
||||||
|
@ -945,13 +944,15 @@ bool JUTException::queryMapAddress(char* mapPath, u32 address, s32 section_id, u
|
||||||
strcpy(buffer, mapPath);
|
strcpy(buffer, mapPath);
|
||||||
strcat(buffer, ".map");
|
strcat(buffer, ".map");
|
||||||
if (queryMapAddress_single(buffer, address, section_id, out_addr, out_size, out_line,
|
if (queryMapAddress_single(buffer, address, section_id, out_addr, out_size, out_line,
|
||||||
line_length, print, begin_with_newline) == true) {
|
line_length, print, begin_with_newline) == true)
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} else if (sMapFileList.getFirst() != sMapFileList.getEnd()) {
|
} else if (sMapFileList.getFirst() != sMapFileList.getEnd()) {
|
||||||
if (queryMapAddress_single(sMapFileList.getFirst()->getObject()->mPath, address, -1,
|
if (queryMapAddress_single(sMapFileList.getFirst()->getObject()->mPath, address, -1,
|
||||||
out_addr, out_size, out_line, line_length, print,
|
out_addr, out_size, out_line, line_length, print,
|
||||||
begin_with_newline) == true) {
|
begin_with_newline) == true)
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1147,5 +1148,3 @@ JUTException::~JUTException() {}
|
||||||
*/
|
*/
|
||||||
/* 804508F8-80450900 000378 0008+00 0/0 3/3 0/0 .sdata None */
|
/* 804508F8-80450900 000378 0008+00 0/0 3/3 0/0 .sdata None */
|
||||||
SECTION_SDATA extern bool sAssertVisible = true;
|
SECTION_SDATA extern bool sAssertVisible = true;
|
||||||
|
|
||||||
/* 8039D490-8039D490 029AF0 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */
|
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
|
|
||||||
#include "JSystem/JUtility/JUTFontData_Ascfont_fix12.h"
|
#include "JSystem/JUtility/JUTFontData_Ascfont_fix12.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
|
|
|
@ -377,7 +377,8 @@ void JUTGamePad::update() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (field_0xa8 == 0 ||
|
if (field_0xa8 == 0 ||
|
||||||
(mButton.mButton & C3ButtonReset::sResetMaskPattern) != C3ButtonReset::sResetPattern) {
|
(mButton.mButton & C3ButtonReset::sResetMaskPattern) != C3ButtonReset::sResetPattern)
|
||||||
|
{
|
||||||
mButtonReset.mReset = false;
|
mButtonReset.mReset = false;
|
||||||
} else if (!JUTGamePad::C3ButtonReset::sResetOccurred) {
|
} else if (!JUTGamePad::C3ButtonReset::sResetOccurred) {
|
||||||
if (mButtonReset.mReset == true) {
|
if (mButtonReset.mReset == true) {
|
||||||
|
@ -488,7 +489,8 @@ void JUTGamePad::CButton::update(PADStatus const* padStatus, u32 stickStatus) {
|
||||||
field_0x1c++;
|
field_0x1c++;
|
||||||
|
|
||||||
if (field_0x1c == field_0x28 ||
|
if (field_0x1c == field_0x28 ||
|
||||||
(field_0x1c > field_0x28 && (field_0x1c - field_0x28) % field_0x2c == 0)) {
|
(field_0x1c > field_0x28 && (field_0x1c - field_0x28) % field_0x2c == 0))
|
||||||
|
{
|
||||||
mRepeat = repeatButton;
|
mRepeat = repeatButton;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -5,12 +5,6 @@
|
||||||
|
|
||||||
#include "JSystem/JUtility/JUTGraphFifo.h"
|
#include "JSystem/JUtility/JUTGraphFifo.h"
|
||||||
#include "JSystem/JKernel/JKRHeap.h"
|
#include "JSystem/JKernel/JKRHeap.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
|
||||||
// Declarations:
|
|
||||||
//
|
|
||||||
|
|
||||||
/* 804514B8-804514BC 0009B8 0004+00 1/1 0/0 0/0 .sbss None */
|
/* 804514B8-804514BC 0009B8 0004+00 1/1 0/0 0/0 .sbss None */
|
||||||
static bool data_804514B8;
|
static bool data_804514B8;
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
|
|
||||||
#include "JSystem/JUtility/JUTNameTab.h"
|
#include "JSystem/JUtility/JUTNameTab.h"
|
||||||
#include "MSL_C/MSL_Common/Src/string.h"
|
#include "MSL_C/MSL_Common/Src/string.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
JUTNameTab::JUTNameTab() {
|
JUTNameTab::JUTNameTab() {
|
||||||
setResource(NULL);
|
setResource(NULL);
|
||||||
|
|
|
@ -224,30 +224,32 @@ SECTION_SDATA2 static f64 lit_2315 = 4503599627370496.0 /* cast u32 to float */;
|
||||||
#ifdef NONMATCHING // float literals
|
#ifdef NONMATCHING // float literals
|
||||||
void JUTProcBar::adjustMeterLength(u32 param_0, f32* param_1, f32 param_2, f32 param_3,
|
void JUTProcBar::adjustMeterLength(u32 param_0, f32* param_1, f32 param_2, f32 param_3,
|
||||||
int* param_4) {
|
int* param_4) {
|
||||||
BOOL var2 = false;
|
BOOL var2 = false;
|
||||||
float var1 = *param_1;
|
float var1 = *param_1;
|
||||||
while (var1 > param_2) {
|
while (var1 > param_2) {
|
||||||
if (param_0 * var1 * FLOAT_LABEL(lit_2308) / FLOAT_LABEL(lit_2309) <= field_0x114.mWidth - FLOAT_LABEL(lit_2310))
|
if (param_0 * var1 * FLOAT_LABEL(lit_2308) / FLOAT_LABEL(lit_2309) <=
|
||||||
break;
|
field_0x114.mWidth - FLOAT_LABEL(lit_2310))
|
||||||
|
break;
|
||||||
|
|
||||||
var1 -= FLOAT_LABEL(lit_2311);
|
var1 -= FLOAT_LABEL(lit_2311);
|
||||||
var2 = true;
|
var2 = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (var1 >= param_3)
|
if (var1 >= param_3)
|
||||||
*param_4 = 0;
|
*param_4 = 0;
|
||||||
if (var1 > param_3 - FLOAT_LABEL(lit_2312))
|
if (var1 > param_3 - FLOAT_LABEL(lit_2312))
|
||||||
var1 = param_3;
|
var1 = param_3;
|
||||||
|
|
||||||
while (!var2 && var1 < param_3) {
|
while (!var2 && var1 < param_3) {
|
||||||
(*param_4)++;
|
(*param_4)++;
|
||||||
if (*param_4 < 0x1e)
|
if (*param_4 < 0x1e)
|
||||||
break;
|
break;
|
||||||
if ((param_0 * var1 * FLOAT_LABEL(lit_2308) / FLOAT_LABEL(lit_2309)) < (field_0x114.mWidth - FLOAT_LABEL(lit_2313)))
|
if ((param_0 * var1 * FLOAT_LABEL(lit_2308) / FLOAT_LABEL(lit_2309)) <
|
||||||
var1 += FLOAT_LABEL(lit_2312);
|
(field_0x114.mWidth - FLOAT_LABEL(lit_2313)))
|
||||||
break;
|
var1 += FLOAT_LABEL(lit_2312);
|
||||||
}
|
break;
|
||||||
*param_1 = var1;
|
}
|
||||||
|
*param_1 = var1;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#pragma push
|
#pragma push
|
||||||
|
@ -294,7 +296,8 @@ void JUTProcBar::drawProcessBar() {
|
||||||
}
|
}
|
||||||
int r29 = 16666;
|
int r29 = 16666;
|
||||||
if (JUTGetVideoManager() &&
|
if (JUTGetVideoManager() &&
|
||||||
((JUTGetVideoManager()->getRenderMode()->vi_tv_mode >> 2) & 0x0f) == 1) {
|
((JUTGetVideoManager()->getRenderMode()->vi_tv_mode >> 2) & 0x0f) == 1)
|
||||||
|
{
|
||||||
r29 = 20000;
|
r29 = 20000;
|
||||||
}
|
}
|
||||||
static int cnt = 0;
|
static int cnt = 0;
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "JSystem/JUtility/JUTResFont.h"
|
#include "JSystem/JUtility/JUTResFont.h"
|
||||||
|
#include "JSystem/JUtility/JUTConsole.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
#include "dolphin/gx/GX.h"
|
#include "dolphin/gx/GX.h"
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -54,7 +54,6 @@ extern "C" void getDescent__10JUTResFontCFv();
|
||||||
extern "C" void getHeight__10JUTResFontCFv();
|
extern "C" void getHeight__10JUTResFontCFv();
|
||||||
extern "C" void __ct__7JUTFontFv();
|
extern "C" void __ct__7JUTFontFv();
|
||||||
extern "C" void initialize_state__7JUTFontFv();
|
extern "C" void initialize_state__7JUTFontFv();
|
||||||
extern "C" void JUTReportConsole();
|
|
||||||
extern "C" void GXClearVtxDesc();
|
extern "C" void GXClearVtxDesc();
|
||||||
extern "C" void _savegpr_25();
|
extern "C" void _savegpr_25();
|
||||||
extern "C" void _savegpr_27();
|
extern "C" void _savegpr_27();
|
||||||
|
@ -158,7 +157,6 @@ bool JUTResFont::protected_initiate(ResFONT const* param_0, JKRHeap* param_1) {
|
||||||
|
|
||||||
if (!param_0) {
|
if (!param_0) {
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
}
|
}
|
||||||
mResFont = param_0;
|
mResFont = param_0;
|
||||||
mValid = true;
|
mValid = true;
|
||||||
|
@ -186,59 +184,40 @@ bool JUTResFont::protected_initiate(ResFONT const* param_0, JKRHeap* param_1) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ############################################################################################## */
|
|
||||||
/* 8039D45C-8039D45C 029ABC 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */
|
|
||||||
#pragma push
|
|
||||||
#pragma force_active on
|
|
||||||
SECTION_DEAD static char const* const stringBase_8039D45C = "JUTResFont: Unknown data block\n";
|
|
||||||
#pragma pop
|
|
||||||
|
|
||||||
/* 802DF248-802DF344 2D9B88 00FC+00 1/1 0/0 0/0 .text countBlock__10JUTResFontFv */
|
/* 802DF248-802DF344 2D9B88 00FC+00 1/1 0/0 0/0 .text countBlock__10JUTResFontFv */
|
||||||
#ifdef NONMATCHING
|
|
||||||
void JUTResFont::countBlock() {
|
void JUTResFont::countBlock() {
|
||||||
mWidthBlockCount = 0;
|
mWid1BlockNum = 0;
|
||||||
mGlyphBlockCount = 0;
|
mGly1BlockNum = 0;
|
||||||
mMapBlockCount = 0;
|
mMap1BlockNum = 0;
|
||||||
u8* pData = (u8*)&mResource->mData;
|
|
||||||
for (u32 i = 0; i < mResource->mChunkNum; i++, pData += ((BlockHeader*)pData)->mSize) {
|
u8* pData = (u8*)&mResFont->data;
|
||||||
int magic = ((BlockHeader*)pData)->mMagic;
|
for (u32 i = 0; i < mResFont->numBlocks; i++, pData += ((BlockHeader*)pData)->size) {
|
||||||
switch (magic) {
|
int magic = ((BlockHeader*)pData)->magic;
|
||||||
case 'WID1':
|
switch (magic) {
|
||||||
mWidthBlockCount++;
|
case 'WID1':
|
||||||
break;
|
mWid1BlockNum++;
|
||||||
case 'GLY1':
|
break;
|
||||||
mGlyphBlockCount++;
|
case 'GLY1':
|
||||||
break;
|
mGly1BlockNum++;
|
||||||
case 'MAP1':
|
break;
|
||||||
mMapBlockCount++;
|
case 'MAP1':
|
||||||
break;
|
mMap1BlockNum++;
|
||||||
case 'INF1':
|
break;
|
||||||
// mInf1Ptr;
|
case 'INF1':
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
JUTReportConsole("JUTResFont: Unknown data block\n");
|
JUTReportConsole("JUTResFont: Unknown data block\n");
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
#pragma push
|
|
||||||
#pragma optimization_level 0
|
|
||||||
#pragma optimizewithasm off
|
|
||||||
asm void JUTResFont::countBlock() {
|
|
||||||
nofralloc
|
|
||||||
#include "asm/JSystem/JUtility/JUTResFont/countBlock__10JUTResFontFv.s"
|
|
||||||
}
|
|
||||||
#pragma pop
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ############################################################################################## */
|
/* ############################################################################################## */
|
||||||
/* 8039D390-8039D39C -00001 000C+00 1/1 1/1 0/0 .rodata saoAboutEncoding___10JUTResFont */
|
/* 8039D390-8039D39C -00001 000C+00 1/1 1/1 0/0 .rodata saoAboutEncoding___10JUTResFont */
|
||||||
SECTION_RODATA void* const JUTResFont::saoAboutEncoding_[3] = {
|
IsLeadByte_func const JUTResFont::saoAboutEncoding_[3] = {
|
||||||
(void*)isLeadByte_1Byte__7JUTFontFi,
|
JUTFont::isLeadByte_1Byte,
|
||||||
(void*)isLeadByte_2Byte__7JUTFontFi,
|
JUTFont::isLeadByte_2Byte,
|
||||||
(void*)isLeadByte_ShiftJIS__7JUTFontFi,
|
JUTFont::isLeadByte_ShiftJIS,
|
||||||
};
|
};
|
||||||
COMPILER_STRIP_GATE(0x8039D390, &JUTResFont::saoAboutEncoding_);
|
|
||||||
|
|
||||||
/* 8039D45C-8039D45C 029ABC 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */
|
/* 8039D45C-8039D45C 029ABC 0000+00 0/0 0/0 0/0 .rodata @stringBase0 */
|
||||||
#pragma push
|
#pragma push
|
||||||
|
@ -328,70 +307,70 @@ SECTION_SDATA2 static f64 lit_651 = 4503599627370496.0 /* cast u32 to float */;
|
||||||
#ifdef NONMATCHING
|
#ifdef NONMATCHING
|
||||||
// still missing a bunch of stuff
|
// still missing a bunch of stuff
|
||||||
f32 JUTResFont::drawChar_scale(f32 pos_x, f32 pos_y, f32 scale_x, f32 scale_y, int str_int,
|
f32 JUTResFont::drawChar_scale(f32 pos_x, f32 pos_y, f32 scale_x, f32 scale_y, int str_int,
|
||||||
bool flag) {
|
bool flag) {
|
||||||
JUTFont::TWidth width;
|
JUTFont::TWidth width;
|
||||||
f32 width_val;
|
f32 width_val;
|
||||||
f32 pos_height, ascent, ascent_val, scaled_height;
|
f32 pos_height, ascent, ascent_val, scaled_height;
|
||||||
f32 sca_wid;
|
f32 sca_wid;
|
||||||
|
|
||||||
loadFont(str_int, GX_TEXMAP0, &width);
|
loadFont(str_int, GX_TEXMAP0, &width);
|
||||||
|
|
||||||
if ((mFixed) || (!flag)) {
|
if ((mFixed) || (!flag)) {
|
||||||
width_val = pos_x;
|
width_val = pos_x;
|
||||||
} else {
|
} else {
|
||||||
width_val = (pos_x - width.field_0x0 * (scale_x / getCellWidth()));
|
width_val = (pos_x - width.field_0x0 * (scale_x / getCellWidth()));
|
||||||
}
|
}
|
||||||
f32 retval = mFixedWidth * (scale_x / getCellWidth());
|
f32 retval = mFixedWidth * (scale_x / getCellWidth());
|
||||||
if (mFixed == false) {
|
if (mFixed == false) {
|
||||||
if (!flag) {
|
if (!flag) {
|
||||||
retval = (width.field_0x1 + width.field_0x0) * (scale_x / getCellWidth());
|
retval = (width.field_0x1 + width.field_0x0) * (scale_x / getCellWidth());
|
||||||
} else {
|
} else {
|
||||||
retval = width.field_0x1 * (scale_x / getCellWidth());
|
retval = width.field_0x1 * (scale_x / getCellWidth());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sca_wid = width_val + scale_x;
|
sca_wid = width_val + scale_x;
|
||||||
ascent_val = pos_y - getAscent() * (scale_y / getHeight());
|
ascent_val = pos_y - getAscent() * (scale_y / getHeight());
|
||||||
scaled_height = scale_y / getHeight();
|
scaled_height = scale_y / getHeight();
|
||||||
f32 descent = getDescent();
|
f32 descent = getDescent();
|
||||||
f32 ascent_calc = descent * ascent_val;
|
f32 ascent_calc = descent * ascent_val;
|
||||||
f32 deshei = descent * scaled_height + pos_y;
|
f32 deshei = descent * scaled_height + pos_y;
|
||||||
|
|
||||||
ResFONT::GLY1* used_glyphs = mpGlyphBlocks[field_0x66];
|
ResFONT::GLY1* used_glyphs = mpGlyphBlocks[field_0x66];
|
||||||
u16 tex_width = used_glyphs->textureWidth;
|
u16 tex_width = used_glyphs->textureWidth;
|
||||||
u16 tex_height = used_glyphs->textureHeight;
|
u16 tex_height = used_glyphs->textureHeight;
|
||||||
int t_width = mWidth;
|
int t_width = mWidth;
|
||||||
int t_height = mHeight;
|
int t_height = mHeight;
|
||||||
int shift_width = (t_width + used_glyphs->cellHeight) << 15;
|
int shift_width = (t_width + used_glyphs->cellHeight) << 15;
|
||||||
int div_width = (t_width << 15) / tex_width;
|
int div_width = (t_width << 15) / tex_width;
|
||||||
int div_height = (t_height << 15) / tex_height;
|
int div_height = (t_height << 15) / tex_height;
|
||||||
u16 sumWidth = t_width + used_glyphs->cellWidth;
|
u16 sumWidth = t_width + used_glyphs->cellWidth;
|
||||||
int shift_height = t_height + used_glyphs->cellHeight << 15;
|
int shift_height = t_height + used_glyphs->cellHeight << 15;
|
||||||
u16 sumHeight = t_height + used_glyphs->cellHeight;
|
u16 sumHeight = t_height + used_glyphs->cellHeight;
|
||||||
s32 width_ratio = shift_width / tex_width;
|
s32 width_ratio = shift_width / tex_width;
|
||||||
s32 height_ratio = shift_height / tex_height;
|
s32 height_ratio = shift_height / tex_height;
|
||||||
|
|
||||||
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0);
|
||||||
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
GXBegin(GX_QUADS, GX_VTXFMT0, 4);
|
||||||
|
|
||||||
GXPosition3f32(width_val,ascent_val,0.0f);
|
GXPosition3f32(width_val, ascent_val, 0.0f);
|
||||||
GXColor1u32(mColor1);
|
GXColor1u32(mColor1);
|
||||||
i_GXTexCoord2u16(div_width,div_height);
|
i_GXTexCoord2u16(div_width, div_height);
|
||||||
|
|
||||||
GXPosition3f32(sca_wid,ascent_val,0.0f);
|
GXPosition3f32(sca_wid, ascent_val, 0.0f);
|
||||||
GXColor1u32(mColor2);
|
GXColor1u32(mColor2);
|
||||||
i_GXTexCoord2u16(width_ratio,div_height);
|
i_GXTexCoord2u16(width_ratio, div_height);
|
||||||
|
|
||||||
GXPosition3f32(sca_wid,deshei,0.0f);
|
GXPosition3f32(sca_wid, deshei, 0.0f);
|
||||||
GXColor1u32(mColor4);
|
GXColor1u32(mColor4);
|
||||||
i_GXTexCoord2u16(width_ratio,height_ratio);
|
i_GXTexCoord2u16(width_ratio, height_ratio);
|
||||||
|
|
||||||
GXPosition3f32(width_val,deshei,0.0f);
|
GXPosition3f32(width_val, deshei, 0.0f);
|
||||||
GXColor1u32(mColor3);
|
GXColor1u32(mColor3);
|
||||||
i_GXTexCoord2u16(div_width,height_ratio);
|
i_GXTexCoord2u16(div_width, height_ratio);
|
||||||
|
|
||||||
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_S16, 0);
|
GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_S16, 0);
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#pragma push
|
#pragma push
|
||||||
|
@ -425,10 +404,10 @@ void JUTResFont::getWidthEntry(int param_0, JUTFont::TWidth* i_width) const {
|
||||||
|
|
||||||
for (int i = 0; i < mWid1BlockNum; i++) {
|
for (int i = 0; i < mWid1BlockNum; i++) {
|
||||||
if (mpWidthBlocks[i]->startCode <= code && code <= mpWidthBlocks[i]->endCode) {
|
if (mpWidthBlocks[i]->startCode <= code && code <= mpWidthBlocks[i]->endCode) {
|
||||||
u8* ptr = &mpWidthBlocks[i]->mChunkNum[(code - mpWidthBlocks[i]->startCode) * 2];
|
u8* ptr = &mpWidthBlocks[i]->mChunkNum[(code - mpWidthBlocks[i]->startCode) * 2];
|
||||||
i_width->field_0x0 = ptr[0];
|
i_width->field_0x0 = ptr[0];
|
||||||
i_width->field_0x1 = ptr[1];
|
i_width->field_0x1 = ptr[1];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -443,7 +422,6 @@ int JUTResFont::getCellWidth() const {
|
||||||
if (glyphBlock) {
|
if (glyphBlock) {
|
||||||
return glyphBlock->cellWidth;
|
return glyphBlock->cellWidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return getWidth();
|
return getWidth();
|
||||||
|
@ -460,7 +438,6 @@ int JUTResFont::getCellHeight() const {
|
||||||
if (glyphBlock) {
|
if (glyphBlock) {
|
||||||
return glyphBlock->cellHeight;
|
return glyphBlock->cellHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return getHeight();
|
return getHeight();
|
||||||
|
@ -476,8 +453,6 @@ asm u16 JUTResFont::getCellHeight() const {
|
||||||
#pragma pop
|
#pragma pop
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* 802DFDA4-802DFDD8 2DA6E4 0034+00 1/0 1/0 0/0 .text isLeadByte__10JUTResFontCFi */
|
/* 802DFDA4-802DFDD8 2DA6E4 0034+00 1/0 1/0 0/0 .text isLeadByte__10JUTResFontCFi */
|
||||||
bool JUTResFont::isLeadByte(int param_0) const {
|
bool JUTResFont::isLeadByte(int param_0) const {
|
||||||
return (*mIsLeadByte)(param_0);
|
return (*mIsLeadByte)(param_0);
|
||||||
|
@ -486,22 +461,14 @@ bool JUTResFont::isLeadByte(int param_0) const {
|
||||||
/* ############################################################################################## */
|
/* ############################################################################################## */
|
||||||
/* 8039D39C-8039D45C 0299FC 00BE+02 1/1 0/0 0/0 .rodata halftofull$726 */
|
/* 8039D39C-8039D45C 0299FC 00BE+02 1/1 0/0 0/0 .rodata halftofull$726 */
|
||||||
static const u16 halftofull[95] = {
|
static const u16 halftofull[95] = {
|
||||||
0x8140, 0x8149, 0x8168, 0x8194, 0x8190, 0x8193,
|
0x8140, 0x8149, 0x8168, 0x8194, 0x8190, 0x8193, 0x8195, 0x8166, 0x8169, 0x816A, 0x8196, 0x817B,
|
||||||
0x8195, 0x8166, 0x8169, 0x816A, 0x8196, 0x817B,
|
0x8143, 0x817C, 0x8144, 0x815E, 0x824F, 0x8250, 0x8251, 0x8252, 0x8253, 0x8254, 0x8255, 0x8256,
|
||||||
0x8143, 0x817C, 0x8144, 0x815E, 0x824F, 0x8250,
|
0x8257, 0x8258, 0x8146, 0x8147, 0x8183, 0x8181, 0x8184, 0x8148, 0x8197, 0x8260, 0x8261, 0x8262,
|
||||||
0x8251, 0x8252, 0x8253, 0x8254, 0x8255, 0x8256,
|
0x8263, 0x8264, 0x8265, 0x8266, 0x8267, 0x8268, 0x8269, 0x826A, 0x826B, 0x826C, 0x826D, 0x826E,
|
||||||
0x8257, 0x8258, 0x8146, 0x8147, 0x8183, 0x8181,
|
0x826F, 0x8270, 0x8271, 0x8272, 0x8273, 0x8274, 0x8275, 0x8276, 0x8277, 0x8278, 0x8279, 0x816D,
|
||||||
0x8184, 0x8148, 0x8197, 0x8260, 0x8261, 0x8262,
|
0x818F, 0x816E, 0x814F, 0x8151, 0x8165, 0x8281, 0x8282, 0x8283, 0x8284, 0x8285, 0x8286, 0x8287,
|
||||||
0x8263, 0x8264, 0x8265, 0x8266, 0x8267, 0x8268,
|
0x8288, 0x8289, 0x828A, 0x828B, 0x828C, 0x828D, 0x828E, 0x828F, 0x8290, 0x8291, 0x8292, 0x8293,
|
||||||
0x8269, 0x826A, 0x826B, 0x826C, 0x826D, 0x826E,
|
0x8294, 0x8295, 0x8296, 0x8297, 0x8298, 0x8299, 0x829A, 0x816F, 0x8162, 0x8170, 0x8160,
|
||||||
0x826F, 0x8270, 0x8271, 0x8272, 0x8273, 0x8274,
|
|
||||||
0x8275, 0x8276, 0x8277, 0x8278, 0x8279, 0x816D,
|
|
||||||
0x818F, 0x816E, 0x814F, 0x8151, 0x8165, 0x8281,
|
|
||||||
0x8282, 0x8283, 0x8284, 0x8285, 0x8286, 0x8287,
|
|
||||||
0x8288, 0x8289, 0x828A, 0x828B, 0x828C, 0x828D,
|
|
||||||
0x828E, 0x828F, 0x8290, 0x8291, 0x8292, 0x8293,
|
|
||||||
0x8294, 0x8295, 0x8296, 0x8297, 0x8298, 0x8299,
|
|
||||||
0x829A, 0x816F, 0x8162, 0x8170, 0x8160,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/* 802DFDD8-802DFF60 2DA718 0188+00 2/2 0/0 0/0 .text getFontCode__10JUTResFontCFi */
|
/* 802DFDD8-802DFF60 2DA718 0188+00 2/2 0/0 0/0 .text getFontCode__10JUTResFontCFi */
|
||||||
|
@ -509,54 +476,53 @@ static const u16 halftofull[95] = {
|
||||||
// still many issues
|
// still many issues
|
||||||
int JUTResFont::getFontCode(int param_0) const {
|
int JUTResFont::getFontCode(int param_0) const {
|
||||||
int ret = mInf1Ptr->width;
|
int ret = mInf1Ptr->width;
|
||||||
if ((getFontType() == 2) && (mMaxCode >= 0x8000U) && (param_0 >= 0x20) && (param_0 < 0x7FU)) {
|
if ((getFontType() == 2) && (mMaxCode >= 0x8000U) && (param_0 >= 0x20) && (param_0 < 0x7FU)) {
|
||||||
param_0 = halftofull[param_0 - 32];
|
param_0 = halftofull[param_0 - 32];
|
||||||
}
|
}
|
||||||
int j = 0;
|
int j = 0;
|
||||||
for (int i = mMap1BlockNum; i > 0; j++, i--) {
|
for (int i = mMap1BlockNum; i > 0; j++, i--) {
|
||||||
if ((mpMapBlocks[j]->endCode <= param_0) && (param_0 <= mpMapBlocks[j]->numEntries)) {
|
if ((mpMapBlocks[j]->endCode <= param_0) && (param_0 <= mpMapBlocks[j]->numEntries)) {
|
||||||
ResFONT::MAP1* temp_r4 = mpMapBlocks[j];
|
ResFONT::MAP1* temp_r4 = mpMapBlocks[j];
|
||||||
if (temp_r4->startCode == 0) {
|
if (temp_r4->startCode == 0) {
|
||||||
ret = param_0 - temp_r4->endCode;
|
ret = param_0 - temp_r4->endCode;
|
||||||
break;
|
break;
|
||||||
} else if (temp_r4->startCode == 2) {
|
} else if (temp_r4->startCode == 2) {
|
||||||
ret = *(&mpMapBlocks[j]->mLeading + ((param_0 - mpMapBlocks[j]->endCode)));
|
ret = *(&mpMapBlocks[j]->mLeading + ((param_0 - mpMapBlocks[j]->endCode)));
|
||||||
break;
|
break;
|
||||||
} else if (temp_r4->startCode == 3) {
|
} else if (temp_r4->startCode == 3) {
|
||||||
u16* leading_temp = &temp_r4->mLeading;
|
u16* leading_temp = &temp_r4->mLeading;
|
||||||
int phi_r5 = 0;
|
int phi_r5 = 0;
|
||||||
int phi_r6_2 = temp_r4->numEntries - 1;
|
int phi_r6_2 = temp_r4->numEntries - 1;
|
||||||
|
|
||||||
while (phi_r6_2 >= phi_r5) {
|
while (phi_r6_2 >= phi_r5) {
|
||||||
|
u32 temp_r3 = phi_r6_2 + phi_r5;
|
||||||
|
int temp_r7 = (int)((temp_r3 >> 0x1FU) + phi_r6_2 + phi_r5) >> 1;
|
||||||
|
|
||||||
u32 temp_r3 = phi_r6_2 + phi_r5;
|
if (param_0 < leading_temp[temp_r7 * 2]) {
|
||||||
int temp_r7 = (int)((temp_r3 >> 0x1FU) + phi_r6_2 + phi_r5) >> 1;
|
phi_r6_2 = temp_r7 - 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (param_0 < leading_temp[temp_r7 * 2]) {
|
if (param_0 > leading_temp[temp_r7 * 2]) {
|
||||||
phi_r6_2 = temp_r7 - 1;
|
phi_r5 = temp_r7 + 1;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (param_0 > leading_temp[temp_r7 * 2]) {
|
ret = leading_temp[temp_r7 * 2 + 1];
|
||||||
phi_r5 = temp_r7 + 1;
|
break;
|
||||||
continue;
|
}
|
||||||
}
|
} else if (temp_r4->startCode == 1) {
|
||||||
|
u16* phi_r5_2 = NULL;
|
||||||
ret = leading_temp[temp_r7 * 2 + 1];
|
if (temp_r4->numEntries == 1) {
|
||||||
break;
|
phi_r5_2 = &temp_r4->mLeading;
|
||||||
}
|
}
|
||||||
} else if (temp_r4->startCode == 1) {
|
ret = convertSjis(param_0, phi_r5_2);
|
||||||
u16* phi_r5_2 = NULL;
|
break;
|
||||||
if (temp_r4->numEntries == 1) {
|
}
|
||||||
phi_r5_2 = &temp_r4->mLeading;
|
break;
|
||||||
}
|
}
|
||||||
ret = convertSjis(param_0, phi_r5_2);
|
}
|
||||||
break;
|
return ret;
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#pragma push
|
#pragma push
|
||||||
|
@ -571,9 +537,7 @@ asm int JUTResFont::getFontCode(int param_0) const {
|
||||||
|
|
||||||
/* 802DFF60-802E00C4 2DA8A0 0164+00 1/0 0/0 0/0 .text loadImage__10JUTResFontFi11_GXTexMapID */
|
/* 802DFF60-802E00C4 2DA8A0 0164+00 1/0 0/0 0/0 .text loadImage__10JUTResFontFi11_GXTexMapID */
|
||||||
#ifdef NONMATCHING
|
#ifdef NONMATCHING
|
||||||
asm void JUTResFont::loadImage(int param_0, _GXTexMapID param_1) {
|
asm void JUTResFont::loadImage(int param_0, _GXTexMapID param_1) {}
|
||||||
|
|
||||||
}
|
|
||||||
#else
|
#else
|
||||||
#pragma push
|
#pragma push
|
||||||
#pragma optimization_level 0
|
#pragma optimization_level 0
|
||||||
|
@ -590,17 +554,17 @@ int JUTResFont::convertSjis(int inChr, u16* inLead) const {
|
||||||
int tmp = inChr >> 8 & 0xFF;
|
int tmp = inChr >> 8 & 0xFF;
|
||||||
int tmp2 = (u8)inChr - 0x40;
|
int tmp2 = (u8)inChr - 0x40;
|
||||||
|
|
||||||
if (0x40 <= tmp2) {
|
if (0x40 <= tmp2) {
|
||||||
tmp2--;
|
tmp2--;
|
||||||
}
|
}
|
||||||
|
|
||||||
u16 lead = 0x31c;
|
u16 lead = 0x31c;
|
||||||
|
|
||||||
if (inLead) {
|
if (inLead) {
|
||||||
lead = *inLead;
|
lead = *inLead;
|
||||||
}
|
}
|
||||||
|
|
||||||
return tmp2 + (tmp - 0x88) * 0xbc + -0x5e + lead;
|
return tmp2 + (tmp - 0x88) * 0xbc + -0x5e + lead;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802E0108-802E0110 2DAA48 0008+00 1/0 0/0 0/0 .text isLeadByte_1Byte__7JUTFontFi */
|
/* 802E0108-802E0110 2DAA48 0008+00 1/0 0/0 0/0 .text isLeadByte_1Byte__7JUTFontFi */
|
||||||
|
|
|
@ -6,20 +6,8 @@
|
||||||
#include "JSystem/JUtility/JUTVideo.h"
|
#include "JSystem/JUtility/JUTVideo.h"
|
||||||
#include "JSystem/JUtility/JUTDirectPrint.h"
|
#include "JSystem/JUtility/JUTDirectPrint.h"
|
||||||
#include "JSystem/JUtility/JUTXfb.h"
|
#include "JSystem/JUtility/JUTXfb.h"
|
||||||
#include "dol2asm.h"
|
|
||||||
#include "dolphin/types.h"
|
|
||||||
#include "dolphin/vi/vi.h"
|
#include "dolphin/vi/vi.h"
|
||||||
|
|
||||||
//
|
|
||||||
// External References:
|
|
||||||
//
|
|
||||||
|
|
||||||
extern "C" void GXSetDrawDone();
|
|
||||||
|
|
||||||
//
|
|
||||||
// Declarations:
|
|
||||||
//
|
|
||||||
|
|
||||||
/* 80451538-8045153C 000A38 0004+00 4/4 18/18 1/1 .sbss sManager__8JUTVideo */
|
/* 80451538-8045153C 000A38 0004+00 4/4 18/18 1/1 .sbss sManager__8JUTVideo */
|
||||||
JUTVideo* JUTVideo::sManager;
|
JUTVideo* JUTVideo::sManager;
|
||||||
|
|
||||||
|
@ -32,12 +20,6 @@ OSTick JUTVideo::sVideoInterval;
|
||||||
/* 80451544-80451548 000A44 0004+00 4/4 0/0 0/0 .sbss None */
|
/* 80451544-80451548 000A44 0004+00 4/4 0/0 0/0 .sbss None */
|
||||||
static bool data_80451544;
|
static bool data_80451544;
|
||||||
|
|
||||||
/* 80451548-8045154C 000A48 0004+00 1/1 0/0 0/0 .sbss frameBuffer$2222 */
|
|
||||||
static void* frameBuffer;
|
|
||||||
|
|
||||||
/* 8045154C-80451550 000A4C 0004+00 1/1 0/0 0/0 .sbss None */
|
|
||||||
static s8 data_8045154C;
|
|
||||||
|
|
||||||
/* 802E4C54-802E4CAC 2DF594 0058+00 0/0 1/1 0/0 .text
|
/* 802E4C54-802E4CAC 2DF594 0058+00 0/0 1/1 0/0 .text
|
||||||
* createManager__8JUTVideoFPC16_GXRenderModeObj */
|
* createManager__8JUTVideoFPC16_GXRenderModeObj */
|
||||||
JUTVideo* JUTVideo::createManager(_GXRenderModeObj const* param_0) {
|
JUTVideo* JUTVideo::createManager(_GXRenderModeObj const* param_0) {
|
||||||
|
@ -105,10 +87,7 @@ void JUTVideo::preRetraceProc(u32 retrace_count) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!data_8045154C) {
|
static void* frameBuffer = NULL;
|
||||||
frameBuffer = NULL;
|
|
||||||
data_8045154C = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (frameBuffer) {
|
if (frameBuffer) {
|
||||||
JUTVideo* videoManager = JUTGetVideoManager();
|
JUTVideo* videoManager = JUTGetVideoManager();
|
||||||
|
@ -234,6 +213,4 @@ void JUTVideo::setRenderMode(GXRenderModeObj const* pObj) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 802E5210-802E5214 2DFB50 0004+00 0/0 1/1 0/0 .text waitRetraceIfNeed__8JUTVideoFv */
|
/* 802E5210-802E5214 2DFB50 0004+00 0/0 1/1 0/0 .text waitRetraceIfNeed__8JUTVideoFv */
|
||||||
void JUTVideo::waitRetraceIfNeed() {
|
void JUTVideo::waitRetraceIfNeed() {}
|
||||||
/* empty function */
|
|
||||||
}
|
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
#include "JSystem/JUtility/JUTXfb.h"
|
#include "JSystem/JUtility/JUTXfb.h"
|
||||||
#include "dol2asm.h"
|
#include "dol2asm.h"
|
||||||
#include "dolphin/gx/GX.h"
|
#include "dolphin/gx/GX.h"
|
||||||
#include "dolphin/types.h"
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Forward References:
|
// Forward References:
|
||||||
|
@ -76,8 +75,8 @@ JUTXfb::JUTXfb(_GXRenderModeObj const* pObj, JKRHeap* pHeap, JUTXfb::EXfbNumber
|
||||||
#pragma push
|
#pragma push
|
||||||
#pragma optimization_level 0
|
#pragma optimization_level 0
|
||||||
#pragma optimizewithasm off
|
#pragma optimizewithasm off
|
||||||
asm JUTXfb::JUTXfb(_GXRenderModeObj const* param_0, JKRHeap* param_1, JUTXfb::EXfbNumber param_2) {
|
asm JUTXfb::JUTXfb(_GXRenderModeObj const* param_0, JKRHeap* param_1,
|
||||||
nofralloc
|
JUTXfb::EXfbNumber param_2){nofralloc
|
||||||
#include "asm/JSystem/JUtility/JUTXfb/__ct__6JUTXfbFPC16_GXRenderModeObjP7JKRHeapQ26JUTXfb10EXfbNumber.s"
|
#include "asm/JSystem/JUtility/JUTXfb/__ct__6JUTXfbFPC16_GXRenderModeObjP7JKRHeapQ26JUTXfb10EXfbNumber.s"
|
||||||
}
|
}
|
||||||
#pragma pop
|
#pragma pop
|
||||||
|
|
Loading…
Reference in New Issue