libpurple/protocols/ircv3/purpleircv3messagehandlers.h

Sat, 01 Jul 2023 02:01:14 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Sat, 01 Jul 2023 02:01:14 -0500
changeset 42229
605f8cba9704
parent 41951
00c472cd0fff
child 42275
7568bf87e388
permissions
-rw-r--r--

Add gobject-introspection for ircv3

This includes a pkgconfig file and installs the header files as well as
purpleircv3.h to ${prefix}/include/purple-3/libpurple/protocols/ircv3.

This does not yet include the documentation as I assume that's going to touch
a bunch of files.

Testing Done:
Compiled against gplugin 0.41.0 locally without issue. Also installed to a local prefix and verified everything looked okie dokie.

Reviewed at https://reviews.imfreedom.org/r/2484/

/*
 * Purple - Internet Messaging Library
 * Copyright (C) Pidgin Developers <devel@pidgin.im>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, see <https://www.gnu.org/licenses/>.
 */
#if !defined(PURPLE_IRCV3_GLOBAL_HEADER_INSIDE) && \
    !defined(PURPLE_IRCV3_COMPILATION)
# error "only <libpurple/protocols/ircv3.h> may be included directly"
#endif

#ifndef PURPLE_IRCV3_MESSAGE_HANDLERS_H
#define PURPLE_IRCV3_MESSAGE_HANDLERS_H

#include <glib.h>

#include <purple.h>

G_BEGIN_DECLS

/**
 * PurpleIRCv3MessageHandler:
 * @tags: (element-type utf8 utf8): A [struct@GLib.HashTable] of tags for this
 *        message.
 * @source: The source of the command.
 * @command: The command or numeric of the message.
 * @n_params: The number of parameters.
 * @params: (array length=n_params): The parameters of the message.
 * @error: (nullable): A return address for a [type@GLib.Error].
 * @data: The user data that was passed to [method@PurpleIRCv3.Parser.parse].
 *
 * Defines the type of a function that will be called to handle a message.
 *
 * Returns: %TRUE if the command was handled properly, otherwise %FALSE and
 *          @error may be set.
 *
 * Since: 3.0.0
 */
typedef gboolean (*PurpleIRCv3MessageHandler)(GHashTable *tags,
                                              const char *source,
                                              const char *command,
                                              guint n_params,
                                              GStrv params,
                                              GError **error,
                                              gpointer data);

G_GNUC_INTERNAL gboolean purple_ircv3_message_handler_fallback(GHashTable *tags, const char *source, const char *command, guint n_params, GStrv params, GError **error, gpointer data);
G_GNUC_INTERNAL gboolean purple_ircv3_message_handler_ping(GHashTable *tags, const char *source, const char *command, guint n_params, GStrv params, GError **error, gpointer data);
G_GNUC_INTERNAL gboolean purple_ircv3_message_handler_privmsg(GHashTable *tags, const char *source, const char *command, guint n_params, GStrv params, GError **error, gpointer data);

G_END_DECLS

#endif /* PURPLE_IRCV3_MESSAGE_HANDLERS_H */

mercurial