blob: 11f93b66ad9ab095c2b3f8e68de3f5de151d9586 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
/*:*
*: File: ./src/mods/commands/yc_col.cpp
*:
*: yChat; Homepage: www.yChat.org; Version 0.8.3-CURRENT
*:
*: Copyright (C) 2003 Paul C. Buetow, Volker Richter
*: Copyright (C) 2004 Paul C. Buetow
*: Copyright (C) 2005 EXA Digital Solutions GbR
*:
*: This program is free software; you can redistribute it and/or
*: modify it under the terms of the GNU General Public License
*: as published by the Free Software Foundation; either version 2
*: of the License, or (at your option) any later version.
*:
*: This program is distributed in the hope that it will be useful,
*: but WITHOUT ANY WARRANTY; without even the implied warranty of
*: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
*: GNU General Public License for more details.
*:
*: You should have received a copy of the GNU General Public License
*: along with this program; if not, write to the Free Software
*: Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*:*/
#include <iostream>
#include "../../wrap.h"
#include "../../chat/room.h"
#include "../../chat/user.h"
#include "../../tool/tool.h"
/*
gcc -shared -o yc_name.so yc_name.cpp
*/
using namespace std;
extern "C"
{
int valid_color( string );
int extern_function(void *v_arg)
{
container *c=(container *)v_arg;
user *p_user = (user*)c->elem[1]; // the corresponding user
vector<string> *params= (vector<string>*) c->elem[2]; // param array
string s_color;
string s_color2;
conf* p_conf = (conf*) ((dynamic_wrap*)c->elem[3])->CONF;
timr* p_timr = (timr*) ((dynamic_wrap*)c->elem[3])->TIMR;
if ( params->empty() )
{
s_color = p_conf->get_elem( "chat.html.user.color1" );
s_color2 = p_conf->get_elem( "chat.html.user.color2" );
}
else
{
s_color = (string) params->front();
params->erase( params->begin() );
if ( ! params->empty() )
s_color2 = (string) params->front();
else
s_color2 = p_conf->get_elem( "chat.html.user.color1" );
}
s_color = tool::to_lower( s_color );
s_color2 = tool::to_lower( s_color2 );
if( valid_color(s_color) != 1 )
{
string *answerstring=new string(s_color + " is not a valid color.<br>\n");
p_user->msg_post( answerstring );
}
else if( valid_color(s_color2) != 1 )
{
string *answerstring=new string( s_color2 + " is not a valid color.<br>\n");
p_user->msg_post( answerstring );
}
else
{
string *answerstring=new string(p_timr->get_time() + " " + p_user->get_colored_bold_name()+ " changes color to <font color=\"#"
+ s_color + "\">" + s_color + "</font> <font color=\"#"
+ s_color2 + "\">" + s_color2 + "</font><br>\n");
p_user->get_room()->msg_post( answerstring );
p_user->set_col1(s_color);
p_user->set_col2(s_color2);
p_user->get_room()->reload_onlineframe();
}
return 0;
}
int valid_color( string s_color )
{
if(s_color.size()!=6)
return 0;
string valid="abcdef0123456789";
for(int i=0;i<s_color.size();i++)
{
string s_char=s_color.substr(i,1);
if(valid.find(s_char)==string::npos)
return 0;
}
return 1;
}
}
|