From 9cd3ccffd5372dfde3af478e3f832f18db4be3f1 Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Sat, 6 Apr 2013 13:14:41 +0200 Subject: tagging tags --- ychat-0.7.9.1/src/mods/html/yc_help.cpp | 50 +++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100755 ychat-0.7.9.1/src/mods/html/yc_help.cpp (limited to 'ychat-0.7.9.1/src/mods/html/yc_help.cpp') diff --git a/ychat-0.7.9.1/src/mods/html/yc_help.cpp b/ychat-0.7.9.1/src/mods/html/yc_help.cpp new file mode 100755 index 0000000..da58be8 --- /dev/null +++ b/ychat-0.7.9.1/src/mods/html/yc_help.cpp @@ -0,0 +1,50 @@ +#include "../../incl.h" + +/* + gcc -shared -o yc_name.so yc_name.cpp +*/ + +using namespace std; + +extern "C" +{ + int extern_function(void *v_arg) + { + container* c = (container*) v_arg; + dynamic_wrap* p_wrap = (dynamic_wrap*) c->elem[0]; + user* p_user = (user*) c->elem[2]; + + modl* p_modl = (modl*) p_wrap->MODL; + conf* p_conf = (conf*) p_wrap->CONF; + chat* p_chat = (chat*) p_wrap->CHAT; + string* s_content = &(*((map*) c->elem[1]))["content"]; + + vector* p_vec_keys = p_modl->get_mod_vector(); + + sort(p_vec_keys->begin(), p_vec_keys->end()); + vector::iterator p_vec_keys_iter = p_vec_keys->begin(); + + while( p_vec_keys_iter != p_vec_keys->end() ) + { + + if ( p_vec_keys_iter->find( "mods/commands/", 0 ) != string::npos ) + { + + string s_command_name = p_vec_keys_iter->substr(17); + s_command_name.erase( s_command_name.find( ".so" ) ); + + if ( !p_chat->get_command_disabled( s_command_name ) && + p_chat->get_command_status( s_command_name ) >= p_user->get_status()) + { + s_content->append( "\n" ); + s_content->append( "\n" ); + s_content->append( "\n" ); + s_content->append( "
/" + s_command_name + "
" + p_conf->get_elem("chat.msgs.help." + s_command_name) + "
\n
\n" ); + } + } + p_vec_keys_iter++; + } + return 0; + } +} + -- cgit v1.2.3