summaryrefslogtreecommitdiff
path: root/context.h
diff options
context:
space:
mode:
Diffstat (limited to 'context.h')
-rw-r--r--context.h150
1 files changed, 142 insertions, 8 deletions
diff --git a/context.h b/context.h
index 0444aee..db476cb 100644
--- a/context.h
+++ b/context.h
@@ -175,13 +175,13 @@ typedef long ptrdiff_t;
o(handle_08_recv_game_list, int entry_count, GameListEntry *entries, GameListEntry &entry_0) \
o(handle_01_recv_error, char *mesg) \
o(handle_06_recv_chat, TPlyGuildCardTag &tag, char *mesg) \
- o(handle_11_additional_info_reply_packet, void) \
+ o(handle_11_recv_message, char *mesg, u8 unused) \
o(handle_1A_D5_recv_text, char *text) \
o(handle_0E_recv_start_game, TPlyJoinLobbyData *entries, u8 entry_count, int lobby_entry_idx) \
o(unused7, void) \
- o(handle_64_join_game_packet, void) \
+ o(handle_64_recv_start_game3, TPlyJoinGame &join_data) \
o(unused8, void) \
- o(handle_67_join_lobby_packet, void) \
+ o(handle_67_recv_start_lobby2, TPlyJoinLobbyEntry *entries, u8 entry_count, int client_id, int leader_id, int lobby_number, int block_number, int smth, int event) \
o(handle_80_unused_ignored_packet, void) \
o(unused9, void) \
o(handle_65_add_player_to_game_packet, void) \
@@ -202,12 +202,12 @@ typedef long ptrdiff_t;
o(handle_D8_infoboard_packet, void) \
o(handle_A2_quest_list_packet, void) \
o(handle_A3_quest_info_packet, void) \
- o(handle_44_quest_file_list_packet, void) \
- o(handle_13_quest_data_packet, void) \
+ o(handle_44_recv_download_head, TRecvDownloadHead &download_head) \
+ o(handle_13_recv_download, TRecvDownload &download) \
o(handle_A4_downloadable_quest_menu_packet, void) \
o(handle_A5_downloadable_quest_info_packet, void) \
- o(handle_A6_download_quest_file_list_packet, void) \
- o(handle_A7_download_quest_file_data_packet, void) \
+ o(handle_A6_recv_download_head2, TRecvDownloadHead &download_head) \
+ o(handle_A7_recv_download2, TRecvDownload &download) \
o(unused11, void) \
o(handle_1F_recv_info_list, int entry_count, GameListEntry *entries, GameListEntry &entry_0) \
o(handle_B0_server_message_packet, void) \
@@ -518,6 +518,7 @@ extern TTcpSocket *tcp_socket_table[16];
// pso/TProtocol.h
EXTERN_OBJECT_NAME(TProtocol);
extern TPlyMeetUserExtension meet_user_settings;
+extern u32 game_variations[16][2];
// TObject.cpp
#define o(name) extern const char *name##_name;
@@ -783,7 +784,7 @@ enum object_flags {
class TPlyCharData {
public:
TPlyCharData() {};
- void bswap();
+ void bswap() {};
TPlyCharData &assign(const TPlyCharData &src);
public:
TPlyInventory m_inventory;
@@ -1198,6 +1199,109 @@ public:
};
};
+class TPlyJoinLobbyEntry {
+public:
+ TPlyJoinLobbyData lobby_data;
+ TPlyCharData char_data;
+public:
+ void bswap() {
+ lobby_data.tag.bswap();
+ bswap_32(&lobby_data.ip_addr);
+ bswap_32(&lobby_data.client_id);
+ char_data.bswap();
+ };
+};
+
+class TRecvDownload {
+public:
+ packet_header header;
+ char filename[16];
+ u8 data[1024];
+ u32 data_size;
+public:
+ void bswap() {
+ header.bswap();
+ bswap_32(&data_size);
+ };
+};
+
+class TSendDownloadHead {
+public:
+ packet_header header;
+ char filename[16];
+public:
+ void bswap() {
+ header.bswap();
+ };
+};
+
+class TRecvDownloadHead {
+public:
+ packet_header header;
+ char path[32];
+ u16 unused;
+ u16 flags;
+ char filename[16];
+ u32 file_size;
+public:
+ void bswap() {
+ header.bswap();
+ bswap_32(&file_size);
+ };
+};
+
+class TPlyJoinLobby {
+public:
+ packet_header header;
+ u8 client_id;
+ u8 leader_id;
+ u8 disable_udp;
+ u8 lobby_number;
+ u8 block_number;
+ u8 unknown1;
+ u8 event;
+ u8 unknown2;
+ u8 unused[4];
+ TPlyJoinLobbyEntry entries[12];
+public:
+ void bswap() {
+ header.bswap();
+ for (int i = 0; i < 12; ++i) {
+ entries[i].bswap();
+ }
+ };
+};
+
+class TPlyJoinGame {
+public:
+ packet_header header;
+ u32 variations[16][2];
+ TPlyJoinLobbyData lobby_data[4];
+ u8 client_id;
+ u8 leader_id;
+ u8 disable_udp;
+ u8 difficulty;
+ u8 battle_mode;
+ u8 event;
+ u8 section_id;
+ u8 challenge_mode;
+ u32 rare_seed;
+ u8 episode;
+ u8 unknown1;
+ u8 solo_mode;
+ u8 unknown2;
+public:
+ void bswap() {
+ header.bswap();
+ for (int i = 0; i < 16; ++i) {
+ for (int j = 0; j < 2; ++j) {
+ bswap_32(&variations[i][j]);
+ }
+ }
+ bswap_32(&rare_seed);
+ };
+};
+
class TPlyStartGame {
public:
packet_header header;
@@ -1220,6 +1324,16 @@ public:
TPlyGuildCardTag tag;
};
+class TPlyRecvLogin : public TPlyGuildCardTagPacket {
+public:
+ TPlyClientConfig client_config;
+public:
+ void bswap() {
+ header.bswap();
+ tag.bswap();
+ };
+};
+
class TMessageBox {
public:
packet_header header;
@@ -1302,4 +1416,24 @@ public:
void recv_info_list(packet &pkt);
// 0x0E
void recv_start_game(packet &pkt);
+ // 0x64
+ void recv_start_game3(packet &pkt);
+ // 0x67
+ void recv_start_lobby2(packet &pkt);
+ // 0x12
+ void recv_banner(packet &pkt);
+ // 0x16
+ void recv_banner_head(packet &pkt);
+ // 0x44
+ void recv_download_head(packet &pkt);
+ // 0xA6
+ void recv_download_head2(packet &pkt);
+ // 0xA7
+ void recv_download2(packet &pkt);
+ // 0x13
+ void recv_download(packet &pkt);
+ // 0x14
+ void recv_upload(packet &pkt);
+ // 0x11
+ void recv_message(packet &pkt);
};