Thu, 06 Feb 2014 20:02:57 +0530
Merge gtkdoc-conversion
| 6694 | 1 | /** |
| 15884 | 2 | * @file tcl_cmds.c Commands for the Purple Tcl plugin bindings |
| 6694 | 3 | * |
| 15884 | 4 | * purple |
| 6694 | 5 | * |
| 6 | * Copyright (C) 2003 Ethan Blanton <eblanton@cs.purdue.edu> | |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
7 | * |
| 6694 | 8 | * This program is free software; you can redistribute it and/or modify |
| 9 | * it under the terms of the GNU General Public License as published by | |
| 10 | * the Free Software Foundation; either version 2 of the License, or | |
| 11 | * (at your option) any later version. | |
| 12 | * | |
| 13 | * This program is distributed in the hope that it will be useful, | |
| 14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 16 | * GNU General Public License for more details. | |
| 17 | * | |
| 18 | * You should have received a copy of the GNU General Public License | |
| 19 | * along with this program; if not, write to the Free Software | |
|
19859
71d37b57eff2
The FSF changed its address a while ago; our files were out of date.
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
19726
diff
changeset
|
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
| 6694 | 21 | */ |
| 22 | ||
| 23 | #include <tcl.h> | |
| 24 | ||
| 25 | #include "internal.h" | |
| 26 | #include "conversation.h" | |
| 27 | #include "connection.h" | |
|
22353
daef90676a8f
One more g_idle_add call
Mark Doliner <markdoliner@pidgin.im>
parents:
22240
diff
changeset
|
28 | #include "eventloop.h" |
| 6694 | 29 | #include "account.h" |
| 30 | #include "server.h" | |
| 31 | #include "notify.h" | |
|
34706
02cb08146888
Renamed blist.[ch] to buddylist.[ch]
Ankit Vani <a@nevitus.org>
parents:
34699
diff
changeset
|
32 | #include "buddylist.h" |
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
33 | #include "savedstatuses.h" |
| 6694 | 34 | #include "debug.h" |
| 35 | #include "prefs.h" | |
|
34852
0e01a98b2ef7
Renamed blistnodes.[ch] to blistnode.[ch], presences.[ch] to presence.[ch]
Ankit Vani <a@nevitus.org>
parents:
34842
diff
changeset
|
36 | #include "presence.h" |
| 6694 | 37 | #include "core.h" |
| 38 | ||
| 15884 | 39 | #include "tcl_purple.h" |
| 6694 | 40 | |
| 15884 | 41 | static PurpleAccount *tcl_validate_account(Tcl_Obj *obj, Tcl_Interp *interp); |
| 42 | static PurpleConversation *tcl_validate_conversation(Tcl_Obj *obj, Tcl_Interp *interp); | |
| 43 | static PurpleConnection *tcl_validate_gc(Tcl_Obj *obj, Tcl_Interp *interp); | |
| 6694 | 44 | |
| 15884 | 45 | static PurpleAccount *tcl_validate_account(Tcl_Obj *obj, Tcl_Interp *interp) |
| 6694 | 46 | { |
| 15884 | 47 | PurpleAccount *account; |
|
18122
9bf9970c1b6a
disapproval of revision '2d8ea56b90971e7851442d96b7d74ecb4f052126'
Richard Laager <rlaager@pidgin.im>
parents:
18121
diff
changeset
|
48 | GList *cur; |
| 13812 | 49 | |
| 15884 | 50 | account = purple_tcl_ref_get(interp, obj, PurpleTclRefAccount); |
| 13812 | 51 | |
| 52 | if (account == NULL) | |
| 53 | return NULL; | |
| 54 | ||
| 15884 | 55 | for (cur = purple_accounts_get_all(); cur != NULL; cur = g_list_next(cur)) { |
| 6694 | 56 | if (account == cur->data) |
| 13812 | 57 | return account; |
| 6694 | 58 | } |
| 59 | if (interp != NULL) | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
60 | Tcl_SetObjResult(interp, Tcl_NewStringObj("invalid account", -1)); |
| 13812 | 61 | return NULL; |
| 6694 | 62 | } |
| 63 | ||
| 15884 | 64 | static PurpleConversation *tcl_validate_conversation(Tcl_Obj *obj, Tcl_Interp *interp) |
| 6694 | 65 | { |
| 15884 | 66 | PurpleConversation *convo; |
|
18122
9bf9970c1b6a
disapproval of revision '2d8ea56b90971e7851442d96b7d74ecb4f052126'
Richard Laager <rlaager@pidgin.im>
parents:
18121
diff
changeset
|
67 | GList *cur; |
| 6694 | 68 | |
| 15884 | 69 | convo = purple_tcl_ref_get(interp, obj, PurpleTclRefConversation); |
| 13812 | 70 | |
| 71 | if (convo == NULL) | |
| 72 | return NULL; | |
| 73 | ||
|
34655
6a939719ea98
Replaced purple_conversations_get() with purple_conversations_get_all(), similar to other purple entities
Ankit Vani <a@nevitus.org>
parents:
34632
diff
changeset
|
74 | for (cur = purple_conversations_get_all(); cur != NULL; cur = g_list_next(cur)) { |
| 6694 | 75 | if (convo == cur->data) |
| 13812 | 76 | return convo; |
| 6694 | 77 | } |
| 78 | if (interp != NULL) | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
79 | Tcl_SetObjResult(interp, Tcl_NewStringObj("invalid conversation", -1)); |
| 13812 | 80 | return NULL; |
| 6694 | 81 | } |
| 82 | ||
| 15884 | 83 | static PurpleConnection *tcl_validate_gc(Tcl_Obj *obj, Tcl_Interp *interp) |
| 6694 | 84 | { |
| 15884 | 85 | PurpleConnection *gc; |
|
18122
9bf9970c1b6a
disapproval of revision '2d8ea56b90971e7851442d96b7d74ecb4f052126'
Richard Laager <rlaager@pidgin.im>
parents:
18121
diff
changeset
|
86 | GList *cur; |
| 13817 | 87 | |
| 15884 | 88 | gc = purple_tcl_ref_get(interp, obj, PurpleTclRefConnection); |
| 13817 | 89 | |
| 90 | if (gc == NULL) | |
| 91 | return NULL; | |
| 92 | ||
| 15884 | 93 | for (cur = purple_connections_get_all(); cur != NULL; cur = g_list_next(cur)) { |
| 6694 | 94 | if (gc == cur->data) |
| 13817 | 95 | return gc; |
| 6694 | 96 | } |
| 13817 | 97 | return NULL; |
| 6694 | 98 | } |
| 99 | ||
| 100 | int tcl_cmd_account(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 101 | { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
102 | Tcl_Obj *result, *list, *elem; |
| 13828 | 103 | const char *cmds[] = { "alias", "connect", "connection", "disconnect", |
| 104 | "enabled", "find", "handle", "isconnected", | |
| 105 | "list", "presence", "protocol", "status", | |
| 106 | "status_type", "status_types", "username", | |
| 107 | NULL }; | |
| 108 | enum { CMD_ACCOUNT_ALIAS, | |
| 13812 | 109 | CMD_ACCOUNT_CONNECT, CMD_ACCOUNT_CONNECTION, |
| 110 | CMD_ACCOUNT_DISCONNECT, CMD_ACCOUNT_ENABLED, CMD_ACCOUNT_FIND, | |
| 111 | CMD_ACCOUNT_HANDLE, CMD_ACCOUNT_ISCONNECTED, CMD_ACCOUNT_LIST, | |
| 13828 | 112 | CMD_ACCOUNT_PRESENCE, CMD_ACCOUNT_PROTOCOL, CMD_ACCOUNT_STATUS, |
| 113 | CMD_ACCOUNT_STATUS_TYPE, CMD_ACCOUNT_STATUS_TYPES, | |
| 114 | CMD_ACCOUNT_USERNAME } cmd; | |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
115 | const char *listopts[] = { "-all", "-online", NULL }; |
| 6694 | 116 | enum { CMD_ACCOUNTLIST_ALL, CMD_ACCOUNTLIST_ONLINE } listopt; |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
7713
diff
changeset
|
117 | const char *alias; |
|
18190
bcf28ef7e8ff
Re-fix the DBus list handling code by killing const GList* / const GSList*
Richard Laager <rlaager@pidgin.im>
parents:
18122
diff
changeset
|
118 | GList *cur; |
| 15884 | 119 | PurpleAccount *account; |
| 120 | PurpleStatus *status; | |
| 121 | PurpleStatusType *status_type; | |
|
34806
182a4df77539
Refactored tcl plugins to use GType instead of PurpleValue.
Ankit Vani <a@nevitus.org>
parents:
34746
diff
changeset
|
122 | GValue *value; |
| 13828 | 123 | char *attr_id; |
| 6694 | 124 | int error; |
| 13828 | 125 | int b, i; |
| 6694 | 126 | |
| 127 | if (objc < 2) { | |
| 128 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 129 | return TCL_ERROR; | |
| 130 | } | |
| 131 | ||
| 132 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 133 | return error; | |
| 134 | ||
| 135 | switch (cmd) { | |
| 136 | case CMD_ACCOUNT_ALIAS: | |
| 137 | if (objc != 3) { | |
| 138 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 139 | return TCL_ERROR; | |
| 140 | } | |
| 13812 | 141 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 142 | return TCL_ERROR; |
|
34589
428e92c79631
Renamed purple_account_[get,set]_alias to purple_account[get,set]_private_alias.
Ankit Vani <a@nevitus.org>
parents:
33896
diff
changeset
|
143 | alias = purple_account_get_private_alias(account); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
144 | Tcl_SetObjResult(interp, Tcl_NewStringObj(alias ? (char *)alias : "", -1)); |
| 6694 | 145 | break; |
| 146 | case CMD_ACCOUNT_CONNECT: | |
| 147 | if (objc != 3) { | |
| 148 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 149 | return TCL_ERROR; | |
| 150 | } | |
| 13812 | 151 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 152 | return TCL_ERROR; |
| 15884 | 153 | if (!purple_account_is_connected(account)) |
| 154 | purple_account_connect(account); | |
| 13817 | 155 | Tcl_SetObjResult(interp, |
| 15884 | 156 | purple_tcl_ref_new(PurpleTclRefConnection, |
| 157 | purple_account_get_connection(account))); | |
| 6694 | 158 | break; |
| 159 | case CMD_ACCOUNT_CONNECTION: | |
| 160 | if (objc != 3) { | |
| 161 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 162 | return TCL_ERROR; | |
| 163 | } | |
| 13812 | 164 | |
| 165 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) | |
| 6694 | 166 | return TCL_ERROR; |
| 13817 | 167 | Tcl_SetObjResult(interp, |
| 15884 | 168 | purple_tcl_ref_new(PurpleTclRefConnection, |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
169 | purple_account_get_connection(account))); |
| 6694 | 170 | break; |
| 171 | case CMD_ACCOUNT_DISCONNECT: | |
| 172 | if (objc != 3) { | |
| 173 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 174 | return TCL_ERROR; | |
| 175 | } | |
| 13812 | 176 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 177 | return TCL_ERROR; |
| 15884 | 178 | purple_account_disconnect(account); |
| 6694 | 179 | break; |
| 13812 | 180 | case CMD_ACCOUNT_ENABLED: |
| 181 | if (objc != 3 && objc != 4) { | |
| 182 | Tcl_WrongNumArgs(interp, 2, objv, "account ?enabled?"); | |
| 183 | return TCL_ERROR; | |
| 184 | } | |
| 185 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) | |
| 186 | return TCL_ERROR; | |
| 187 | if (objc == 3) { | |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
188 | Tcl_SetObjResult(interp, |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
189 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
190 | purple_account_get_enabled(account, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
191 | purple_core_get_ui()))); |
| 13812 | 192 | } else { |
| 193 | if ((error = Tcl_GetBooleanFromObj(interp, objv[3], &b)) != TCL_OK) | |
| 194 | return TCL_ERROR; | |
| 15884 | 195 | purple_account_set_enabled(account, purple_core_get_ui(), b); |
| 13812 | 196 | } |
| 197 | break; | |
| 6694 | 198 | case CMD_ACCOUNT_FIND: |
| 199 | if (objc != 4) { | |
| 200 | Tcl_WrongNumArgs(interp, 2, objv, "username protocol"); | |
| 201 | return TCL_ERROR; | |
| 202 | } | |
| 15884 | 203 | account = purple_accounts_find(Tcl_GetString(objv[2]), |
| 13817 | 204 | Tcl_GetString(objv[3])); |
| 205 | Tcl_SetObjResult(interp, | |
| 15884 | 206 | purple_tcl_ref_new(PurpleTclRefAccount, account)); |
| 6694 | 207 | break; |
| 208 | case CMD_ACCOUNT_HANDLE: | |
| 209 | if (objc != 2) { | |
| 210 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 211 | return TCL_ERROR; | |
| 212 | } | |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
213 | Tcl_SetObjResult(interp, |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
214 | purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
215 | purple_accounts_get_handle())); |
| 6694 | 216 | break; |
| 217 | case CMD_ACCOUNT_ISCONNECTED: | |
| 218 | if (objc != 3) { | |
| 219 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 220 | return TCL_ERROR; | |
| 221 | } | |
| 13812 | 222 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 223 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
224 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
225 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
226 | purple_account_is_connected(account))); |
| 6694 | 227 | break; |
| 228 | case CMD_ACCOUNT_LIST: | |
| 229 | listopt = CMD_ACCOUNTLIST_ALL; | |
| 230 | if (objc > 3) { | |
| 231 | Tcl_WrongNumArgs(interp, 2, objv, "?option?"); | |
| 232 | return TCL_ERROR; | |
| 233 | } | |
| 234 | if (objc == 3) { | |
| 235 | if ((error = Tcl_GetIndexFromObj(interp, objv[2], listopts, "option", 0, (int *)&listopt)) != TCL_OK) | |
| 236 | return error; | |
| 237 | } | |
| 238 | list = Tcl_NewListObj(0, NULL); | |
| 15884 | 239 | for (cur = purple_accounts_get_all(); cur != NULL; cur = g_list_next(cur)) { |
| 6694 | 240 | account = cur->data; |
| 15884 | 241 | if (listopt == CMD_ACCOUNTLIST_ONLINE && !purple_account_is_connected(account)) |
| 6694 | 242 | continue; |
| 15884 | 243 | elem = purple_tcl_ref_new(PurpleTclRefAccount, account); |
| 6694 | 244 | Tcl_ListObjAppendElement(interp, list, elem); |
| 245 | } | |
| 246 | Tcl_SetObjResult(interp, list); | |
| 247 | break; | |
| 13823 | 248 | case CMD_ACCOUNT_PRESENCE: |
| 249 | if (objc != 3) { | |
| 250 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 251 | return TCL_ERROR; | |
| 252 | } | |
| 253 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) | |
| 254 | return TCL_ERROR; | |
| 15884 | 255 | Tcl_SetObjResult(interp, purple_tcl_ref_new(PurpleTclRefPresence, |
| 256 | purple_account_get_presence(account))); | |
| 13823 | 257 | break; |
| 6694 | 258 | case CMD_ACCOUNT_PROTOCOL: |
| 259 | if (objc != 3) { | |
| 260 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 261 | return TCL_ERROR; | |
| 262 | } | |
| 13812 | 263 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 264 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
265 | Tcl_SetObjResult(interp, Tcl_NewStringObj((char *)purple_account_get_protocol_id(account), -1)); |
| 6694 | 266 | break; |
| 13828 | 267 | case CMD_ACCOUNT_STATUS: |
| 268 | if (objc < 3) { | |
| 269 | Tcl_WrongNumArgs(interp, 2, objv, "account ?status_id name value ...?"); | |
| 270 | return TCL_ERROR; | |
| 271 | } | |
| 272 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) | |
| 273 | return TCL_ERROR; | |
| 274 | if (objc == 3) { | |
| 275 | Tcl_SetObjResult(interp, | |
| 15884 | 276 | purple_tcl_ref_new(PurpleTclRefStatus, |
| 277 | purple_account_get_active_status(account))); | |
| 13828 | 278 | } else { |
| 279 | GList *l = NULL; | |
| 280 | if (objc % 2) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
281 | Tcl_SetObjResult(interp, Tcl_NewStringObj("name without value setting status", -1)); |
| 13828 | 282 | return TCL_ERROR; |
| 283 | } | |
| 15884 | 284 | status = purple_account_get_status(account, Tcl_GetString(objv[3])); |
| 13828 | 285 | if (status == NULL) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
286 | Tcl_SetObjResult(interp, Tcl_NewStringObj("invalid status for account", -1)); |
| 13828 | 287 | return TCL_ERROR; |
| 288 | } | |
| 289 | for (i = 4; i < objc; i += 2) { | |
| 290 | attr_id = Tcl_GetString(objv[i]); | |
| 15884 | 291 | value = purple_status_get_attr_value(status, attr_id); |
| 13828 | 292 | if (value == NULL) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
293 | Tcl_SetObjResult(interp, Tcl_NewStringObj("invalid attribute for account", -1)); |
| 13828 | 294 | return TCL_ERROR; |
| 295 | } | |
|
34806
182a4df77539
Refactored tcl plugins to use GType instead of PurpleValue.
Ankit Vani <a@nevitus.org>
parents:
34746
diff
changeset
|
296 | switch (G_VALUE_TYPE(value)) { |
|
182a4df77539
Refactored tcl plugins to use GType instead of PurpleValue.
Ankit Vani <a@nevitus.org>
parents:
34746
diff
changeset
|
297 | case G_TYPE_BOOLEAN: |
| 13828 | 298 | error = Tcl_GetBooleanFromObj(interp, objv[i + 1], &b); |
| 299 | if (error != TCL_OK) | |
| 300 | return error; | |
| 301 | l = g_list_append(l, attr_id); | |
| 302 | l = g_list_append(l, GINT_TO_POINTER(b)); | |
| 303 | break; | |
|
34806
182a4df77539
Refactored tcl plugins to use GType instead of PurpleValue.
Ankit Vani <a@nevitus.org>
parents:
34746
diff
changeset
|
304 | case G_TYPE_INT: |
| 13828 | 305 | error = Tcl_GetIntFromObj(interp, objv[i + 1], &b); |
| 306 | if (error != TCL_OK) | |
| 307 | return error; | |
| 308 | l = g_list_append(l, attr_id); | |
| 309 | l = g_list_append(l, GINT_TO_POINTER(b)); | |
| 310 | break; | |
|
34806
182a4df77539
Refactored tcl plugins to use GType instead of PurpleValue.
Ankit Vani <a@nevitus.org>
parents:
34746
diff
changeset
|
311 | case G_TYPE_STRING: |
| 13828 | 312 | l = g_list_append(l, attr_id); |
| 313 | l = g_list_append(l, Tcl_GetString(objv[i + 1])); | |
| 314 | break; | |
| 315 | default: | |
|
34806
182a4df77539
Refactored tcl plugins to use GType instead of PurpleValue.
Ankit Vani <a@nevitus.org>
parents:
34746
diff
changeset
|
316 | Tcl_SetObjResult(interp, Tcl_NewStringObj("unknown GValue type", -1)); |
| 13828 | 317 | return TCL_ERROR; |
| 318 | } | |
| 319 | } | |
| 15884 | 320 | purple_account_set_status_list(account, Tcl_GetString(objv[3]), TRUE, l); |
| 13828 | 321 | g_list_free(l); |
| 322 | } | |
| 323 | break; | |
| 13812 | 324 | case CMD_ACCOUNT_STATUS_TYPE: |
| 325 | if (objc != 4 && objc != 5) { | |
| 326 | Tcl_WrongNumArgs(interp, 2, objv, "account ?statustype? ?-primitive primitive?"); | |
| 327 | return TCL_ERROR; | |
| 328 | } | |
| 329 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) | |
| 330 | return TCL_ERROR; | |
| 331 | if (objc == 4) { | |
| 15884 | 332 | status_type = purple_account_get_status_type(account, |
| 13812 | 333 | Tcl_GetString(objv[3])); |
| 334 | } else { | |
| 15884 | 335 | PurpleStatusPrimitive primitive; |
| 13812 | 336 | if (strcmp(Tcl_GetString(objv[3]), "-primitive")) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
337 | result = Tcl_NewStringObj("bad option \"", -1); |
| 13812 | 338 | Tcl_AppendObjToObj(result, objv[3]); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
339 | Tcl_AppendToObj(result, "\": should be -primitive", -1); |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
340 | Tcl_SetObjResult(interp,result); |
| 13812 | 341 | return TCL_ERROR; |
| 342 | } | |
| 15884 | 343 | primitive = purple_primitive_get_type_from_id(Tcl_GetString(objv[4])); |
| 344 | status_type = purple_account_get_status_type_with_primitive(account, | |
| 13812 | 345 | primitive); |
| 346 | } | |
| 347 | if (status_type == NULL) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
348 | Tcl_SetObjResult(interp, Tcl_NewStringObj("status type not found", -1)); |
| 13812 | 349 | return TCL_ERROR; |
| 350 | } | |
| 351 | Tcl_SetObjResult(interp, | |
| 15884 | 352 | purple_tcl_ref_new(PurpleTclRefStatusType, |
| 13812 | 353 | status_type)); |
| 354 | break; | |
| 355 | case CMD_ACCOUNT_STATUS_TYPES: | |
| 356 | if (objc != 3) { | |
| 357 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 358 | return TCL_ERROR; | |
| 359 | } | |
| 360 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) | |
| 361 | return TCL_ERROR; | |
| 362 | list = Tcl_NewListObj(0, NULL); | |
| 15884 | 363 | for (cur = purple_account_get_status_types(account); cur != NULL; |
| 13812 | 364 | cur = g_list_next(cur)) { |
| 365 | Tcl_ListObjAppendElement(interp, list, | |
| 15884 | 366 | purple_tcl_ref_new(PurpleTclRefStatusType, |
| 13812 | 367 | cur->data)); |
| 368 | } | |
| 369 | Tcl_SetObjResult(interp, list); | |
| 370 | break; | |
| 6694 | 371 | case CMD_ACCOUNT_USERNAME: |
| 372 | if (objc != 3) { | |
| 373 | Tcl_WrongNumArgs(interp, 2, objv, "account"); | |
| 374 | return TCL_ERROR; | |
| 375 | } | |
| 13812 | 376 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 377 | return TCL_ERROR; |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
378 | Tcl_SetObjResult(interp, |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
379 | Tcl_NewStringObj((char *)purple_account_get_username(account), -1)); |
| 6694 | 380 | break; |
| 381 | } | |
| 382 | ||
| 383 | return TCL_OK; | |
| 384 | } | |
| 385 | ||
| 15884 | 386 | static PurpleBlistNode *tcl_list_to_buddy(Tcl_Interp *interp, int count, Tcl_Obj **elems) |
| 6694 | 387 | { |
| 15884 | 388 | PurpleBlistNode *node = NULL; |
| 389 | PurpleAccount *account; | |
| 6694 | 390 | char *name; |
| 391 | char *type; | |
| 392 | ||
| 393 | if (count < 3) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
394 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
395 | Tcl_NewStringObj("list too short", -1)); |
| 6694 | 396 | return NULL; |
| 397 | } | |
| 398 | ||
| 399 | type = Tcl_GetString(elems[0]); | |
| 400 | name = Tcl_GetString(elems[1]); | |
| 13812 | 401 | if ((account = tcl_validate_account(elems[2], interp)) == NULL) |
| 6694 | 402 | return NULL; |
| 403 | ||
| 404 | if (!strcmp(type, "buddy")) { | |
|
34728
8efd73063ecf
Renamed buddy list functions to more appropriate/simler names.
Ankit Vani <a@nevitus.org>
parents:
34706
diff
changeset
|
405 | node = PURPLE_BLIST_NODE(purple_blist_find_buddy(account, name)); |
| 6694 | 406 | } else if (!strcmp(type, "group")) { |
|
24974
a81952e9babb
Update some casts (that the script didn't fix correctly) to GObject macros.
Richard Laager <rlaager@pidgin.im>
parents:
24560
diff
changeset
|
407 | node = PURPLE_BLIST_NODE(purple_blist_find_chat(account, name)); |
| 6694 | 408 | } |
| 409 | ||
| 410 | return node; | |
| 411 | } | |
| 412 | ||
| 413 | int tcl_cmd_buddy(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 414 | { | |
| 6746 | 415 | Tcl_Obj *list, *tclgroup, *tclgrouplist, *tclcontact, *tclcontactlist, *tclbud, **elems, *result; |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
416 | const char *cmds[] = { "alias", "handle", "info", "list", NULL }; |
| 6694 | 417 | enum { CMD_BUDDY_ALIAS, CMD_BUDDY_HANDLE, CMD_BUDDY_INFO, CMD_BUDDY_LIST } cmd; |
| 15884 | 418 | PurpleBlistNode *node, *gnode, *bnode; |
| 419 | PurpleAccount *account; | |
| 420 | PurpleBuddy *bud; | |
| 421 | PurpleChat *cnode; | |
| 6694 | 422 | int error, all = 0, count; |
| 423 | ||
| 424 | if (objc < 2) { | |
| 425 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 426 | return TCL_ERROR; | |
| 427 | } | |
| 428 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 429 | return error; | |
| 430 | ||
| 431 | switch (cmd) { | |
| 432 | case CMD_BUDDY_ALIAS: | |
| 433 | if (objc != 3) { | |
| 434 | Tcl_WrongNumArgs(interp, 2, objv, "buddy"); | |
| 435 | return TCL_ERROR; | |
| 436 | } | |
| 437 | if ((error = Tcl_ListObjGetElements(interp, objv[2], &count, &elems)) != TCL_OK) | |
| 438 | return error; | |
| 439 | if ((node = tcl_list_to_buddy(interp, count, elems)) == NULL) | |
| 440 | return TCL_ERROR; | |
|
34695
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
441 | if (PURPLE_IS_CHAT(node)) |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
442 | Tcl_SetObjResult(interp, |
|
34740
9401f9b1ca68
Used GObject-style casts in plugins.
Ankit Vani <a@nevitus.org>
parents:
34728
diff
changeset
|
443 | Tcl_NewStringObj(purple_chat_get_name(PURPLE_CHAT(node)), -1)); |
|
34695
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
444 | else if (PURPLE_IS_BUDDY(node)) |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
445 | Tcl_SetObjResult(interp, |
|
34740
9401f9b1ca68
Used GObject-style casts in plugins.
Ankit Vani <a@nevitus.org>
parents:
34728
diff
changeset
|
446 | Tcl_NewStringObj((char *)purple_buddy_get_alias(PURPLE_BUDDY(node)), -1)); |
| 6694 | 447 | return TCL_OK; |
| 448 | break; | |
| 449 | case CMD_BUDDY_HANDLE: | |
| 450 | if (objc != 2) { | |
| 451 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 452 | return TCL_ERROR; | |
| 453 | } | |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
454 | Tcl_SetObjResult(interp, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
455 | purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
456 | purple_blist_get_handle())); |
| 6694 | 457 | break; |
| 458 | case CMD_BUDDY_INFO: | |
| 459 | if (objc != 3 && objc != 4) { | |
| 460 | Tcl_WrongNumArgs(interp, 2, objv, "( buddy | account username )"); | |
| 461 | return TCL_ERROR; | |
| 462 | } | |
| 463 | if (objc == 3) { | |
| 464 | if ((error = Tcl_ListObjGetElements(interp, objv[2], &count, &elems)) != TCL_OK) | |
| 465 | return error; | |
| 466 | if (count < 3) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
467 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
468 | Tcl_NewStringObj("buddy too short", -1)); |
| 6694 | 469 | return TCL_ERROR; |
| 470 | } | |
| 471 | if (strcmp("buddy", Tcl_GetString(elems[0]))) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
472 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
473 | Tcl_NewStringObj("invalid buddy", -1)); |
| 6694 | 474 | return TCL_ERROR; |
| 475 | } | |
| 13812 | 476 | if ((account = tcl_validate_account(elems[2], interp)) == NULL) |
| 6694 | 477 | return TCL_ERROR; |
| 15884 | 478 | serv_get_info(purple_account_get_connection(account), Tcl_GetString(elems[1])); |
| 6694 | 479 | } else { |
| 13812 | 480 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 6694 | 481 | return TCL_ERROR; |
| 15884 | 482 | serv_get_info(purple_account_get_connection(account), Tcl_GetString(objv[3])); |
| 6694 | 483 | } |
| 484 | break; | |
| 485 | case CMD_BUDDY_LIST: | |
| 486 | if (objc == 3) { | |
| 487 | if (!strcmp("-all", Tcl_GetString(objv[2]))) { | |
| 488 | all = 1; | |
| 489 | } else { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
490 | result = Tcl_NewStringObj("",-1); |
| 6694 | 491 | Tcl_AppendStringsToObj(result, "unknown option: ", Tcl_GetString(objv[2]), NULL); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
492 | Tcl_SetObjResult(interp,result); |
| 6694 | 493 | return TCL_ERROR; |
| 494 | } | |
| 495 | } | |
| 496 | list = Tcl_NewListObj(0, NULL); | |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
497 | for (gnode = purple_blist_get_root(); gnode != NULL; gnode = purple_blist_node_get_sibling_next(gnode)) { |
| 6694 | 498 | tclgroup = Tcl_NewListObj(0, NULL); |
| 499 | Tcl_ListObjAppendElement(interp, tclgroup, Tcl_NewStringObj("group", -1)); | |
| 500 | Tcl_ListObjAppendElement(interp, tclgroup, | |
|
34740
9401f9b1ca68
Used GObject-style casts in plugins.
Ankit Vani <a@nevitus.org>
parents:
34728
diff
changeset
|
501 | Tcl_NewStringObj(purple_group_get_name(PURPLE_GROUP(gnode)), -1)); |
| 6694 | 502 | tclgrouplist = Tcl_NewListObj(0, NULL); |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
503 | for (node = purple_blist_node_get_first_child(gnode); node != NULL; node = purple_blist_node_get_sibling_next(node)) { |
|
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
504 | PurpleAccount *account; |
|
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
505 | |
|
34695
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
506 | if (PURPLE_IS_CONTACT(node)) { |
| 6746 | 507 | tclcontact = Tcl_NewListObj(0, NULL); |
| 508 | Tcl_IncrRefCount(tclcontact); | |
| 509 | Tcl_ListObjAppendElement(interp, tclcontact, Tcl_NewStringObj("contact", -1)); | |
| 510 | tclcontactlist = Tcl_NewListObj(0, NULL); | |
| 511 | Tcl_IncrRefCount(tclcontactlist); | |
| 512 | count = 0; | |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
513 | for (bnode = purple_blist_node_get_first_child(node); bnode != NULL; bnode = purple_blist_node_get_sibling_next(bnode)) { |
|
34695
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
514 | if (!PURPLE_IS_BUDDY(bnode)) |
| 6746 | 515 | continue; |
|
34740
9401f9b1ca68
Used GObject-style casts in plugins.
Ankit Vani <a@nevitus.org>
parents:
34728
diff
changeset
|
516 | bud = PURPLE_BUDDY(bnode); |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
517 | account = purple_buddy_get_account(bud); |
|
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
518 | if (!all && !purple_account_is_connected(account)) |
| 6746 | 519 | continue; |
| 520 | count++; | |
| 521 | tclbud = Tcl_NewListObj(0, NULL); | |
| 522 | Tcl_ListObjAppendElement(interp, tclbud, Tcl_NewStringObj("buddy", -1)); | |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
523 | Tcl_ListObjAppendElement(interp, tclbud, Tcl_NewStringObj(purple_buddy_get_name(bud), -1)); |
|
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
524 | Tcl_ListObjAppendElement(interp, tclbud, purple_tcl_ref_new(PurpleTclRefAccount, account)); |
| 6746 | 525 | Tcl_ListObjAppendElement(interp, tclcontactlist, tclbud); |
| 526 | } | |
| 527 | if (count) { | |
| 528 | Tcl_ListObjAppendElement(interp, tclcontact, tclcontactlist); | |
| 529 | Tcl_ListObjAppendElement(interp, tclgrouplist, tclcontact); | |
| 530 | } | |
| 531 | Tcl_DecrRefCount(tclcontact); | |
| 532 | Tcl_DecrRefCount(tclcontactlist); | |
|
34695
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
533 | } else if (PURPLE_IS_CHAT(node)) { |
|
34740
9401f9b1ca68
Used GObject-style casts in plugins.
Ankit Vani <a@nevitus.org>
parents:
34728
diff
changeset
|
534 | cnode = PURPLE_CHAT(node); |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
535 | account = purple_chat_get_account(cnode); |
|
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
536 | if (!all && !purple_account_is_connected(account)) |
| 6694 | 537 | continue; |
| 538 | tclbud = Tcl_NewListObj(0, NULL); | |
| 539 | Tcl_ListObjAppendElement(interp, tclbud, Tcl_NewStringObj("chat", -1)); | |
|
24556
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
540 | Tcl_ListObjAppendElement(interp, tclbud, Tcl_NewStringObj(purple_chat_get_name(cnode), -1)); |
|
8c9cf439084a
Fix Tcl to compile with the hidden structs.
Richard Laager <rlaager@pidgin.im>
parents:
22353
diff
changeset
|
541 | Tcl_ListObjAppendElement(interp, tclbud, purple_tcl_ref_new(PurpleTclRefAccount, account)); |
| 6746 | 542 | Tcl_ListObjAppendElement(interp, tclgrouplist, tclbud); |
|
34695
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
543 | } else { |
|
60a278f1365b
Refactored libpurple plugins with initial GObject blist API
Ankit Vani <a@nevitus.org>
parents:
34655
diff
changeset
|
544 | purple_debug(PURPLE_DEBUG_WARNING, "tcl", "Unexpected buddy type %s", G_OBJECT_TYPE_NAME(node)); |
| 6694 | 545 | continue; |
| 546 | } | |
| 547 | } | |
| 548 | Tcl_ListObjAppendElement(interp, tclgroup, tclgrouplist); | |
| 549 | Tcl_ListObjAppendElement(interp, list, tclgroup); | |
| 550 | } | |
| 551 | Tcl_SetObjResult(interp, list); | |
| 552 | break; | |
| 553 | } | |
| 554 | ||
| 555 | return TCL_OK; | |
| 556 | } | |
| 557 | ||
| 13847 | 558 | int tcl_cmd_cmd(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
| 559 | { | |
|
19726
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
560 | const char *cmds[] = { "do", "help", "list", "register", "unregister", NULL }; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
561 | enum { CMD_CMD_DO, CMD_CMD_HELP, CMD_CMD_LIST, CMD_CMD_REGISTER, CMD_CMD_UNREGISTER } cmd; |
| 13847 | 562 | struct tcl_cmd_handler *handler; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
563 | Tcl_Obj *list, *elem; |
|
19726
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
564 | PurpleConversation *convo; |
| 15884 | 565 | PurpleCmdId id; |
|
19726
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
566 | PurpleCmdStatus status; |
| 13847 | 567 | int error; |
|
19726
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
568 | GList *l, *cur; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
569 | gchar *escaped, *errstr = NULL; |
| 13847 | 570 | |
| 571 | if (objc < 2) { | |
| 572 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 573 | return TCL_ERROR; | |
| 574 | } | |
| 575 | ||
| 576 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 577 | return error; | |
| 578 | ||
| 579 | switch (cmd) { | |
|
19726
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
580 | case CMD_CMD_DO: |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
581 | if (objc != 4) { |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
582 | Tcl_WrongNumArgs(interp, 2, objv, "conversation command"); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
583 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
584 | } |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
585 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
586 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
587 | escaped = g_markup_escape_text(Tcl_GetString(objv[3]), -1); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
588 | status = purple_cmd_do_command(convo, Tcl_GetString(objv[3]), |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
589 | escaped, &errstr); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
590 | g_free(escaped); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
591 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
592 | Tcl_NewStringObj(errstr ? (char *)errstr : "", -1)); |
|
19726
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
593 | g_free(errstr); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
594 | if (status != PURPLE_CMD_STATUS_OK) { |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
595 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
596 | } |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
597 | break; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
598 | case CMD_CMD_HELP: |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
599 | if (objc != 4) { |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
600 | Tcl_WrongNumArgs(interp, 2, objv, "conversation name"); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
601 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
602 | } |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
603 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
604 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
605 | l = cur = purple_cmd_help(convo, Tcl_GetString(objv[3])); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
606 | list = Tcl_NewListObj(0, NULL); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
607 | while (cur != NULL) { |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
608 | elem = Tcl_NewStringObj((char *)cur->data, -1); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
609 | Tcl_ListObjAppendElement(interp, list, elem); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
610 | cur = g_list_next(cur); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
611 | } |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
612 | g_list_free(l); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
613 | Tcl_SetObjResult(interp, list); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
614 | break; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
615 | case CMD_CMD_LIST: |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
616 | if (objc != 3) { |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
617 | Tcl_WrongNumArgs(interp, 2, objv, "conversation"); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
618 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
619 | } |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
620 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
621 | return TCL_ERROR; |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
622 | l = cur = purple_cmd_list(convo); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
623 | list = Tcl_NewListObj(0, NULL); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
624 | while (cur != NULL) { |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
625 | elem = Tcl_NewStringObj((char *)cur->data, -1); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
626 | Tcl_ListObjAppendElement(interp, list, elem); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
627 | cur = g_list_next(cur); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
628 | } |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
629 | g_list_free(l); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
630 | Tcl_SetObjResult(interp, list); |
|
22a31d50bab5
Patch from Dossy Shiobara which improves Tcl support for purple
Ethan Blanton <elb@pidgin.im>
parents:
18190
diff
changeset
|
631 | break; |
| 13847 | 632 | case CMD_CMD_REGISTER: |
| 633 | if (objc != 9) { | |
|
36545
23b59a16c808
Replaced some _prpl_ stuff with _protocol_
Ankit Vani <a@nevitus.org>
parents:
34864
diff
changeset
|
634 | Tcl_WrongNumArgs(interp, 2, objv, "cmd arglist priority flags protocol_id proc helpstr"); |
| 13847 | 635 | return TCL_ERROR; |
| 636 | } | |
| 637 | handler = g_new0(struct tcl_cmd_handler, 1); | |
| 638 | handler->cmd = objv[2]; | |
| 639 | handler->args = Tcl_GetString(objv[3]); | |
| 640 | handler->nargs = strlen(handler->args); | |
| 641 | if ((error = Tcl_GetIntFromObj(interp, objv[4], | |
| 642 | &handler->priority)) != TCL_OK) { | |
| 643 | g_free(handler); | |
| 644 | return error; | |
| 645 | } | |
| 646 | if ((error = Tcl_GetIntFromObj(interp, objv[5], | |
| 647 | &handler->flags)) != TCL_OK) { | |
| 648 | g_free(handler); | |
| 649 | return error; | |
| 650 | } | |
|
36545
23b59a16c808
Replaced some _prpl_ stuff with _protocol_
Ankit Vani <a@nevitus.org>
parents:
34864
diff
changeset
|
651 | handler->protocol_id = Tcl_GetString(objv[6]); |
| 13847 | 652 | handler->proc = objv[7]; |
| 653 | handler->helpstr = Tcl_GetString(objv[8]); | |
| 654 | handler->interp = interp; | |
| 655 | if ((id = tcl_cmd_register(handler)) == 0) { | |
| 656 | tcl_cmd_handler_free(handler); | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
657 | Tcl_SetObjResult(interp, Tcl_NewIntObj(0)); |
| 13847 | 658 | } else { |
| 659 | handler->id = id; | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
660 | Tcl_SetObjResult(interp, Tcl_NewIntObj(id)); |
| 13847 | 661 | } |
| 662 | break; | |
| 663 | case CMD_CMD_UNREGISTER: | |
| 664 | if (objc != 3) { | |
| 665 | Tcl_WrongNumArgs(interp, 2, objv, "id"); | |
| 666 | return TCL_ERROR; | |
| 667 | } | |
| 668 | if ((error = Tcl_GetIntFromObj(interp, objv[2], | |
| 669 | (int *)&id)) != TCL_OK) | |
| 670 | return error; | |
| 671 | tcl_cmd_unregister(id, interp); | |
| 672 | break; | |
| 673 | } | |
| 674 | ||
| 675 | return TCL_OK; | |
| 676 | } | |
| 677 | ||
| 6694 | 678 | int tcl_cmd_connection(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
| 679 | { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
680 | Tcl_Obj *list, *elem; |
|
26824
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
681 | const char *cmds[] = { "account", "displayname", "handle", "list", "state", NULL }; |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
682 | enum { CMD_CONN_ACCOUNT, CMD_CONN_DISPLAYNAME, CMD_CONN_HANDLE, |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
683 | CMD_CONN_LIST, CMD_CONN_STATE } cmd; |
| 6694 | 684 | int error; |
|
18122
9bf9970c1b6a
disapproval of revision '2d8ea56b90971e7851442d96b7d74ecb4f052126'
Richard Laager <rlaager@pidgin.im>
parents:
18121
diff
changeset
|
685 | GList *cur; |
| 15884 | 686 | PurpleConnection *gc; |
| 6694 | 687 | |
| 688 | if (objc < 2) { | |
| 689 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 690 | return TCL_ERROR; | |
| 691 | } | |
| 692 | ||
| 693 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 694 | return error; | |
| 695 | ||
| 696 | switch (cmd) { | |
| 697 | case CMD_CONN_ACCOUNT: | |
| 698 | if (objc != 3) { | |
|
6864
359bc55e767f
[gaim-migrate @ 7410]
Björn Voigt <bjoern@cs.tu-berlin.de>
parents:
6746
diff
changeset
|
699 | Tcl_WrongNumArgs(interp, 2, objv, "gc"); |
| 6694 | 700 | return TCL_ERROR; |
| 701 | } | |
| 13817 | 702 | if ((gc = tcl_validate_gc(objv[2], interp)) == NULL) |
| 6694 | 703 | return TCL_ERROR; |
| 13817 | 704 | Tcl_SetObjResult(interp, |
| 15884 | 705 | purple_tcl_ref_new(PurpleTclRefAccount, |
| 706 | purple_connection_get_account(gc))); | |
| 6694 | 707 | break; |
| 7713 | 708 | case CMD_CONN_DISPLAYNAME: |
| 709 | if (objc != 3) { | |
| 710 | Tcl_WrongNumArgs(interp, 2, objv, "gc"); | |
| 711 | return TCL_ERROR; | |
| 712 | } | |
| 13817 | 713 | if ((gc = tcl_validate_gc(objv[2], interp)) == NULL) |
| 7713 | 714 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
715 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
716 | Tcl_NewStringObj(purple_connection_get_display_name(gc), -1)); |
| 7713 | 717 | break; |
| 6694 | 718 | case CMD_CONN_HANDLE: |
| 719 | if (objc != 2) { | |
| 720 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 721 | return TCL_ERROR; | |
| 722 | } | |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
723 | Tcl_SetObjResult(interp, purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
724 | purple_connections_get_handle())); |
| 6694 | 725 | break; |
| 726 | case CMD_CONN_LIST: | |
| 727 | if (objc != 2) { | |
| 728 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 729 | return TCL_ERROR; | |
| 730 | } | |
| 731 | list = Tcl_NewListObj(0, NULL); | |
| 15884 | 732 | for (cur = purple_connections_get_all(); cur != NULL; cur = g_list_next(cur)) { |
| 733 | elem = purple_tcl_ref_new(PurpleTclRefConnection, cur->data); | |
| 6694 | 734 | Tcl_ListObjAppendElement(interp, list, elem); |
| 735 | } | |
| 736 | Tcl_SetObjResult(interp, list); | |
| 737 | break; | |
|
26824
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
738 | case CMD_CONN_STATE: |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
739 | if (objc != 3) { |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
740 | Tcl_WrongNumArgs(interp, 2, objv, "gc"); |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
741 | return TCL_ERROR; |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
742 | } |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
743 | if ((gc = tcl_validate_gc(objv[2], interp)) == NULL) |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
744 | return TCL_ERROR; |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
745 | switch (purple_connection_get_state(gc)) { |
|
34746
dc9c911dbd35
Started GObjectification of PurpleConnection.
Ankit Vani <a@nevitus.org>
parents:
34740
diff
changeset
|
746 | case PURPLE_CONNECTION_DISCONNECTED: |
|
26824
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
747 | Tcl_SetObjResult(interp, Tcl_NewStringObj("disconnected", -1)); |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
748 | break; |
|
34746
dc9c911dbd35
Started GObjectification of PurpleConnection.
Ankit Vani <a@nevitus.org>
parents:
34740
diff
changeset
|
749 | case PURPLE_CONNECTION_CONNECTED: |
|
26824
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
750 | Tcl_SetObjResult(interp, Tcl_NewStringObj("connected", -1)); |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
751 | break; |
|
34746
dc9c911dbd35
Started GObjectification of PurpleConnection.
Ankit Vani <a@nevitus.org>
parents:
34740
diff
changeset
|
752 | case PURPLE_CONNECTION_CONNECTING: |
|
26824
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
753 | Tcl_SetObjResult(interp, Tcl_NewStringObj("connecting", -1)); |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
754 | break; |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
755 | } |
|
c7ba07f9ca42
Add the Tcl command purple::connection state (purple_connection_get_state).
Ethan Blanton <elb@pidgin.im>
parents:
25913
diff
changeset
|
756 | break; |
| 6694 | 757 | } |
| 758 | ||
| 759 | return TCL_OK; | |
| 760 | } | |
| 761 | ||
| 762 | int tcl_cmd_conversation(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 763 | { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
764 | Tcl_Obj *list, *elem; |
| 14425 | 765 | const char *cmds[] = { "find", "handle", "list", "new", "write", "name", "title", "send", NULL }; |
| 766 | enum { CMD_CONV_FIND, CMD_CONV_HANDLE, CMD_CONV_LIST, CMD_CONV_NEW, CMD_CONV_WRITE , CMD_CONV_NAME, CMD_CONV_TITLE, CMD_CONV_SEND } cmd; | |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
767 | const char *styles[] = { "send", "recv", "system", NULL }; |
| 6694 | 768 | enum { CMD_CONV_WRITE_SEND, CMD_CONV_WRITE_RECV, CMD_CONV_WRITE_SYSTEM } style; |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
769 | const char *newopts[] = { "-chat", "-im" }; |
| 6694 | 770 | enum { CMD_CONV_NEW_CHAT, CMD_CONV_NEW_IM } newopt; |
| 15884 | 771 | PurpleConversation *convo; |
| 772 | PurpleAccount *account; | |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
773 | gboolean is_chat = FALSE; |
|
18122
9bf9970c1b6a
disapproval of revision '2d8ea56b90971e7851442d96b7d74ecb4f052126'
Richard Laager <rlaager@pidgin.im>
parents:
18121
diff
changeset
|
774 | GList *cur; |
| 6694 | 775 | char *opt, *from, *what; |
| 7156 | 776 | int error, argsused, flags = 0; |
| 6694 | 777 | |
| 778 | if (objc < 2) { | |
| 779 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 780 | return TCL_ERROR; | |
| 781 | } | |
| 782 | ||
| 783 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 784 | return error; | |
| 785 | ||
| 786 | switch (cmd) { | |
| 787 | case CMD_CONV_FIND: | |
| 10829 | 788 | if (objc != 4) { |
| 789 | Tcl_WrongNumArgs(interp, 2, objv, "account name"); | |
| 6694 | 790 | return TCL_ERROR; |
| 791 | } | |
| 792 | account = NULL; | |
| 13812 | 793 | if ((account = tcl_validate_account(objv[2], interp)) == NULL) |
| 10829 | 794 | return TCL_ERROR; |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
795 | convo = purple_conversations_find_with_account(Tcl_GetString(objv[3]), |
| 10829 | 796 | account); |
| 15884 | 797 | Tcl_SetObjResult(interp, purple_tcl_ref_new(PurpleTclRefConversation, convo)); |
| 6694 | 798 | break; |
| 799 | case CMD_CONV_HANDLE: | |
| 800 | if (objc != 2) { | |
| 801 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 802 | return TCL_ERROR; | |
| 803 | } | |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
804 | Tcl_SetObjResult(interp, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
805 | purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
806 | purple_conversations_get_handle())); |
| 6694 | 807 | break; |
| 808 | case CMD_CONV_LIST: | |
| 809 | list = Tcl_NewListObj(0, NULL); | |
|
34655
6a939719ea98
Replaced purple_conversations_get() with purple_conversations_get_all(), similar to other purple entities
Ankit Vani <a@nevitus.org>
parents:
34632
diff
changeset
|
810 | for (cur = purple_conversations_get_all(); cur != NULL; cur = g_list_next(cur)) { |
| 15884 | 811 | elem = purple_tcl_ref_new(PurpleTclRefConversation, cur->data); |
| 6694 | 812 | Tcl_ListObjAppendElement(interp, list, elem); |
| 813 | } | |
| 814 | Tcl_SetObjResult(interp, list); | |
| 815 | break; | |
| 816 | case CMD_CONV_NEW: | |
| 817 | if (objc < 4) { | |
| 818 | Tcl_WrongNumArgs(interp, 2, objv, "?options? account name"); | |
| 819 | return TCL_ERROR; | |
| 820 | } | |
| 821 | argsused = 2; | |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
822 | is_chat = FALSE; |
| 6694 | 823 | while (argsused < objc) { |
| 824 | opt = Tcl_GetString(objv[argsused]); | |
| 825 | if (*opt == '-') { | |
| 826 | if ((error = Tcl_GetIndexFromObj(interp, objv[argsused], newopts, | |
| 827 | "option", 0, (int *)&newopt)) != TCL_OK) | |
| 828 | return error; | |
| 829 | argsused++; | |
| 830 | switch (newopt) { | |
| 831 | case CMD_CONV_NEW_CHAT: | |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
832 | is_chat = TRUE; |
| 6694 | 833 | break; |
| 834 | case CMD_CONV_NEW_IM: | |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
835 | is_chat = FALSE; |
| 6694 | 836 | break; |
| 837 | } | |
| 838 | } else { | |
| 839 | break; | |
| 840 | } | |
| 841 | } | |
| 842 | if (objc - argsused != 2) { | |
| 843 | Tcl_WrongNumArgs(interp, 2, objv, "?options? account name"); | |
| 844 | return TCL_ERROR; | |
| 845 | } | |
| 13812 | 846 | if ((account = tcl_validate_account(objv[argsused++], interp)) == NULL) |
| 6694 | 847 | return TCL_ERROR; |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
848 | if (is_chat) |
|
34632
ebe6b2a60305
Changed all arguments and return types of Chat and IMs to PurpleChatConversation and PurpleIMConversation.
Ankit Vani <a@nevitus.org>
parents:
34620
diff
changeset
|
849 | convo = PURPLE_CONVERSATION(purple_chat_conversation_new(account, Tcl_GetString(objv[argsused]))); |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
850 | else |
|
34632
ebe6b2a60305
Changed all arguments and return types of Chat and IMs to PurpleChatConversation and PurpleIMConversation.
Ankit Vani <a@nevitus.org>
parents:
34620
diff
changeset
|
851 | convo = PURPLE_CONVERSATION(purple_im_conversation_new(account, Tcl_GetString(objv[argsused]))); |
| 15884 | 852 | Tcl_SetObjResult(interp, purple_tcl_ref_new(PurpleTclRefConversation, convo)); |
| 6694 | 853 | break; |
| 854 | case CMD_CONV_WRITE: | |
| 855 | if (objc != 6) { | |
| 856 | Tcl_WrongNumArgs(interp, 2, objv, "conversation style from what"); | |
| 857 | return TCL_ERROR; | |
| 858 | } | |
| 13812 | 859 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) |
| 860 | return TCL_ERROR; | |
| 6694 | 861 | if ((error = Tcl_GetIndexFromObj(interp, objv[3], styles, "style", 0, (int *)&style)) != TCL_OK) |
| 862 | return error; | |
| 863 | from = Tcl_GetString(objv[4]); | |
| 864 | what = Tcl_GetString(objv[5]); | |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
865 | |
| 6694 | 866 | switch (style) { |
| 867 | case CMD_CONV_WRITE_SEND: | |
| 15884 | 868 | flags = PURPLE_MESSAGE_SEND; |
| 6694 | 869 | break; |
| 870 | case CMD_CONV_WRITE_RECV: | |
| 15884 | 871 | flags = PURPLE_MESSAGE_RECV; |
| 6694 | 872 | break; |
| 873 | case CMD_CONV_WRITE_SYSTEM: | |
| 15884 | 874 | flags = PURPLE_MESSAGE_SYSTEM; |
| 6694 | 875 | break; |
| 876 | } | |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
877 | purple_conversation_write_message(convo, from, what, flags, time(NULL)); |
| 14357 | 878 | case CMD_CONV_NAME: |
| 879 | if (objc != 3) { | |
| 880 | Tcl_WrongNumArgs(interp, 2, objv, "conversation"); | |
| 881 | return TCL_ERROR; | |
| 882 | } | |
| 883 | ||
| 884 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) | |
| 885 | return TCL_ERROR; | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
886 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
887 | Tcl_NewStringObj((char *)purple_conversation_get_name(convo), -1)); |
| 14357 | 888 | break; |
| 889 | case CMD_CONV_TITLE: | |
| 890 | if (objc != 3) { | |
| 891 | Tcl_WrongNumArgs(interp, 2, objv, "conversation"); | |
| 892 | return TCL_ERROR; | |
| 893 | } | |
| 894 | ||
| 895 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) | |
| 896 | return TCL_ERROR; | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
897 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
898 | Tcl_NewStringObj((char *)purple_conversation_get_title(convo), -1)); |
| 14357 | 899 | break; |
| 14425 | 900 | case CMD_CONV_SEND: |
| 901 | if (objc != 4) { | |
| 902 | Tcl_WrongNumArgs(interp, 2, objv, "conversation message"); | |
| 903 | return TCL_ERROR; | |
| 904 | } | |
| 905 | if ((convo = tcl_validate_conversation(objv[2], interp)) == NULL) | |
| 906 | return TCL_ERROR; | |
| 907 | what = Tcl_GetString(objv[3]); | |
|
34618
949097b6b371
Refactored libpurple/plugins/tcl to use GObject-based PurpleConversation
Ankit Vani <a@nevitus.org>
parents:
34589
diff
changeset
|
908 | purple_conversation_send(convo, what); |
| 14425 | 909 | break; |
| 6694 | 910 | } |
| 911 | ||
| 912 | return TCL_OK; | |
| 913 | } | |
| 914 | ||
| 915 | int tcl_cmd_core(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 916 | { | |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
917 | const char *cmds[] = { "handle", "quit", NULL }; |
| 6694 | 918 | enum { CMD_CORE_HANDLE, CMD_CORE_QUIT } cmd; |
| 919 | int error; | |
| 920 | ||
| 921 | if (objc < 2) { | |
| 922 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 923 | return TCL_ERROR; | |
| 924 | } | |
| 925 | ||
| 926 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 927 | return error; | |
| 928 | ||
| 929 | switch (cmd) { | |
| 930 | case CMD_CORE_HANDLE: | |
| 931 | if (objc != 2) { | |
| 932 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 933 | return TCL_ERROR; | |
| 934 | } | |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
935 | Tcl_SetObjResult(interp, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
936 | purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
937 | purple_get_core())); |
| 6694 | 938 | break; |
| 939 | case CMD_CORE_QUIT: | |
| 940 | if (objc != 2) { | |
| 941 | Tcl_WrongNumArgs(interp, 2, objv, ""); | |
| 942 | return TCL_ERROR; | |
| 943 | } | |
| 15884 | 944 | purple_core_quit(); |
| 6694 | 945 | break; |
| 946 | } | |
| 947 | ||
| 948 | return TCL_OK; | |
| 949 | } | |
| 950 | ||
| 951 | int tcl_cmd_debug(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 952 | { | |
| 953 | char *category, *message; | |
| 954 | int lev; | |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
955 | const char *levels[] = { "-misc", "-info", "-warning", "-error", NULL }; |
| 15884 | 956 | PurpleDebugLevel levelind[] = { PURPLE_DEBUG_MISC, PURPLE_DEBUG_INFO, PURPLE_DEBUG_WARNING, PURPLE_DEBUG_ERROR }; |
| 6694 | 957 | int error; |
| 958 | ||
| 959 | if (objc != 4) { | |
| 960 | Tcl_WrongNumArgs(interp, 1, objv, "level category message"); | |
| 961 | return TCL_ERROR; | |
| 962 | } | |
| 963 | ||
| 964 | error = Tcl_GetIndexFromObj(interp, objv[1], levels, "debug level", 0, &lev); | |
| 965 | if (error != TCL_OK) | |
| 966 | return error; | |
| 967 | ||
| 968 | category = Tcl_GetString(objv[2]); | |
| 969 | message = Tcl_GetString(objv[3]); | |
| 970 | ||
| 15884 | 971 | purple_debug(levelind[lev], category, "%s\n", message); |
| 6694 | 972 | |
| 973 | return TCL_OK; | |
| 974 | } | |
| 975 | ||
| 976 | int tcl_cmd_notify(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 977 | { | |
| 978 | int error, type; | |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
979 | const char *opts[] = { "-error", "-warning", "-info", NULL }; |
| 15884 | 980 | PurpleNotifyMsgType optind[] = { PURPLE_NOTIFY_MSG_ERROR, PURPLE_NOTIFY_MSG_WARNING, PURPLE_NOTIFY_MSG_INFO }; |
| 6694 | 981 | char *title, *msg1, *msg2; |
| 982 | ||
| 983 | if (objc < 4 || objc > 5) { | |
| 984 | Tcl_WrongNumArgs(interp, 1, objv, "?type? title primary secondary"); | |
| 985 | return TCL_ERROR; | |
| 986 | } | |
| 987 | ||
| 988 | if (objc == 4) { | |
| 13424 | 989 | type = 1; /* Default to warning */ |
| 6694 | 990 | title = Tcl_GetString(objv[1]); |
| 991 | msg1 = Tcl_GetString(objv[2]); | |
| 992 | msg2 = Tcl_GetString(objv[3]); | |
| 993 | } else { | |
| 994 | error = Tcl_GetIndexFromObj(interp, objv[1], opts, "message type", 0, &type); | |
| 995 | if (error != TCL_OK) | |
| 996 | return error; | |
| 997 | title = Tcl_GetString(objv[2]); | |
| 998 | msg1 = Tcl_GetString(objv[3]); | |
| 999 | msg2 = Tcl_GetString(objv[4]); | |
| 1000 | } | |
| 1001 | ||
|
34449
bbcb198650b7
Notify API: extend purple_notify_message with PurpleRequestCommonParameters
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
33896
diff
changeset
|
1002 | purple_notify_message(_tcl_plugin, optind[type], title, msg1, msg2, NULL, NULL, NULL); |
| 6694 | 1003 | |
| 1004 | return TCL_OK; | |
| 1005 | } | |
| 1006 | ||
|
15750
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1007 | int tcl_cmd_plugins(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1008 | { |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1009 | const char *cmds[] = { "handle", NULL }; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1010 | enum { CMD_PLUGINS_HANDLE } cmd; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1011 | int error; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1012 | |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1013 | if (objc < 2) { |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1014 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1015 | return TCL_ERROR; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1016 | } |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1017 | |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1018 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1019 | return error; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1020 | |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1021 | switch (cmd) { |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1022 | case CMD_PLUGINS_HANDLE: |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1023 | if (objc != 2) { |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1024 | Tcl_WrongNumArgs(interp, 2, objv, ""); |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1025 | return TCL_ERROR; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1026 | } |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1027 | Tcl_SetObjResult(interp, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1028 | purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1029 | purple_plugins_get_handle())); |
|
15750
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1030 | break; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1031 | } |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1032 | |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1033 | return TCL_OK; |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1034 | } |
|
c238e0966eb1
gaim::plugin Tcl command, thanks to Dossy Shiobara
Ethan Blanton <elb@pidgin.im>
parents:
15435
diff
changeset
|
1035 | |
| 6694 | 1036 | int tcl_cmd_prefs(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
| 1037 | { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1038 | Tcl_Obj *list, *elem, **elems; |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
1039 | const char *cmds[] = { "get", "set", "type", NULL }; |
| 6694 | 1040 | enum { CMD_PREFS_GET, CMD_PREFS_SET, CMD_PREFS_TYPE } cmd; |
| 1041 | /* char *types[] = { "none", "boolean", "int", "string", "stringlist", NULL }; */ | |
| 1042 | /* enum { TCL_PREFS_NONE, TCL_PREFS_BOOL, TCL_PREFS_INT, TCL_PREFS_STRING, TCL_PREFS_STRINGLIST } type; */ | |
| 15884 | 1043 | PurplePrefType preftype; |
| 6694 | 1044 | GList *cur; |
| 1045 | int error, intval, nelem, i; | |
| 1046 | ||
| 1047 | if (objc < 2) { | |
| 1048 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 1049 | return TCL_ERROR; | |
| 1050 | } | |
| 1051 | ||
| 1052 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 1053 | return error; | |
| 1054 | ||
| 1055 | switch (cmd) { | |
| 1056 | case CMD_PREFS_GET: | |
| 1057 | if (objc != 3) { | |
| 1058 | Tcl_WrongNumArgs(interp, 1, objv, "path"); | |
| 1059 | return TCL_ERROR; | |
| 1060 | } | |
|
35378
5d9e2581005b
gtk-doc prep: *_get_type() functions are hidden as standard GType-returning funcs, so rename them.
Ankit Vani <a@nevitus.org>
parents:
34955
diff
changeset
|
1061 | preftype = purple_prefs_get_pref_type(Tcl_GetString(objv[2])); |
| 6694 | 1062 | switch (preftype) { |
| 15884 | 1063 | case PURPLE_PREF_NONE: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1064 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1065 | Tcl_NewStringObj("pref type none", -1)); |
| 6694 | 1066 | return TCL_ERROR; |
| 1067 | break; | |
| 15884 | 1068 | case PURPLE_PREF_BOOLEAN: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1069 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1070 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1071 | purple_prefs_get_bool(Tcl_GetString(objv[2])))); |
| 6694 | 1072 | break; |
| 15884 | 1073 | case PURPLE_PREF_INT: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1074 | Tcl_SetObjResult(interp, Tcl_NewIntObj(purple_prefs_get_int(Tcl_GetString(objv[2])))); |
| 6694 | 1075 | break; |
| 15884 | 1076 | case PURPLE_PREF_STRING: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1077 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1078 | Tcl_NewStringObj((char *)purple_prefs_get_string(Tcl_GetString(objv[2])), -1)); |
| 6694 | 1079 | break; |
| 15884 | 1080 | case PURPLE_PREF_STRING_LIST: |
| 1081 | cur = purple_prefs_get_string_list(Tcl_GetString(objv[2])); | |
| 6694 | 1082 | list = Tcl_NewListObj(0, NULL); |
| 1083 | while (cur != NULL) { | |
| 1084 | elem = Tcl_NewStringObj((char *)cur->data, -1); | |
| 1085 | Tcl_ListObjAppendElement(interp, list, elem); | |
|
22240
3f3d4ff9f323
disapproval of revision 'b2c07c730315e96101dd0371133d170396333f4c'
Etan Reisner <deryni@pidgin.im>
parents:
22239
diff
changeset
|
1086 | cur = g_list_next(cur); |
| 6694 | 1087 | } |
| 1088 | Tcl_SetObjResult(interp, list); | |
| 1089 | break; | |
| 1090 | default: | |
| 15884 | 1091 | purple_debug(PURPLE_DEBUG_ERROR, "tcl", "tcl does not know about pref type %d\n", preftype); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1092 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1093 | Tcl_NewStringObj("unknown pref type", -1)); |
| 6694 | 1094 | return TCL_ERROR; |
| 1095 | } | |
| 1096 | break; | |
| 1097 | case CMD_PREFS_SET: | |
| 1098 | if (objc != 4) { | |
| 1099 | Tcl_WrongNumArgs(interp, 1, objv, "path value"); | |
| 1100 | return TCL_ERROR; | |
| 1101 | } | |
|
35378
5d9e2581005b
gtk-doc prep: *_get_type() functions are hidden as standard GType-returning funcs, so rename them.
Ankit Vani <a@nevitus.org>
parents:
34955
diff
changeset
|
1102 | preftype = purple_prefs_get_pref_type(Tcl_GetString(objv[2])); |
| 6694 | 1103 | switch (preftype) { |
| 15884 | 1104 | case PURPLE_PREF_NONE: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1105 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1106 | Tcl_NewStringObj("bad path or pref type none", -1)); |
| 6694 | 1107 | return TCL_ERROR; |
| 1108 | break; | |
| 15884 | 1109 | case PURPLE_PREF_BOOLEAN: |
| 6694 | 1110 | if ((error = Tcl_GetBooleanFromObj(interp, objv[3], &intval)) != TCL_OK) |
| 1111 | return error; | |
| 15884 | 1112 | purple_prefs_set_bool(Tcl_GetString(objv[2]), intval); |
| 6694 | 1113 | break; |
| 15884 | 1114 | case PURPLE_PREF_INT: |
| 6694 | 1115 | if ((error = Tcl_GetIntFromObj(interp, objv[3], &intval)) != TCL_OK) |
| 1116 | return error; | |
| 15884 | 1117 | purple_prefs_set_int(Tcl_GetString(objv[2]), intval); |
| 6694 | 1118 | break; |
| 15884 | 1119 | case PURPLE_PREF_STRING: |
| 1120 | purple_prefs_set_string(Tcl_GetString(objv[2]), Tcl_GetString(objv[3])); | |
| 6694 | 1121 | break; |
| 15884 | 1122 | case PURPLE_PREF_STRING_LIST: |
| 6694 | 1123 | if ((error = Tcl_ListObjGetElements(interp, objv[3], &nelem, &elems)) != TCL_OK) |
| 1124 | return error; | |
| 1125 | cur = NULL; | |
| 1126 | for (i = 0; i < nelem; i++) { | |
| 1127 | cur = g_list_append(cur, (gpointer)Tcl_GetString(elems[i])); | |
| 1128 | } | |
| 15884 | 1129 | purple_prefs_set_string_list(Tcl_GetString(objv[2]), cur); |
| 6694 | 1130 | g_list_free(cur); |
| 1131 | break; | |
| 1132 | default: | |
| 15884 | 1133 | purple_debug(PURPLE_DEBUG_ERROR, "tcl", "tcl does not know about pref type %d\n", preftype); |
| 6694 | 1134 | return TCL_ERROR; |
| 1135 | } | |
| 1136 | break; | |
| 1137 | case CMD_PREFS_TYPE: | |
| 1138 | if (objc != 3) { | |
| 1139 | Tcl_WrongNumArgs(interp, 1, objv, "path"); | |
| 1140 | return TCL_ERROR; | |
| 1141 | } | |
|
35378
5d9e2581005b
gtk-doc prep: *_get_type() functions are hidden as standard GType-returning funcs, so rename them.
Ankit Vani <a@nevitus.org>
parents:
34955
diff
changeset
|
1142 | preftype = purple_prefs_get_pref_type(Tcl_GetString(objv[2])); |
| 6694 | 1143 | switch (preftype) { |
| 15884 | 1144 | case PURPLE_PREF_NONE: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1145 | Tcl_SetObjResult(interp, Tcl_NewStringObj("none", -1)); |
| 6694 | 1146 | break; |
| 15884 | 1147 | case PURPLE_PREF_BOOLEAN: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1148 | Tcl_SetObjResult(interp, Tcl_NewStringObj("boolean", -1)); |
| 6694 | 1149 | break; |
| 15884 | 1150 | case PURPLE_PREF_INT: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1151 | Tcl_SetObjResult(interp, Tcl_NewStringObj("int", -1)); |
| 6694 | 1152 | break; |
| 15884 | 1153 | case PURPLE_PREF_STRING: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1154 | Tcl_SetObjResult(interp, Tcl_NewStringObj("string", -1)); |
| 6694 | 1155 | break; |
| 15884 | 1156 | case PURPLE_PREF_STRING_LIST: |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1157 | Tcl_SetObjResult(interp, Tcl_NewStringObj("stringlist", -1)); |
| 6694 | 1158 | break; |
| 1159 | default: | |
| 15884 | 1160 | purple_debug(PURPLE_DEBUG_ERROR, "tcl", "tcl does not know about pref type %d\n", preftype); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1161 | Tcl_SetObjResult(interp, Tcl_NewStringObj("unknown", -1)); |
| 6694 | 1162 | } |
| 1163 | break; | |
| 1164 | } | |
| 1165 | ||
| 1166 | return TCL_OK; | |
| 1167 | } | |
| 1168 | ||
| 13823 | 1169 | int tcl_cmd_presence(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
| 1170 | { | |
| 1171 | const char *cmds[] = { "account", "active_status", "available", | |
|
34842
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1172 | "idle", "type", "login", "online", "status", |
|
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1173 | "statuses", NULL }; |
| 13823 | 1174 | enum { CMD_PRESENCE_ACCOUNT, CMD_PRESENCE_ACTIVE_STATUS, |
|
34842
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1175 | CMD_PRESENCE_AVAILABLE, CMD_PRESENCE_IDLE, CMD_PRESENCE_TYPE, |
|
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1176 | CMD_PRESENCE_LOGIN, CMD_PRESENCE_ONLINE, |
| 13823 | 1177 | CMD_PRESENCE_STATUS, CMD_PRESENCE_STATUSES } cmd; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1178 | Tcl_Obj *result; |
| 13823 | 1179 | Tcl_Obj *list, *elem; |
| 15884 | 1180 | PurplePresence *presence; |
|
18190
bcf28ef7e8ff
Re-fix the DBus list handling code by killing const GList* / const GSList*
Richard Laager <rlaager@pidgin.im>
parents:
18122
diff
changeset
|
1181 | GList *cur; |
| 13823 | 1182 | int error, idle, idle_time, login_time; |
| 1183 | ||
| 1184 | if (objc < 2) { | |
| 1185 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 1186 | return TCL_ERROR; | |
| 1187 | } | |
| 1188 | ||
| 1189 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 1190 | return error; | |
| 1191 | ||
| 1192 | switch (cmd) { | |
| 1193 | case CMD_PRESENCE_ACCOUNT: | |
| 1194 | if (objc != 3) { | |
| 1195 | Tcl_WrongNumArgs(interp, 2, objv, "presence"); | |
| 1196 | return TCL_ERROR; | |
| 1197 | } | |
| 15884 | 1198 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1199 | return TCL_ERROR; |
| 15884 | 1200 | Tcl_SetObjResult(interp, purple_tcl_ref_new(PurpleTclRefAccount, |
|
34842
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1201 | purple_account_presence_get_account(PURPLE_ACCOUNT_PRESENCE(presence)))); |
| 13823 | 1202 | break; |
| 1203 | case CMD_PRESENCE_ACTIVE_STATUS: | |
| 1204 | if (objc != 3 && objc != 4 && objc != 5) { | |
| 1205 | Tcl_WrongNumArgs(interp, 2, objv, "presence [?status_id? | ?-primitive primitive?]"); | |
| 1206 | return TCL_ERROR; | |
| 1207 | } | |
| 15884 | 1208 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1209 | return TCL_ERROR; |
| 1210 | if (objc == 3) { | |
| 1211 | Tcl_SetObjResult(interp, | |
| 15884 | 1212 | purple_tcl_ref_new(PurpleTclRefStatus, |
| 1213 | purple_presence_get_active_status(presence))); | |
| 13823 | 1214 | } else if (objc == 4) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1215 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1216 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1217 | purple_presence_is_status_active(presence, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1218 | Tcl_GetString(objv[3])))); |
| 13823 | 1219 | } else { |
| 15884 | 1220 | PurpleStatusPrimitive primitive; |
| 13823 | 1221 | if (strcmp(Tcl_GetString(objv[3]), "-primitive")) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1222 | result = Tcl_NewStringObj("bad option \"", -1); |
| 13823 | 1223 | Tcl_AppendObjToObj(result, objv[3]); |
| 1224 | Tcl_AppendToObj(result, | |
| 1225 | "\": should be -primitive", -1); | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1226 | Tcl_SetObjResult(interp,result); |
| 13823 | 1227 | return TCL_ERROR; |
| 1228 | } | |
| 15884 | 1229 | primitive = purple_primitive_get_type_from_id(Tcl_GetString(objv[4])); |
| 1230 | if (primitive == PURPLE_STATUS_UNSET) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1231 | result = Tcl_NewStringObj("invalid primitive ", -1); |
| 13823 | 1232 | Tcl_AppendObjToObj(result, objv[4]); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1233 | Tcl_SetObjResult(interp,result); |
| 13823 | 1234 | return TCL_ERROR; |
| 1235 | } | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1236 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1237 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1238 | purple_presence_is_status_primitive_active(presence, primitive))); |
| 13823 | 1239 | break; |
| 1240 | } | |
| 1241 | break; | |
| 1242 | case CMD_PRESENCE_AVAILABLE: | |
| 1243 | if (objc != 3) { | |
| 1244 | Tcl_WrongNumArgs(interp, 2, objv, "presence"); | |
| 1245 | return TCL_ERROR; | |
| 1246 | } | |
| 15884 | 1247 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1248 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1249 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1250 | Tcl_NewBooleanObj(purple_presence_is_available(presence))); |
| 13823 | 1251 | break; |
|
34842
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1252 | case CMD_PRESENCE_TYPE: |
| 13823 | 1253 | if (objc != 3) { |
| 1254 | Tcl_WrongNumArgs(interp, 2, objv, "presence"); | |
| 1255 | return TCL_ERROR; | |
| 1256 | } | |
| 15884 | 1257 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1258 | return TCL_ERROR; |
|
34842
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1259 | if (PURPLE_IS_ACCOUNT_PRESENCE(presence)) |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1260 | Tcl_SetObjResult(interp, Tcl_NewStringObj("account", -1)); |
|
34842
68373b7fdc20
Refactored libpurple plugins to use the GObject presence API
Ankit Vani <a@nevitus.org>
parents:
34838
diff
changeset
|
1261 | else if (PURPLE_IS_BUDDY_PRESENCE(presence)) |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1262 | Tcl_SetObjResult(interp, Tcl_NewStringObj("buddy", -1)); |
| 13823 | 1263 | break; |
| 1264 | case CMD_PRESENCE_IDLE: | |
| 1265 | if (objc < 3 || objc > 5) { | |
| 1266 | Tcl_WrongNumArgs(interp, 2, objv, "presence ?idle? ?time?"); | |
| 1267 | return TCL_ERROR; | |
| 1268 | } | |
| 15884 | 1269 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1270 | return TCL_ERROR; |
| 1271 | if (objc == 3) { | |
| 15884 | 1272 | if (purple_presence_is_idle(presence)) { |
| 1273 | idle_time = purple_presence_get_idle_time (presence); | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1274 | Tcl_SetObjResult(interp, Tcl_NewIntObj(idle_time)); |
| 13823 | 1275 | } else { |
| 1276 | result = Tcl_NewListObj(0, NULL); | |
| 1277 | Tcl_SetObjResult(interp, result); | |
| 1278 | } | |
| 1279 | break; | |
| 1280 | } | |
| 1281 | if ((error = Tcl_GetBooleanFromObj(interp, objv[3], &idle)) != TCL_OK) | |
| 1282 | return TCL_ERROR; | |
| 1283 | if (objc == 4) { | |
| 15884 | 1284 | purple_presence_set_idle(presence, idle, time(NULL)); |
| 13823 | 1285 | } else if (objc == 5) { |
| 1286 | if ((error = Tcl_GetIntFromObj(interp, | |
| 1287 | objv[4], | |
| 1288 | &idle_time)) != TCL_OK) | |
| 1289 | return TCL_ERROR; | |
| 15884 | 1290 | purple_presence_set_idle(presence, idle, idle_time); |
| 13823 | 1291 | } |
| 1292 | break; | |
| 1293 | case CMD_PRESENCE_LOGIN: | |
| 1294 | if (objc != 3 && objc != 4) { | |
| 1295 | Tcl_WrongNumArgs(interp, 2, objv, "presence ?time?"); | |
| 1296 | return TCL_ERROR; | |
| 1297 | } | |
| 15884 | 1298 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1299 | return TCL_ERROR; |
| 1300 | if (objc == 3) { | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1301 | Tcl_SetObjResult(interp, Tcl_NewIntObj(purple_presence_get_login_time(presence))); |
| 13823 | 1302 | } else { |
| 1303 | if ((error == Tcl_GetIntFromObj(interp, | |
| 1304 | objv[3], | |
| 1305 | &login_time)) != TCL_OK) | |
| 1306 | return TCL_ERROR; | |
| 15884 | 1307 | purple_presence_set_login_time(presence, login_time); |
| 13823 | 1308 | } |
| 1309 | break; | |
| 1310 | case CMD_PRESENCE_ONLINE: | |
| 1311 | if (objc != 3) { | |
| 1312 | Tcl_WrongNumArgs(interp, 2, objv, "presence"); | |
| 1313 | return TCL_ERROR; | |
| 1314 | } | |
| 15884 | 1315 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1316 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1317 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1318 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1319 | purple_presence_is_online(presence))); |
| 13823 | 1320 | break; |
| 1321 | case CMD_PRESENCE_STATUS: | |
| 1322 | if (objc != 4) { | |
| 1323 | Tcl_WrongNumArgs(interp, 2, objv, "presence status_id"); | |
| 1324 | return TCL_ERROR; | |
| 1325 | } | |
| 15884 | 1326 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1327 | return TCL_ERROR; |
| 1328 | Tcl_SetObjResult(interp, | |
| 15884 | 1329 | purple_tcl_ref_new(PurpleTclRefStatus, |
| 1330 | purple_presence_get_status(presence, | |
| 13823 | 1331 | Tcl_GetString(objv[3])))); |
| 1332 | break; | |
| 1333 | case CMD_PRESENCE_STATUSES: | |
| 1334 | if (objc != 3) { | |
| 1335 | Tcl_WrongNumArgs(interp, 2, objv, "presence"); | |
| 1336 | return TCL_ERROR; | |
| 1337 | } | |
| 15884 | 1338 | if ((presence = purple_tcl_ref_get(interp, objv[2], PurpleTclRefPresence)) == NULL) |
| 13823 | 1339 | return TCL_ERROR; |
| 1340 | list = Tcl_NewListObj(0, NULL); | |
| 15884 | 1341 | for (cur = purple_presence_get_statuses(presence); cur != NULL; |
| 13823 | 1342 | cur = g_list_next(cur)) { |
| 15884 | 1343 | elem = purple_tcl_ref_new(PurpleTclRefStatus, cur->data); |
| 13823 | 1344 | Tcl_ListObjAppendElement(interp, list, elem); |
| 1345 | } | |
| 1346 | Tcl_SetObjResult(interp, list); | |
| 1347 | break; | |
| 1348 | } | |
| 1349 | ||
| 1350 | return TCL_OK; | |
| 1351 | } | |
| 1352 | ||
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1353 | int tcl_cmd_savedstatus(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1354 | { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1355 | Tcl_Obj *result; |
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1356 | const char *cmds[] = { "current", "handle", NULL }; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1357 | enum { CMD_SAVEDSTATUS_CURRENT, CMD_SAVEDSTATUS_HANDLE } cmd; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1358 | int error; |
| 15884 | 1359 | PurpleSavedStatus *saved_status; |
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1360 | |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1361 | if (objc < 2) { |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1362 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1363 | return TCL_ERROR; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1364 | } |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1365 | |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1366 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1367 | return error; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1368 | |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1369 | switch (cmd) { |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1370 | case CMD_SAVEDSTATUS_CURRENT: |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1371 | if (objc != 2) { |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1372 | Tcl_WrongNumArgs(interp, 2, objv, ""); |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1373 | return TCL_ERROR; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1374 | } |
| 15884 | 1375 | if ((saved_status = purple_savedstatus_get_current()) == NULL) |
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1376 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1377 | result = Tcl_NewListObj(0, NULL); |
| 15884 | 1378 | Tcl_ListObjAppendElement(interp, result, Tcl_NewStringObj(purple_savedstatus_get_title(saved_status), -1)); |
|
35378
5d9e2581005b
gtk-doc prep: *_get_type() functions are hidden as standard GType-returning funcs, so rename them.
Ankit Vani <a@nevitus.org>
parents:
34955
diff
changeset
|
1379 | Tcl_ListObjAppendElement(interp, result, Tcl_NewIntObj(purple_savedstatus_get_primitive_type(saved_status))); |
| 15884 | 1380 | Tcl_ListObjAppendElement(interp, result, Tcl_NewStringObj(purple_savedstatus_get_message(saved_status), -1)); |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1381 | Tcl_SetObjResult(interp,result); |
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1382 | break; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1383 | case CMD_SAVEDSTATUS_HANDLE: |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1384 | if (objc != 2) { |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1385 | Tcl_WrongNumArgs(interp, 2, objv, ""); |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1386 | return TCL_ERROR; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1387 | } |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
1388 | Tcl_SetObjResult(interp, |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1389 | purple_tcl_ref_new(PurpleTclRefHandle, |
|
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1390 | purple_savedstatuses_get_handle())); |
|
15758
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1391 | break; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1392 | } |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1393 | |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1394 | return TCL_OK; |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1395 | } |
|
d31f3317c849
Tcl savedstatus command, again from Dossy Shiobara. Dossy is on fire.
Ethan Blanton <elb@pidgin.im>
parents:
15750
diff
changeset
|
1396 | |
| 6694 | 1397 | int tcl_cmd_send_im(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
| 1398 | { | |
| 15884 | 1399 | PurpleConnection *gc; |
| 6694 | 1400 | char *who, *text; |
| 1401 | ||
| 1402 | if (objc != 4) { | |
| 1403 | Tcl_WrongNumArgs(interp, 1, objv, "gc who text"); | |
| 1404 | return TCL_ERROR; | |
| 1405 | } | |
| 1406 | ||
| 13817 | 1407 | if ((gc = tcl_validate_gc(objv[1], interp)) == NULL) |
| 6694 | 1408 | return TCL_ERROR; |
| 1409 | ||
| 1410 | who = Tcl_GetString(objv[2]); | |
| 1411 | text = Tcl_GetString(objv[3]); | |
| 1412 | ||
|
6982
12f08de92674
[gaim-migrate @ 7538]
Mark Doliner <markdoliner@pidgin.im>
parents:
6864
diff
changeset
|
1413 | serv_send_im(gc, who, text, 0); |
| 6694 | 1414 | |
| 1415 | return TCL_OK; | |
| 1416 | } | |
| 1417 | ||
| 1418 | int tcl_cmd_signal(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 1419 | { | |
|
10339
246feba79f04
[gaim-migrate @ 11548]
Mark Doliner <markdoliner@pidgin.im>
parents:
10246
diff
changeset
|
1420 | const char *cmds[] = { "connect", "disconnect", NULL }; |
| 6694 | 1421 | enum { CMD_SIGNAL_CONNECT, CMD_SIGNAL_DISCONNECT } cmd; |
| 1422 | struct tcl_signal_handler *handler; | |
| 1423 | void *instance; | |
| 10597 | 1424 | int error; |
| 6694 | 1425 | |
| 1426 | if (objc < 2) { | |
| 1427 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 1428 | return TCL_ERROR; | |
| 1429 | } | |
| 1430 | ||
| 1431 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 1432 | return error; | |
| 1433 | ||
| 1434 | switch (cmd) { | |
| 1435 | case CMD_SIGNAL_CONNECT: | |
| 1436 | if (objc != 6) { | |
| 1437 | Tcl_WrongNumArgs(interp, 2, objv, "instance signal args proc"); | |
| 1438 | return TCL_ERROR; | |
| 1439 | } | |
| 1440 | handler = g_new0(struct tcl_signal_handler, 1); | |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1441 | if ((handler->instance = purple_tcl_ref_get(interp, objv[2],PurpleTclRefHandle)) == NULL) { |
| 6694 | 1442 | g_free(handler); |
| 1443 | return error; | |
| 1444 | } | |
| 10597 | 1445 | handler->signal = objv[3]; |
| 13812 | 1446 | Tcl_IncrRefCount(handler->signal); |
| 10597 | 1447 | handler->args = objv[4]; |
| 1448 | handler->proc = objv[5]; | |
| 6694 | 1449 | handler->interp = interp; |
| 1450 | if (!tcl_signal_connect(handler)) { | |
| 1451 | tcl_signal_handler_free(handler); | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1452 | Tcl_SetObjResult(interp, Tcl_NewIntObj(1)); |
| 6694 | 1453 | } else { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1454 | Tcl_SetObjResult(interp, Tcl_NewIntObj(0)); |
| 6694 | 1455 | } |
| 1456 | break; | |
| 1457 | case CMD_SIGNAL_DISCONNECT: | |
| 1458 | if (objc != 4) { | |
| 13812 | 1459 | Tcl_WrongNumArgs(interp, 2, objv, "instance signal"); |
| 6694 | 1460 | return TCL_ERROR; |
| 1461 | } | |
|
20393
6280efb8c658
Another fabulous patch to our Tcl loader from venks on irc.freenode.net.
Ethan Blanton <elb@pidgin.im>
parents:
19859
diff
changeset
|
1462 | if ((instance = purple_tcl_ref_get(interp, objv[2],PurpleTclRefHandle)) == NULL) |
| 6694 | 1463 | return error; |
| 1464 | tcl_signal_disconnect(instance, Tcl_GetString(objv[3]), interp); | |
| 1465 | break; | |
| 1466 | } | |
| 1467 | ||
| 1468 | return TCL_OK; | |
| 1469 | } | |
| 1470 | ||
| 13812 | 1471 | int tcl_cmd_status(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) |
| 1472 | { | |
| 13828 | 1473 | const char *cmds[] = { "attr", "type", NULL }; |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1474 | enum { CMD_STATUS_ATTRIBUTE, CMD_STATUS_TYPE } cmd; |
| 15884 | 1475 | PurpleStatus *status; |
| 1476 | PurpleStatusType *status_type; | |
|
25913
3d5e1dfea10a
Fix compile errors from the merge. Untested protocols: msnp9, sametime,
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
24974
diff
changeset
|
1477 | int error; |
|
33896
fb896f14715b
win32: fix most of easy warnings
Tomasz Wasilczyk <tomkiewicz@cpw.pidgin.im>
parents:
33854
diff
changeset
|
1478 | # if (0) |
|
fb896f14715b
win32: fix most of easy warnings
Tomasz Wasilczyk <tomkiewicz@cpw.pidgin.im>
parents:
33854
diff
changeset
|
1479 | /* #if !(defined PURPLE_DISABLE_DEPRECATED) */ |
| 15884 | 1480 | PurpleValue *value; |
| 13826 | 1481 | const char *attr; |
|
25913
3d5e1dfea10a
Fix compile errors from the merge. Untested protocols: msnp9, sametime,
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
24974
diff
changeset
|
1482 | int v; |
|
3d5e1dfea10a
Fix compile errors from the merge. Untested protocols: msnp9, sametime,
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
24974
diff
changeset
|
1483 | #endif |
| 13812 | 1484 | |
| 1485 | if (objc < 2) { | |
| 1486 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 1487 | return TCL_ERROR; | |
| 1488 | } | |
| 1489 | ||
| 1490 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 1491 | return error; | |
| 1492 | ||
| 1493 | switch (cmd) { | |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1494 | case CMD_STATUS_ATTRIBUTE: |
|
33854
5744cfb1c3d1
Fix 3.0.0 compilation for win32, switch gtk (and others) runtimes from gnome.org to opensuse build service
Tomasz Wasilczyk <tomkiewicz@cpw.pidgin.im>
parents:
32145
diff
changeset
|
1495 | # if (0) |
|
5744cfb1c3d1
Fix 3.0.0 compilation for win32, switch gtk (and others) runtimes from gnome.org to opensuse build service
Tomasz Wasilczyk <tomkiewicz@cpw.pidgin.im>
parents:
32145
diff
changeset
|
1496 | /* #if !(defined PURPLE_DISABLE_DEPRECATED) */ |
| 13826 | 1497 | if (objc != 4 && objc != 5) { |
| 1498 | Tcl_WrongNumArgs(interp, 2, objv, "status attr_id ?value?"); | |
| 13812 | 1499 | return TCL_ERROR; |
| 1500 | } | |
| 15884 | 1501 | if ((status = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatus)) == NULL) |
| 13812 | 1502 | return TCL_ERROR; |
| 13826 | 1503 | attr = Tcl_GetString(objv[3]); |
| 15884 | 1504 | value = purple_status_get_attr_value(status, attr); |
| 13812 | 1505 | if (value == NULL) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1506 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1507 | Tcl_NewStringObj("no such attribute", -1)); |
| 13812 | 1508 | return TCL_ERROR; |
| 1509 | } | |
| 15884 | 1510 | switch (purple_value_get_type(value)) { |
| 1511 | case PURPLE_TYPE_BOOLEAN: | |
| 13826 | 1512 | if (objc == 4) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1513 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1514 | Tcl_NewBooleanObj(purple_value_get_boolean(value))); |
| 13826 | 1515 | } else { |
| 1516 | if ((error = Tcl_GetBooleanFromObj(interp, objv[4], &v)) != TCL_OK) | |
| 1517 | return error; | |
| 15884 | 1518 | purple_status_set_attr_boolean(status, attr, v); |
| 13826 | 1519 | } |
| 13812 | 1520 | break; |
| 15884 | 1521 | case PURPLE_TYPE_INT: |
| 13826 | 1522 | if (objc == 4) { |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1523 | Tcl_SetObjResult(interp, Tcl_NewIntObj(purple_value_get_int(value))); |
| 13826 | 1524 | } else { |
| 1525 | if ((error = Tcl_GetIntFromObj(interp, objv[4], &v)) != TCL_OK) | |
| 1526 | return error; | |
| 15884 | 1527 | purple_status_set_attr_int(status, attr, v ); |
| 13826 | 1528 | } |
| 13812 | 1529 | break; |
| 15884 | 1530 | case PURPLE_TYPE_STRING: |
| 13826 | 1531 | if (objc == 4) |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1532 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1533 | Tcl_NewStringObj(purple_value_get_string(value), -1)); |
| 13826 | 1534 | else |
| 15884 | 1535 | purple_status_set_attr_string(status, attr, Tcl_GetString(objv[4])); |
| 13812 | 1536 | break; |
| 1537 | default: | |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1538 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1539 | Tcl_NewStringObj("attribute has unknown type", -1)); |
| 13812 | 1540 | return TCL_ERROR; |
| 1541 | } | |
|
25913
3d5e1dfea10a
Fix compile errors from the merge. Untested protocols: msnp9, sametime,
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
24974
diff
changeset
|
1542 | #endif |
| 13812 | 1543 | break; |
| 1544 | case CMD_STATUS_TYPE: | |
| 1545 | if (objc != 3) { | |
| 1546 | Tcl_WrongNumArgs(interp, 2, objv, "status"); | |
| 1547 | return TCL_ERROR; | |
| 1548 | } | |
| 15884 | 1549 | if ((status = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatus)) == NULL) |
| 13812 | 1550 | return TCL_ERROR; |
|
34855
9c289149eed4
Global replaces according to GObject status API
Ankit Vani <a@nevitus.org>
parents:
34852
diff
changeset
|
1551 | status_type = purple_status_get_status_type(status); |
| 15884 | 1552 | Tcl_SetObjResult(interp, purple_tcl_ref_new(PurpleTclRefStatusType, |
| 13812 | 1553 | status_type)); |
| 1554 | break; | |
| 1555 | } | |
| 1556 | ||
| 1557 | return TCL_OK; | |
| 1558 | } | |
| 1559 | ||
| 1560 | int tcl_cmd_status_attr(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 1561 | { | |
| 1562 | const char *cmds[] = { "id", "name", NULL }; | |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1563 | enum { CMD_STATUS_ATTRIBUTE_ID, CMD_STATUS_ATTRIBUTE_NAME } cmd; |
|
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1564 | PurpleStatusAttribute *attr; |
| 13812 | 1565 | int error; |
| 1566 | ||
| 1567 | if (objc < 2) { | |
| 1568 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 1569 | return TCL_ERROR; | |
| 1570 | } | |
| 1571 | ||
| 1572 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 1573 | return error; | |
| 1574 | ||
| 1575 | switch (cmd) { | |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1576 | case CMD_STATUS_ATTRIBUTE_ID: |
| 13812 | 1577 | if (objc != 3) { |
| 1578 | Tcl_WrongNumArgs(interp, 2, objv, "attr"); | |
| 1579 | return TCL_ERROR; | |
| 1580 | } | |
| 15884 | 1581 | if ((attr = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusAttr)) == NULL) |
| 13812 | 1582 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1583 | Tcl_SetObjResult(interp, |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1584 | Tcl_NewStringObj(purple_status_attribute_get_id(attr), -1)); |
| 13812 | 1585 | break; |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1586 | case CMD_STATUS_ATTRIBUTE_NAME: |
| 13812 | 1587 | if (objc != 3) { |
| 1588 | Tcl_WrongNumArgs(interp, 2, objv, "attr"); | |
| 1589 | return TCL_ERROR; | |
| 1590 | } | |
| 15884 | 1591 | if ((attr = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusAttr)) == NULL) |
| 13812 | 1592 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1593 | Tcl_SetObjResult(interp, |
|
34858
28ac3a0418f1
Renamed PurpleStatusAttr to PurpleStatusAttribute for simplicity.
Ankit Vani <a@nevitus.org>
parents:
34855
diff
changeset
|
1594 | Tcl_NewStringObj(purple_status_attribute_get_name(attr), -1)); |
| 13812 | 1595 | break; |
| 1596 | } | |
| 1597 | ||
| 1598 | return TCL_OK; | |
| 1599 | } | |
| 1600 | ||
| 1601 | int tcl_cmd_status_type(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 1602 | { | |
| 1603 | const char *cmds[] = { "attr", "attrs", "available", "exclusive", "id", | |
|
32145
22222cee0d53
Get rid of the wholly unused "primary attribute" thing in PurpleStatusTypes
Mark Doliner <markdoliner@pidgin.im>
parents:
31294
diff
changeset
|
1604 | "independent", "name", |
| 13812 | 1605 | "primitive", "saveable", "user_settable", |
| 1606 | NULL }; | |
| 1607 | enum { CMD_STATUS_TYPE_ATTR, CMD_STATUS_TYPE_ATTRS, | |
| 1608 | CMD_STATUS_TYPE_AVAILABLE, CMD_STATUS_TYPE_EXCLUSIVE, | |
| 1609 | CMD_STATUS_TYPE_ID, CMD_STATUS_TYPE_INDEPENDENT, | |
|
32145
22222cee0d53
Get rid of the wholly unused "primary attribute" thing in PurpleStatusTypes
Mark Doliner <markdoliner@pidgin.im>
parents:
31294
diff
changeset
|
1610 | CMD_STATUS_TYPE_NAME, |
| 13812 | 1611 | CMD_STATUS_TYPE_PRIMITIVE, CMD_STATUS_TYPE_SAVEABLE, |
| 1612 | CMD_STATUS_TYPE_USER_SETTABLE } cmd; | |
| 15884 | 1613 | PurpleStatusType *status_type; |
| 13812 | 1614 | Tcl_Obj *list, *elem; |
|
18190
bcf28ef7e8ff
Re-fix the DBus list handling code by killing const GList* / const GSList*
Richard Laager <rlaager@pidgin.im>
parents:
18122
diff
changeset
|
1615 | GList *cur; |
| 13812 | 1616 | int error; |
| 1617 | ||
| 1618 | if (objc < 2) { | |
| 1619 | Tcl_WrongNumArgs(interp, 1, objv, "subcommand ?args?"); | |
| 1620 | return TCL_ERROR; | |
| 1621 | } | |
| 1622 | ||
| 1623 | if ((error = Tcl_GetIndexFromObj(interp, objv[1], cmds, "subcommand", 0, (int *)&cmd)) != TCL_OK) | |
| 1624 | return error; | |
| 1625 | ||
| 1626 | switch (cmd) { | |
| 1627 | case CMD_STATUS_TYPE_AVAILABLE: | |
| 1628 | if (objc != 3) { | |
| 1629 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1630 | return TCL_ERROR; | |
| 1631 | } | |
| 15884 | 1632 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1633 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1634 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1635 | Tcl_NewBooleanObj(purple_status_type_is_available(status_type))); |
| 13812 | 1636 | break; |
| 1637 | case CMD_STATUS_TYPE_ATTR: | |
| 1638 | if (objc != 4) { | |
| 1639 | Tcl_WrongNumArgs(interp, 2, objv, "statustype attr"); | |
| 1640 | return TCL_ERROR; | |
| 1641 | } | |
| 15884 | 1642 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1643 | return TCL_ERROR; |
| 1644 | Tcl_SetObjResult(interp, | |
| 15884 | 1645 | purple_tcl_ref_new(PurpleTclRefStatusAttr, |
| 1646 | purple_status_type_get_attr(status_type, | |
| 13812 | 1647 | Tcl_GetStringFromObj(objv[3], NULL)))); |
| 1648 | break; | |
| 1649 | case CMD_STATUS_TYPE_ATTRS: | |
| 1650 | if (objc != 3) { | |
| 1651 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1652 | return TCL_ERROR; | |
| 1653 | } | |
| 15884 | 1654 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1655 | return TCL_ERROR; |
| 1656 | list = Tcl_NewListObj(0, NULL); | |
| 15884 | 1657 | for (cur = purple_status_type_get_attrs(status_type); |
| 13812 | 1658 | cur != NULL; cur = g_list_next(cur)) { |
| 15884 | 1659 | elem = purple_tcl_ref_new(PurpleTclRefStatusAttr, cur->data); |
| 13812 | 1660 | Tcl_ListObjAppendElement(interp, list, elem); |
| 1661 | } | |
| 1662 | Tcl_SetObjResult(interp, list); | |
| 1663 | break; | |
| 1664 | case CMD_STATUS_TYPE_EXCLUSIVE: | |
| 1665 | if (objc != 3) { | |
| 1666 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1667 | return TCL_ERROR; | |
| 1668 | } | |
| 15884 | 1669 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1670 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1671 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1672 | Tcl_NewBooleanObj(purple_status_type_is_exclusive(status_type))); |
| 13812 | 1673 | break; |
| 1674 | case CMD_STATUS_TYPE_ID: | |
| 1675 | if (objc != 3) { | |
| 1676 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1677 | return TCL_ERROR; | |
| 1678 | } | |
| 15884 | 1679 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1680 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1681 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1682 | Tcl_NewStringObj(purple_status_type_get_id(status_type), -1)); |
| 13812 | 1683 | break; |
| 1684 | case CMD_STATUS_TYPE_INDEPENDENT: | |
| 1685 | if (objc != 3) { | |
| 1686 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1687 | return TCL_ERROR; | |
| 1688 | } | |
| 15884 | 1689 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1690 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1691 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1692 | Tcl_NewBooleanObj(purple_status_type_is_independent(status_type))); |
| 13812 | 1693 | break; |
| 1694 | case CMD_STATUS_TYPE_NAME: | |
| 1695 | if (objc != 3) { | |
| 1696 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1697 | return TCL_ERROR; | |
| 1698 | } | |
| 15884 | 1699 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1700 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1701 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1702 | Tcl_NewStringObj(purple_status_type_get_name(status_type), -1)); |
| 13812 | 1703 | break; |
| 1704 | case CMD_STATUS_TYPE_PRIMITIVE: | |
| 1705 | if (objc != 3) { | |
| 1706 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1707 | return TCL_ERROR; | |
| 1708 | } | |
| 15884 | 1709 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1710 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1711 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1712 | Tcl_NewStringObj(purple_primitive_get_id_from_type |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1713 | (purple_status_type_get_primitive(status_type)), -1)); |
| 13812 | 1714 | break; |
| 1715 | case CMD_STATUS_TYPE_SAVEABLE: | |
| 1716 | if (objc != 3) { | |
| 1717 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1718 | return TCL_ERROR; | |
| 1719 | } | |
| 15884 | 1720 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1721 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1722 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1723 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1724 | purple_status_type_is_saveable(status_type))); |
| 13812 | 1725 | break; |
| 1726 | case CMD_STATUS_TYPE_USER_SETTABLE: | |
| 1727 | if (objc != 3) { | |
| 1728 | Tcl_WrongNumArgs(interp, 2, objv, "statustype"); | |
| 1729 | return TCL_ERROR; | |
| 1730 | } | |
| 15884 | 1731 | if ((status_type = purple_tcl_ref_get(interp, objv[2], PurpleTclRefStatusType)) == NULL) |
| 13812 | 1732 | return TCL_ERROR; |
|
20394
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1733 | Tcl_SetObjResult(interp, |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1734 | Tcl_NewBooleanObj( |
|
4088fda4a8e7
The second in a series of Tcl-fixing patches from venks on
Ethan Blanton <elb@pidgin.im>
parents:
20393
diff
changeset
|
1735 | purple_status_type_is_user_settable(status_type))); |
| 13812 | 1736 | break; |
| 1737 | } | |
| 1738 | ||
| 1739 | return TCL_OK; | |
| 1740 | } | |
| 1741 | ||
| 6694 | 1742 | static gboolean unload_self(gpointer data) |
| 1743 | { | |
| 15884 | 1744 | PurplePlugin *plugin = data; |
| 1745 | purple_plugin_unload(plugin); | |
| 6694 | 1746 | return FALSE; |
| 1747 | } | |
| 1748 | ||
| 1749 | int tcl_cmd_unload(ClientData unused, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) | |
| 1750 | { | |
| 15884 | 1751 | PurplePlugin *plugin; |
| 6694 | 1752 | if (objc != 1) { |
| 1753 | Tcl_WrongNumArgs(interp, 1, objv, ""); | |
| 1754 | return TCL_ERROR; | |
| 1755 | } | |
| 1756 | ||
| 1757 | if ((plugin = tcl_interp_get_plugin(interp)) == NULL) { | |
| 1758 | /* This isn't exactly OK, but heh. What do you do? */ | |
| 1759 | return TCL_OK; | |
| 1760 | } | |
|
31294
73607ab89c6f
Remove trailing whitespace
Richard Laager <rlaager@pidgin.im>
parents:
26824
diff
changeset
|
1761 | /* We can't unload immediately, but we can unload at the first |
| 6694 | 1762 | * known safe opportunity. */ |
|
22353
daef90676a8f
One more g_idle_add call
Mark Doliner <markdoliner@pidgin.im>
parents:
22240
diff
changeset
|
1763 | purple_timeout_add(0, unload_self, (gpointer)plugin); |
| 6694 | 1764 | |
| 1765 | return TCL_OK; | |
| 1766 | } |