Sun, 20 Oct 2013 16:21:29 +0530
Merged soc.2013.gobjectification branch
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
1 | /* |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
2 | * Debug Example Plugin |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
3 | * |
|
19878
aa9d2cfa70bf
Fix my e-mail address to match my MTN key since it now is a real e-mail address.
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
19875
diff
changeset
|
4 | * Copyright (C) 2007, John Bailey <rekkanoryo@cpw.pidgin.im> |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
5 | * |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
6 | * This program is free software; you can redistribute it and/or |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
7 | * modify it under the terms of the GNU General Public License as |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
8 | * published by the Free Software Foundation; either version 2 of the |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
9 | * License, or (at your option) any later version. |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
10 | * |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
11 | * This program is distributed in the hope that it will be useful, but |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
12 | * WITHOUT ANY WARRANTY; without even the implied warranty of |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
14 | * General Public License for more details. |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
15 | * |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
16 | * You should have received a copy of the GNU General Public License |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
17 | * along with this program; if not, write to the Free Software |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
19 | * 02111-1301, USA. |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
20 | * |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
21 | */ |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
22 | |
|
35026
fde23518e1e5
Moved PurpleHash to cipher.[ch]
Ankit Vani <a@nevitus.org>
parents:
34964
diff
changeset
|
23 | #include "internal.h" |
|
fde23518e1e5
Moved PurpleHash to cipher.[ch]
Ankit Vani <a@nevitus.org>
parents:
34964
diff
changeset
|
24 | |
|
34964
54ebd3dcae16
Simplified example plugins by including purple.h
Ankit Vani <a@nevitus.org>
parents:
33955
diff
changeset
|
25 | /* This file defines PURPLE_PLUGINS and includes all the libpurple headers */ |
|
54ebd3dcae16
Simplified example plugins by including purple.h
Ankit Vani <a@nevitus.org>
parents:
33955
diff
changeset
|
26 | #include <purple.h> |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
27 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
28 | /* It's more convenient to type PLUGIN_ID all the time than it is to type |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
29 | * "core-debugexample", so define this convenience macro. */ |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
30 | #define PLUGIN_ID "core-debugexample" |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
31 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
32 | /* Common practice in third-party plugins is to define convenience macros for |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
33 | * many of the fields of the plugin info struct, so we'll do that for the |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
34 | * purposes of demonstration. */ |
|
36739
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
35 | #define PLUGIN_AUTHORS { "John Bailey <rekkanoryo@cpw.pidgin.im>", NULL } |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
36 | |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
37 | static PurplePluginInfo * |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
38 | plugin_query(GError **error) |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
39 | { |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
40 | const gchar * const authors[] = PLUGIN_AUTHORS; |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
41 | |
|
36739
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
42 | return purple_plugin_info_new( |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
43 | "id", PLUGIN_ID, |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
44 | "name", "Debug API Example", |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
45 | "version", DISPLAY_VERSION, |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
46 | "category", "Example", |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
47 | "summary", "Debug API Example", |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
48 | "description", "Debug API Example", |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
49 | "authors", authors, |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
50 | "website", "https://pidgin.im", |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
51 | "abi-version", PURPLE_ABI_VERSION, |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
52 | NULL |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
53 | ); |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
54 | } |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
55 | |
|
36792
764b45883fba
Moved internal.h inclusion over others in libpurple plugins
Ankit Vani <a@nevitus.org>
parents:
36739
diff
changeset
|
56 | /* As we've covered before, this function is called when the plugin is loaded. |
|
764b45883fba
Moved internal.h inclusion over others in libpurple plugins
Ankit Vani <a@nevitus.org>
parents:
36739
diff
changeset
|
57 | * Here we're using it to show off the capabilities of the debug API and just |
|
764b45883fba
Moved internal.h inclusion over others in libpurple plugins
Ankit Vani <a@nevitus.org>
parents:
36739
diff
changeset
|
58 | * blindly returning TRUE to tell libpurple it's safe to continue loading. */ |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
59 | static gboolean |
|
36739
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
60 | plugin_load(PurplePlugin *plugin, GError **error) |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
61 | { |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
62 | /* Define these for convenience--we're just using them to show the |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
63 | * similarities of the debug functions to the standard printf(). */ |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
64 | gint i = 256; |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
65 | gfloat f = 512.1024; |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
66 | const gchar *s = "example string"; |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
67 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
68 | /* Introductory message */ |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
69 | purple_debug_info(PLUGIN_ID, |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
70 | "Called plugin_load. Beginning debug demonstration\n"); |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
71 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
72 | /* Show off the debug API a bit */ |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
73 | purple_debug_misc(PLUGIN_ID, |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
74 | "MISC level debug message. i = %d, f = %f, s = %s\n", i, f, s); |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
75 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
76 | purple_debug_info(PLUGIN_ID, |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
77 | "INFO level debug message. i = %d, f = %f, s = %s\n", i, f, s); |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
78 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
79 | purple_debug_warning(PLUGIN_ID, |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
80 | "WARNING level debug message. i = %d, f = %f, s = %s\n", i, f, s); |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
81 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
82 | purple_debug_error(PLUGIN_ID, |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
83 | "ERROR level debug message. i = %d, f = %f, s = %s\n", i, f, s); |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
84 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
85 | purple_debug_fatal(PLUGIN_ID, |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
86 | "FATAL level debug message. i = %d, f = %f, s = %s\n", i, f, s); |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
87 | |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
88 | /* Now just return TRUE to tell libpurple to finish loading. */ |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
89 | return TRUE; |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
90 | } |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
91 | |
|
36739
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
92 | static gboolean |
|
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
93 | plugin_unload(PurplePlugin *plugin, GError **error) |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
94 | { |
|
36739
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
95 | return TRUE; |
|
19875
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
96 | } |
|
ace837283c37
Add the debug example plugin
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
diff
changeset
|
97 | |
|
36739
472bef54ba0a
Started refactoring plugins to use the new plugin API
Ankit Vani <a@nevitus.org>
parents:
36367
diff
changeset
|
98 | PURPLE_PLUGIN_INIT(debugexample, plugin_query, plugin_load, plugin_unload); |