summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--asm/easy_chat.s351
-rw-r--r--include/global.h16
-rw-r--r--ld_script.txt1
-rw-r--r--src/easy_chat.c283
4 files changed, 292 insertions, 359 deletions
diff --git a/asm/easy_chat.s b/asm/easy_chat.s
index a85169b61..4b83db729 100644
--- a/asm/easy_chat.s
+++ b/asm/easy_chat.s
@@ -5,357 +5,6 @@
.text
- thumb_func_start sub_811A20C
-sub_811A20C: @ 811A20C
- push {r4-r6,lr}
- mov r6, r9
- mov r5, r8
- push {r5,r6}
- adds r6, r0, 0
- mov r8, r1
- mov r9, r2
- adds r5, r3, 0
- lsls r6, 24
- lsrs r6, 24
- lsls r5, 24
- lsrs r5, 24
- bl ResetTasks
- ldr r0, =sub_811A2C0
- movs r1, 0
- bl CreateTask
- adds r4, r0, 0
- lsls r4, 24
- lsrs r4, 24
- ldr r1, =gTasks
- lsls r0, r4, 2
- adds r0, r4
- lsls r0, 3
- adds r0, r1
- strh r6, [r0, 0xA]
- strh r5, [r0, 0x16]
- adds r0, r4, 0
- movs r1, 0x2
- mov r2, r8
- bl SetWordTaskArg
- adds r0, r4, 0
- movs r1, 0x4
- mov r2, r9
- bl SetWordTaskArg
- ldr r0, =sub_811A278
- bl SetMainCallback2
- pop {r3,r4}
- mov r8, r3
- mov r9, r4
- pop {r4-r6}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_811A20C
-
- thumb_func_start sub_811A278
-sub_811A278: @ 811A278
- push {lr}
- bl RunTasks
- bl AnimateSprites
- bl BuildOamBuffer
- bl UpdatePaletteFade
- pop {r0}
- bx r0
- thumb_func_end sub_811A278
-
- thumb_func_start sub_811A290
-sub_811A290: @ 811A290
- push {lr}
- bl TransferPlttBuffer
- bl LoadOam
- bl ProcessSpriteCopyRequests
- pop {r0}
- bx r0
- thumb_func_end sub_811A290
-
- thumb_func_start sub_811A2A4
-sub_811A2A4: @ 811A2A4
- lsls r0, 24
- lsrs r0, 24
- ldr r3, =gTasks
- lsls r2, r0, 2
- adds r2, r0
- lsls r2, 3
- adds r2, r3
- str r1, [r2]
- movs r0, 0
- strh r0, [r2, 0x8]
- bx lr
- .pool
- thumb_func_end sub_811A2A4
-
- thumb_func_start sub_811A2C0
-sub_811A2C0: @ 811A2C0
- push {r4,lr}
- lsls r0, 24
- lsrs r4, r0, 24
- bl is_c1_link_related_active
- cmp r0, 0
- bne _0811A2DC
-_0811A2CE:
- adds r0, r4, 0
- bl sub_811A428
- lsls r0, 24
- cmp r0, 0
- bne _0811A2CE
- b _0811A2EA
-_0811A2DC:
- adds r0, r4, 0
- bl sub_811A428
- lsls r0, 24
- lsrs r0, 24
- cmp r0, 0x1
- beq _0811A2F2
-_0811A2EA:
- ldr r1, =sub_811A2FC
- adds r0, r4, 0
- bl sub_811A2A4
-_0811A2F2:
- pop {r4}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_811A2C0
-
- thumb_func_start sub_811A2FC
-sub_811A2FC: @ 811A2FC
- push {r4-r6,lr}
- sub sp, 0x4
- lsls r0, 24
- lsrs r2, r0, 24
- lsls r0, r2, 2
- adds r0, r2
- lsls r0, 3
- ldr r1, =gTasks + 0x8
- adds r5, r0, r1
- movs r1, 0
- ldrsh r0, [r5, r1]
- cmp r0, 0x5
- bls _0811A318
- b _0811A41C
-_0811A318:
- lsls r0, 2
- ldr r1, =_0811A32C
- adds r0, r1
- ldr r0, [r0]
- mov pc, r0
- .pool
- .align 2, 0
-_0811A32C:
- .4byte _0811A344
- .4byte _0811A370
- .4byte _0811A3CC
- .4byte _0811A3D4
- .4byte _0811A3EC
- .4byte _0811A40C
-_0811A344:
- ldr r0, =sub_811A290
- bl SetVBlankCallback
- movs r4, 0x1
- negs r4, r4
- adds r0, r4, 0
- movs r1, 0x10
- movs r2, 0
- bl BlendPalettes
- movs r0, 0
- str r0, [sp]
- adds r0, r4, 0
- adds r1, r4, 0
- movs r2, 0x10
- movs r3, 0
- bl BeginNormalPaletteFade
- movs r0, 0x5
- b _0811A41A
- .pool
-_0811A370:
- bl sub_811AAAC
- lsls r0, 16
- lsrs r4, r0, 16
- adds r6, r4, 0
- adds r0, r4, 0
- bl sub_811A88C
- cmp r0, 0
- beq _0811A39E
- movs r0, 0x1
- negs r0, r0
- movs r1, 0x2
- negs r1, r1
- movs r2, 0
- str r2, [sp]
- movs r3, 0x10
- bl BeginNormalPaletteFade
- movs r0, 0x3
- strh r0, [r5]
- strh r4, [r5, 0xC]
- b _0811A41C
-_0811A39E:
- cmp r4, 0x18
- bne _0811A3B6
- movs r1, 0x1
- negs r1, r1
- str r0, [sp]
- adds r0, r1, 0
- movs r2, 0
- movs r3, 0x10
- bl BeginNormalPaletteFade
- movs r0, 0x4
- b _0811A41A
-_0811A3B6:
- cmp r6, 0
- beq _0811A41C
- movs r0, 0x5
- bl PlaySE
- adds r0, r6, 0
- bl sub_811C158
- ldrh r0, [r5]
- adds r0, 0x1
- b _0811A41A
-_0811A3CC:
- bl sub_811C170
- lsls r0, 24
- b _0811A414
-_0811A3D4:
- ldr r0, =gPaletteFade
- ldrb r1, [r0, 0x7]
- movs r0, 0x80
- ands r0, r1
- cmp r0, 0
- bne _0811A41C
- ldrh r0, [r5, 0xC]
- bl sub_811A8A4
- b _0811A41C
- .pool
-_0811A3EC:
- ldr r0, =gPaletteFade
- ldrb r1, [r0, 0x7]
- movs r0, 0x80
- ands r0, r1
- cmp r0, 0
- bne _0811A41C
- adds r0, r2, 0
- movs r1, 0x4
- bl GetWordTaskArg
- bl sub_811A4D0
- b _0811A41C
- .pool
-_0811A40C:
- ldr r0, =gPaletteFade
- ldrb r1, [r0, 0x7]
- movs r0, 0x80
- ands r0, r1
-_0811A414:
- cmp r0, 0
- bne _0811A41C
- movs r0, 0x1
-_0811A41A:
- strh r0, [r5]
-_0811A41C:
- add sp, 0x4
- pop {r4-r6}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_811A2FC
-
- thumb_func_start sub_811A428
-sub_811A428: @ 811A428
- push {r4-r6,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, =gTasks + 0x8
- adds r6, r0, r1
- movs r1, 0
- ldrsh r0, [r6, r1]
- cmp r0, 0x4
- bhi _0811A4BC
- lsls r0, 2
- ldr r1, =_0811A454
- adds r0, r1
- ldr r0, [r0]
- mov pc, r0
- .pool
- .align 2, 0
-_0811A454:
- .4byte _0811A468
- .4byte _0811A47C
- .4byte _0811A482
- .4byte _0811A498
- .4byte _0811A4B0
-_0811A468:
- movs r0, 0
- bl SetVBlankCallback
- bl ResetSpriteData
- bl FreeAllSpritePalettes
- bl ResetPaletteFade
- b _0811A4C0
-_0811A47C:
- bl sub_811F28C
- b _0811A49C
-_0811A482:
- ldrb r4, [r6, 0x2]
- adds r0, r5, 0
- movs r1, 0x2
- bl GetWordTaskArg
- adds r1, r0, 0
- ldrb r2, [r6, 0xE]
- adds r0, r4, 0
- bl sub_811A95C
- b _0811A49C
-_0811A498:
- bl sub_811BF8C
-_0811A49C:
- lsls r0, 24
- cmp r0, 0
- bne _0811A4C0
- adds r0, r5, 0
- movs r1, 0x4
- bl GetWordTaskArg
- bl sub_811A4D0
- b _0811A4C0
-_0811A4B0:
- bl sub_811BFA4
- lsls r0, 24
- cmp r0, 0
- beq _0811A4C0
- b _0811A4C6
-_0811A4BC:
- movs r0, 0
- b _0811A4C8
-_0811A4C0:
- ldrh r0, [r6]
- adds r0, 0x1
- strh r0, [r6]
-_0811A4C6:
- movs r0, 0x1
-_0811A4C8:
- pop {r4-r6}
- pop {r1}
- bx r1
- thumb_func_end sub_811A428
-
- thumb_func_start sub_811A4D0
-sub_811A4D0: @ 811A4D0
- push {r4,lr}
- adds r4, r0, 0
- bl sub_811C13C
- bl sub_811AA90
- bl sub_811F2B8
- bl FreeAllWindowBuffers
- adds r0, r4, 0
- bl SetMainCallback2
- pop {r4}
- pop {r0}
- bx r0
- thumb_func_end sub_811A4D0
-
thumb_func_start easy_chat_input_maybe
easy_chat_input_maybe: @ 811A4F0
push {r4,r5,lr}
diff --git a/include/global.h b/include/global.h
index 8860b4ae3..b1c4add75 100644
--- a/include/global.h
+++ b/include/global.h
@@ -340,14 +340,14 @@ struct MailStruct
struct UnkMauvilleOldManStruct
{
- u8 unk_2D94;
- u8 unk_2D95;
- /*0x2D96*/ u16 mauvilleOldMan_ecArray[6];
- /*0x2DA2*/ u16 mauvilleOldMan_ecArray2[6];
- /*0x2DAE*/ u8 playerName[8];
- /*0x2DB6*/ u8 filler_2DB6[0x3];
- /*0x2DB9*/ u8 playerTrainerId[4];
- u8 unk_2DBD;
+ u8 unk_2E28;
+ u8 unk_2E29;
+ /*0x2E2A*/ u16 mauvilleOldMan_ecArray[6];
+ /*0x2E36*/ u16 mauvilleOldMan_ecArray2[6];
+ /*0x2E42*/ u8 playerName[8];
+ /*0x2E4A*/ u8 filler_2E4A[0x3];
+ /*0x2E4B*/ u8 playerTrainerId[4];
+ u8 unk_2E4F;
}; /*size = 0x2C*/
struct UnkMauvilleOldManStruct2
diff --git a/ld_script.txt b/ld_script.txt
index f655711dd..8f16f296d 100644
--- a/ld_script.txt
+++ b/ld_script.txt
@@ -161,6 +161,7 @@ SECTIONS {
asm/item_use.o(.text);
asm/battle_anim_80FE840.o(.text);
asm/bike.o(.text);
+ src/easy_chat.o(.text);
asm/easy_chat.o(.text);
asm/mon_markings.o(.text);
asm/mauville_old_man.o(.text);
diff --git a/src/easy_chat.c b/src/easy_chat.c
new file mode 100644
index 000000000..24f1a2b57
--- /dev/null
+++ b/src/easy_chat.c
@@ -0,0 +1,283 @@
+
+// Includes
+#include "global.h"
+#include "songs.h"
+#include "sound.h"
+#include "overworld.h"
+#include "task.h"
+#include "main.h"
+#include "window.h"
+#include "palette.h"
+#include "event_data.h"
+#include "easy_chat.h"
+
+// Static type declarations
+
+#define EZCHAT_TASK_STATE 0
+#define EZCHAT_TASK_UNK01 1
+#define EZCHAT_TASK_UNK02 2
+#define EZCHAT_TASK_MAINCALLBACK 4
+#define EZCHAT_TASK_UNK06 6
+#define EZCHAT_TASK_UNK07 7
+
+// Static RAM declarations
+static void sub_811A2C0(u8);
+static void sub_811A278(void);
+static bool8 sub_811A428(u8);
+static void sub_811A2FC(u8);
+/*static*/ u16 sub_811AAAC(void);
+/*static*/ bool32 sub_811A88C(u16);
+/*static*/ void sub_811C158(u16);
+/*static*/ bool8 sub_811C170(void);
+/*static*/ void sub_811A8A4(u16);
+/*static*/ void sub_811A4D0(MainCallback);
+bool8 sub_811F28C(void);
+bool8 sub_811A95C(u8, u32, u8);
+bool8 sub_811BF8C(void);
+bool8 sub_811BFA4(void);
+void sub_811C13C(void);
+void sub_811AA90(void);
+void sub_811F2B8(void);
+
+// Static ROM declarations
+
+// .rodata
+
+// .text
+
+void sub_811A20C(u8 a0, u32 a1, MainCallback callback, u8 a3)
+{
+ u8 taskId;
+
+ ResetTasks();
+ taskId = CreateTask(sub_811A2C0, 0);
+ gTasks[taskId].data[EZCHAT_TASK_UNK01] = a0;
+ gTasks[taskId].data[EZCHAT_TASK_UNK07] = a3;
+ SetWordTaskArg(taskId, EZCHAT_TASK_UNK02, a1);
+ SetWordTaskArg(taskId, EZCHAT_TASK_MAINCALLBACK, (u32)callback);
+ SetMainCallback2(sub_811A278);
+}
+
+static void sub_811A278(void)
+{
+ RunTasks();
+ AnimateSprites();
+ BuildOamBuffer();
+ UpdatePaletteFade();
+}
+
+static void sub_811A290(void)
+{
+ TransferPlttBuffer();
+ LoadOam();
+ ProcessSpriteCopyRequests();
+}
+
+static void sub_811A2A4(u8 taskId, TaskFunc taskFunc)
+{
+ gTasks[taskId].func = taskFunc;
+ gTasks[taskId].data[EZCHAT_TASK_STATE] = 0;
+}
+
+static void sub_811A2C0(u8 taskId)
+{
+ if (!is_c1_link_related_active())
+ {
+ while (sub_811A428(taskId));
+ }
+ else
+ {
+ if (sub_811A428(taskId) == TRUE)
+ {
+ return;
+ }
+ }
+ sub_811A2A4(taskId, sub_811A2FC);
+}
+
+static void sub_811A2FC(u8 taskId)
+{
+ u16 v0;
+ s16 *data;
+
+ data = gTasks[taskId].data;
+ switch (data[EZCHAT_TASK_STATE])
+ {
+ case 0:
+ SetVBlankCallback(sub_811A290);
+ BlendPalettes(-1, 16, 0);
+ BeginNormalPaletteFade(-1, -1, 16, 0, 0);
+ data[EZCHAT_TASK_STATE] = 5;
+ break;
+ case 1:
+ v0 = sub_811AAAC();
+ if (sub_811A88C(v0))
+ {
+ BeginNormalPaletteFade(-1, -2, 0, 16, 0);
+ data[EZCHAT_TASK_STATE] = 3;
+ data[EZCHAT_TASK_UNK06] = v0;
+ }
+ else if (v0 == 0x18)
+ {
+ BeginNormalPaletteFade(-1, -1, 0, 16, 0);
+ data[EZCHAT_TASK_STATE] = 4;
+ }
+ else if (v0 != 0)
+ {
+ PlaySE(SE_SELECT);
+ sub_811C158(v0);
+ data[EZCHAT_TASK_STATE] ++;
+ }
+ break;
+ case 2:
+ if (!sub_811C170())
+ {
+ data[EZCHAT_TASK_STATE] = 1;
+ }
+ break;
+ case 3:
+ if (!gPaletteFade.active)
+ {
+ sub_811A8A4(data[EZCHAT_TASK_UNK06]);
+ }
+ break;
+ case 4:
+ if (!gPaletteFade.active)
+ {
+ sub_811A4D0((MainCallback)GetWordTaskArg(taskId, EZCHAT_TASK_MAINCALLBACK));
+ }
+ break;
+ case 5:
+ if (!gPaletteFade.active)
+ {
+ data[EZCHAT_TASK_STATE] = 1;
+ }
+ break;
+ }
+}
+
+static bool8 sub_811A428(u8 taskId)
+{
+ s16 *data;
+
+ data = gTasks[taskId].data;
+ switch (data[EZCHAT_TASK_STATE])
+ {
+ case 0:
+ SetVBlankCallback(NULL);
+ ResetSpriteData();
+ FreeAllSpritePalettes();
+ ResetPaletteFade();
+ break;
+ case 1:
+ if (!sub_811F28C())
+ {
+ sub_811A4D0((MainCallback)GetWordTaskArg(taskId, EZCHAT_TASK_MAINCALLBACK));
+ }
+ break;
+ case 2:
+ if (!sub_811A95C(data[EZCHAT_TASK_UNK01], GetWordTaskArg(taskId, EZCHAT_TASK_UNK02), data[EZCHAT_TASK_UNK07]))
+ {
+ sub_811A4D0((MainCallback)GetWordTaskArg(taskId, EZCHAT_TASK_MAINCALLBACK));
+ }
+ break;
+ case 3:
+ if (!sub_811BF8C())
+ {
+ sub_811A4D0((MainCallback)GetWordTaskArg(taskId, EZCHAT_TASK_MAINCALLBACK));
+ }
+ break;
+ case 4:
+ if (sub_811BFA4())
+ {
+ return TRUE;
+ }
+ break;
+ default:
+ return FALSE;
+ }
+ data[EZCHAT_TASK_STATE] ++;
+ return TRUE;
+}
+
+void sub_811A4D0(MainCallback callback)
+{
+ sub_811C13C();
+ sub_811AA90();
+ sub_811F2B8();
+ FreeAllWindowBuffers();
+ SetMainCallback2(callback);
+}
+//
+//void easy_chat_input_maybe(void)
+//{
+// u16 i;
+// u16 *words;
+// OldMan *oldMan;
+// u8 sizeParam = 3;
+// switch (gSpecialVar_0x8004)
+// {
+// case 0:
+// words = gSaveBlock1Ptr->unk2BB0;
+// break;
+// case 1:
+// words = gSaveBlock1Ptr->unk2BBC;
+// break;
+// case 2:
+// words = gSaveBlock1Ptr->unk2BC8;
+// break;
+// case 3:
+// words = gSaveBlock1Ptr->unk2BD4;
+// break;
+// case 4:
+// words = gSaveBlock1Ptr->mail[gSpecialVar_0x8005].words;
+// break;
+// case 6:
+// oldMan = &gSaveBlock1Ptr->oldMan;
+// for (i=0; i<6; i++)
+// {
+// oldMan->oldMan1.mauvilleOldMan_ecArray2[i] = oldMan->oldMan1.mauvilleOldMan_ecArray[i];
+// }
+// words = oldMan->oldMan1.mauvilleOldMan_ecArray2;
+// break;
+// case 5:
+// words = gSaveBlock1Ptr->tvShows[gSpecialVar_0x8005].bravoTrainer.var04;
+// sizeParam = gSpecialVar_0x8006;
+// break;
+// case 7:
+// words = &gSaveBlock1Ptr->tvShows[gSpecialVar_0x8005].fanclubOpinions.var1C[gSpecialVar_0x8006];
+// sizeParam = 1;
+// break;
+// case 8:
+// words = &gSaveBlock1Ptr->tvShows[gSpecialVar_0x8005].recentHappenings.var02;
+// sizeParam = 0;
+// break;
+// case 9:
+// words = NULL;
+// break;
+// case 10:
+// words = &gSaveBlock1Ptr->gabbyAndTyData.quote;
+// *words = -1;
+// sizeParam = 1;
+// break;
+// case 11:
+// words = &gSaveBlock1Ptr->tvShows[gSpecialVar_0x8005].bravoTrainer.var04[gSpecialVar_0x8006];
+// sizeParam = 0;
+// break;
+// case 12:
+// words = gSaveBlock1Ptr->tvShows[gSpecialVar_0x8005].fanclubOpinions.var18;
+// sizeParam = 1;
+// break;
+// case 13:
+// words = (u16 *)gStringVar3;
+// sub_811F88C(words, 2);
+// break;
+// case 14:
+// words =
+// default:
+// return;
+// }
+// overworld_free_bg_tilemaps();
+// sub_811A20C(gSpecialVar_0x8004, words, sub_80861B0, sizeParam);
+//}
+