From 531bcb87aeddb743ae13fff85bd52834f09b60b2 Mon Sep 17 00:00:00 2001 From: Samual Lenks Date: Wed, 13 Feb 2013 13:36:23 -0500 Subject: [PATCH] More cleanup, plus re-implement HUD_Notify_Push properly --- qcsrc/client/hud.qc | 21 ++++++++++++ qcsrc/common/notifications.qc | 62 ++++++++++++++++++++--------------- qcsrc/common/notifications.qh | 11 ++----- 3 files changed, 58 insertions(+), 36 deletions(-) diff --git a/qcsrc/client/hud.qc b/qcsrc/client/hud.qc index 3e3663db5a..5cdc317463 100644 --- a/qcsrc/client/hud.qc +++ b/qcsrc/client/hud.qc @@ -2056,6 +2056,27 @@ void HUD_KillNotify(string s1, string s2, string s3, float type, float msg) // s } }*/ } +void HUD_Notify_Push(string icon, string attacker, string victim) +{ + if(icon != "") + { + --kn_index; + if (kn_index == -1) { kn_index = KN_MAX_ENTRIES-1; } + killnotify_times[kn_index] = time; + + // icon + if(killnotify_icon[kn_index]) { strunzone(killnotify_icon[kn_index]); } + killnotify_icon[kn_index] = strzone(icon); + + // attacker + if(killnotify_attackers[kn_index]) { strunzone(killnotify_attackers[kn_index]); } + killnotify_attackers[kn_index] = strzone(attacker); + + // victim + if(killnotify_victims[kn_index]) { strunzone(killnotify_victims[kn_index]); } + killnotify_victims[kn_index] = strzone(victim); + } +} void HUD_Notify(void) { diff --git a/qcsrc/common/notifications.qc b/qcsrc/common/notifications.qc index 0f51f3524a..4d92ec1ac9 100644 --- a/qcsrc/common/notifications.qc +++ b/qcsrc/common/notifications.qc @@ -4,7 +4,6 @@ // ================================================ #ifndef MENUQC -string arg_slot[7]; entity Get_Notif_Ent(float net_type, float net_name) { switch(net_type) @@ -109,31 +108,6 @@ void Dump_Notifications(float fh, float alsoprint) } #ifndef MENUQC -#ifdef CSQC -void HUD_Notify_Push(string icon, string attacker, string victim) -{ - if(icon != "") - { - --kn_index; - if (kn_index == -1) { kn_index = KN_MAX_ENTRIES-1; } - killnotify_times[kn_index] = time; - - // icon - if(killnotify_icon[kn_index]) { strunzone(killnotify_icon[kn_index]); } - killnotify_icon[kn_index] = strzone(icon); - - // attacker - if(killnotify_attackers[kn_index]) { strunzone(killnotify_attackers[kn_index]); } - killnotify_attackers[kn_index] = strzone(attacker); - - // victim - if(killnotify_victims[kn_index]) { strunzone(killnotify_victims[kn_index]); } - killnotify_victims[kn_index] = strzone(victim); - } -} -#endif // ifdef CSQC - - string Local_Notification_sprintf(string input, string args, string s1, string s2, string s3, string s4, float f1, float f2, float f3, float f4) @@ -152,6 +126,8 @@ string Local_Notification_sprintf(string input, string args, #ifdef CSQC string tmp_s; #endif + + arg_slot[0] = ""; arg_slot[1] = ""; arg_slot[2] = ""; arg_slot[3] = ""; arg_slot[4] = ""; arg_slot[5] = ""; arg_slot[6] = ""; if((remaining != "") && (input != "")) { @@ -204,6 +180,38 @@ string Local_Notification_sprintf(string input, string args, return ""; } +#ifdef CSQC +void Local_Notification_HUD_Notify_Push(string icon, string hudargs, string s1, string s2) +{ + string selected, remaining = hudargs; + float sel_num = 0; + + arg_slot[0] = ""; arg_slot[1] = ""; + + if(remaining != "") + { + for(;remaining;) + { + selected = car(remaining); remaining = cdr(remaining); + + switch(strtolower(selected)) + { + #define ADD_ARG_CASE(selected,result) case selected: { arg_slot[sel_num] = result; ++sel_num; break; } + + ADD_ARG_CASE("s1", s1) + ADD_ARG_CASE("s2", s2) + + #undef ADD_ARG_CASE + default: { backtrace(sprintf("Hit unknown token in selected string! '%s'\n", selected)); break; } + } + if(sel_num == 7) { backtrace("Hit maximum arguments!\n"); break; } + } + } + + HUD_Notify_Push(icon, arg_slot[0], arg_slot[1]); +} +#endif + void Local_Notification(float net_type, float net_name, ...count) { // check supplied type and name for errors @@ -265,7 +273,7 @@ void Local_Notification(float net_type, float net_name, ...count) s1, s2, s3, s4, f1, f2, f3, f4)); #ifdef CSQC - if(notif.nent_icon != "") { HUD_Notify_Push(notif.nent_icon, s1, s2); } + if(notif.nent_icon != "") { Local_Notification_HUD_Notify_Push(notif.nent_icon, notif.nent_hudargs, s1, s2); } #endif break; } diff --git a/qcsrc/common/notifications.qh b/qcsrc/common/notifications.qh index 4cc6da9c95..4b3262efc1 100644 --- a/qcsrc/common/notifications.qh +++ b/qcsrc/common/notifications.qh @@ -15,15 +15,6 @@ #define NO_FL_ARG -12345 #define NO_MSG -12345 -// field identifiers for Get_Field_Value() -#define F_NAME 1 -#define F_INFNAME 2 -#define F_CENNAME 3 -#define F_INFVAL 4 -#define F_CENVAL 5 -#define F_STRNUM 6 -#define F_FLNUM 7 - // ping of bots defined for extra frag message notification information #define BOT_PING -1 @@ -60,6 +51,8 @@ float Get_Notif_Cenval(float net_type, float net_name); float Get_Notif_Strnum(float net_type, float net_name); float Get_Notif_Flnum(float net_type, float net_name); +string arg_slot[7]; + void Local_Notification(float net_type, float net_name, ...count); void Local_Notification_Without_VarArgs(float net_type, float net_name, float stringcount, float floatcount, string s1, string s2, string s3, string s4, float f1, float f2, float f3, float f4); -- 2.39.2