libpurple/plugins/debug_example.c

Sun, 20 Oct 2013 16:21:29 +0530

author
Ankit Vani <a@nevitus.org>
date
Sun, 20 Oct 2013 16:21:29 +0530
branch
soc.2013.gobjectification.plugins
changeset 36906
729bdf55b919
parent 36801
70047858a8fd
parent 35026
fde23518e1e5
child 36909
68cfb4e93457
permissions
-rw-r--r--

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);

mercurial