diff options
author | Asheraf <acheraf1998@gmail.com> | 2018-04-04 17:05:44 +0100 |
---|---|---|
committer | Asheraf <acheraf1998@gmail.com> | 2018-04-04 21:05:38 +0100 |
commit | 9ecc1bde4ea83f14be6b72f68a134dca4cb34478 (patch) | |
tree | 24f6ae9eda91be117f83e185f5b4cfb5536326af | |
parent | ff2fe99a614aa23c73f63402c67c08f7a4885c4b (diff) | |
download | hercules-9ecc1bde4ea83f14be6b72f68a134dca4cb34478.tar.gz hercules-9ecc1bde4ea83f14be6b72f68a134dca4cb34478.tar.bz2 hercules-9ecc1bde4ea83f14be6b72f68a134dca4cb34478.tar.xz hercules-9ecc1bde4ea83f14be6b72f68a134dca4cb34478.zip |
Add support for packet ZC_FORMATSTRING_MSG
-rw-r--r-- | src/map/clif.c | 31 | ||||
-rw-r--r-- | src/map/clif.h | 1 | ||||
-rw-r--r-- | src/map/packets_struct.h | 7 |
3 files changed, 39 insertions, 0 deletions
diff --git a/src/map/clif.c b/src/map/clif.c index afe8aac40..dcb1919fb 100644 --- a/src/map/clif.c +++ b/src/map/clif.c @@ -9232,6 +9232,36 @@ void clif_msgtable_skill(struct map_session_data* sd, uint16 skill_id, int msg_i } /** +* Displays a format string from msgstringtable.txt with a %s value (ZC_FORMATSTRING_MSG). +* +* @param sd The target character. +* @param msg_id msgstringtable message index, 0-based (@see enum clif_messages) +* @param value The value to fill %s. +*/ +void clif_msgtable_str(struct map_session_data *sd, uint16 msg_id, const char *value) +{ + int message_len; + int len; + struct PACKET_ZC_FORMATSTRING_MSG *p; + + nullpo_retv(sd); + nullpo_retv(value); + + message_len = (int)strlen(value) + 1; + len = sizeof(*p) + message_len + 1; + + p = (struct PACKET_ZC_FORMATSTRING_MSG *)aMalloc(len); + p->PacketType = 0x2c2; + p->PacketLength = len; + p->MessageId = msg_id; + safestrncpy(p->MessageString, value, message_len); + p->MessageString[message_len] = 0; + + clif->send(p, p->PacketLength, &sd->bl, SELF); + aFree(p); +} + +/** * Validates and processes a global/guild/party message packet. * * @param[in] sd The source character. @@ -20923,6 +20953,7 @@ void clif_defaults(void) { clif->msgtable_skill = clif_msgtable_skill; clif->msgtable = clif_msgtable; clif->msgtable_num = clif_msgtable_num; + clif->msgtable_str = clif_msgtable_str; clif->message = clif_displaymessage; clif->messageln = clif_displaymessage2; clif->messages = clif_displaymessage_sprintf; diff --git a/src/map/clif.h b/src/map/clif.h index 873188f84..00881db3b 100644 --- a/src/map/clif.h +++ b/src/map/clif.h @@ -886,6 +886,7 @@ struct clif_interface { void (*msgtable) (struct map_session_data* sd, unsigned short msg_id); void (*msgtable_num) (struct map_session_data *sd, unsigned short msg_id, int value); void (*msgtable_skill) (struct map_session_data *sd, uint16 skill_id, int msg_id); + void (*msgtable_str) (struct map_session_data *sd, uint16 msg_id, const char *value); void (*message) (const int fd, const char* mes); void (*messageln) (const int fd, const char* mes); /* message+s(printf) */ diff --git a/src/map/packets_struct.h b/src/map/packets_struct.h index d8a2c6b31..606057f52 100644 --- a/src/map/packets_struct.h +++ b/src/map/packets_struct.h @@ -1699,6 +1699,13 @@ struct packet_quest_hunt_info { struct packet_quest_hunt_info_sub info[]; } __attribute__((packed)); +struct PACKET_ZC_FORMATSTRING_MSG { + uint16 PacketType; + uint16 PacketLength; + uint16 MessageId; + char MessageString[]; +} __attribute__((packed)); + #if !defined(sun) && (!defined(__NETBSD__) || __NetBSD_Version__ >= 600000000) // NetBSD 5 and Solaris don't like pragma pack but accept the packed attribute #pragma pack(pop) #endif // not NetBSD < 6 / Solaris |