libpurple/protocols/ircv3/purpleircv3parser.h

Tue, 29 Nov 2022 00:06:45 -0600

author
Gary Kramlich <grim@reaperworld.com>
date
Tue, 29 Nov 2022 00:06:45 -0600
changeset 41951
00c472cd0fff
parent 41881
7e1dd7e9efbb
child 42229
605f8cba9704
permissions
-rw-r--r--

Create PurpleIRCv3Capabilities for managing capabilities for each connection

This implements everything in capabilities version 302 except for handling the
NEW and DEL commands from the server. I'm not sure how we can test that yet,
so we're ignoring it for now.

After the server has told us about all of the capabilities it supports, we
explicitly request cap-notify which we implictly request when we send
CAP LS 302. This is mostly to test our code and might be removed in the future.

Testing Done:
Connected to my local ergo and used ngrep to verify that everything was being sent correctly.

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

/*
 * 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/>.
 */

#ifndef PURPLE_IRCV3_PARSER_H
#define PURPLE_IRCV3_PARSER_H

#include <glib.h>
#include <glib-object.h>

#include <purple.h>

#include "purpleircv3messagehandlers.h"

G_BEGIN_DECLS

#define PURPLE_IRCV3_TYPE_PARSER (purple_ircv3_parser_get_type())
G_DECLARE_FINAL_TYPE(PurpleIRCv3Parser, purple_ircv3_parser, PURPLE_IRCV3,
                     PARSER, GObject)

/**
 * purple_ircv3_parser_new:
 *
 * Creates a new instance.
 *
 * Since: 3.0.0
 */
G_GNUC_INTERNAL PurpleIRCv3Parser *purple_ircv3_parser_new(void);

/**
 * purple_ircv3_parser_set_fallback_handler: (skip):
 * @parser: The instance.
 * @handler: A [func@PurpleIRCv3.MessageHandler].
 *
 * Sets @handler to be called for any messages that @parser doesn't know how to
 * handle.
 *
 * Since: 3.0.0
 */
G_GNUC_INTERNAL void purple_ircv3_parser_set_fallback_handler(PurpleIRCv3Parser *parser, PurpleIRCv3MessageHandler handler);

/**
 * purple_ircv3_parser_parse:
 * @parser: The instance.
 * @buffer: The buffer to parse.
 * @error: Return address for a #GError, or %NULL.
 * @data: (nullable): Optional data to pass to the handler.
 *
 * Parses @buffer with @parser.
 *
 * Returns: %TRUE if the buffer was parsed correctly or %FALSE with @error set.
 *
 * Since: 3.0.0
 */
G_GNUC_INTERNAL gboolean purple_ircv3_parser_parse(PurpleIRCv3Parser *parser, const gchar *buffer, GError **error, gpointer data);

/**
 * purple_ircv3_parser_add_default_handlers:
 * @parser: The instance.
 *
 * Adds all of the default handlers to @parser.
 *
 * Since: 3.0.0
 */
G_GNUC_INTERNAL void purple_ircv3_parser_add_default_handlers(PurpleIRCv3Parser *parser);

G_END_DECLS

#endif /* PURPLE_IRCV3_PARSER_H */

mercurial