libpurple/media/codec.h

Thu, 30 Apr 2020 23:43:54 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Thu, 30 Apr 2020 23:43:54 -0500
changeset 40350
72271baf92bc
parent 40188
80e78796edb2
child 40474
1341be8e3402
permissions
-rw-r--r--

Split PurpleKeyValuePair out to it's own file and try to do some cleanup in the files that need to include it.

/* purple
 *
 * Purple is the legal property of its developers, whose names are too numerous
 * to list here.  Please refer to the COPYRIGHT file distributed with this
 * source distribution.
 *
 * 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, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
 */

#ifndef PURPLE_MEDIA_CODEC_H
#define PURPLE_MEDIA_CODEC_H
/**
 * SECTION:codec
 * @section_id: libpurple-codec
 * @short_description: <filename>media/codec.h</filename>
 * @title: Codec for Media API
 */

#include "enum-types.h"

/**
 * PurpleMediaCodec:
 *
 * An opaque structure representing an audio or video codec.
 */
typedef struct _PurpleMediaCodec PurpleMediaCodec;

#include <purplekeyvaluepair.h>

#include <glib-object.h>

G_BEGIN_DECLS

#define PURPLE_TYPE_MEDIA_CODEC  purple_media_codec_get_type()

/**
 * purple_media_codec_get_type:
 *
 * Gets the type of the media codec structure.
 *
 * Returns: The media codec's GType
 */
G_DECLARE_FINAL_TYPE(PurpleMediaCodec, purple_media_codec, PURPLE,
		MEDIA_CODEC, GObject)

/**
 * purple_media_codec_new:
 * @id: Codec identifier.
 * @encoding_name: Name of the media type this encodes.
 * @media_type: PurpleMediaSessionType of this codec.
 * @clock_rate: The clock rate this codec encodes at, if applicable.
 *
 * Creates a new PurpleMediaCodec instance.
 *
 * Returns: The newly created PurpleMediaCodec.
 */
PurpleMediaCodec *purple_media_codec_new(int id, const char *encoding_name,
		PurpleMediaSessionType media_type, guint clock_rate);

/**
 * purple_media_codec_get_id:
 * @codec: The codec to get the id from.
 *
 * Gets the codec id.
 *
 * Returns: The codec id.
 */
guint purple_media_codec_get_id(PurpleMediaCodec *codec);

/**
 * purple_media_codec_get_encoding_name:
 * @codec: The codec to get the encoding name from.
 *
 * Gets the encoding name.
 *
 * Returns: The encoding name.
 */
gchar *purple_media_codec_get_encoding_name(PurpleMediaCodec *codec);

/**
 * purple_media_codec_get_clock_rate:
 * @codec: The codec to get the clock rate from.
 *
 * Gets the clock rate.
 *
 * Returns: The clock rate.
 */
guint purple_media_codec_get_clock_rate(PurpleMediaCodec *codec);

/**
 * purple_media_codec_get_channels:
 * @codec: The codec to get the number of channels from.
 *
 * Gets the number of channels.
 *
 * Returns: The number of channels.
 */
guint purple_media_codec_get_channels(PurpleMediaCodec *codec);

/**
 * purple_media_codec_get_optional_parameters:
 * @codec: The codec to get the optional parameters from.
 *
 * Gets a list of the optional parameters.
 *
 * Returns: (element-type PurpleKeyValuePair) (transfer none): The list of
 *          optional parameters.
 */
GList *purple_media_codec_get_optional_parameters(PurpleMediaCodec *codec);

/**
 * purple_media_codec_add_optional_parameter:
 * @codec: The codec to add the parameter to.
 * @name: The name of the parameter to add.
 * @value: The value of the parameter to add.
 *
 * Adds an optional parameter to the codec.
 */
void purple_media_codec_add_optional_parameter(PurpleMediaCodec *codec,
		const gchar *name, const gchar *value);

/**
 * purple_media_codec_remove_optional_parameter:
 * @codec: The codec to remove the parameter from.
 * @param: A pointer to the parameter to remove.
 *
 * Removes an optional parameter from the codec.
 */
void purple_media_codec_remove_optional_parameter(PurpleMediaCodec *codec,
		PurpleKeyValuePair *param);

/**
 * purple_media_codec_get_optional_parameter:
 * @codec: The codec to find the parameter in.
 * @name: The name of the parameter to search for.
 * @value: The value to search for or NULL.
 *
 * Gets an optional parameter based on the values given.
 *
 * Returns: (transfer none): The value found or NULL.
 */
PurpleKeyValuePair *purple_media_codec_get_optional_parameter(
		PurpleMediaCodec *codec, const gchar *name,
		const gchar *value);

/**
 * purple_media_codec_copy:
 * @codec: The codec to copy.
 *
 * Copies a PurpleMediaCodec object.
 *
 * Returns: (transfer full): The copy of the codec.
 */
PurpleMediaCodec *purple_media_codec_copy(PurpleMediaCodec *codec);

/**
 * purple_media_codec_list_copy:
 * @codecs: (element-type PurpleMediaCodec) (transfer none): The list of codecs
 *          to be copied.
 *
 * Copies a GList of PurpleMediaCodec and its contents.
 *
 * Returns: (element-type PurpleMediaCodec) (transfer full): The copy of the
 *          codec list.
 */
GList *purple_media_codec_list_copy(GList *codecs);

/**
 * purple_media_codec_list_free:
 * @codecs: (element-type PurpleMediaCodec) (transfer full): The list of codecs
 *          to be freed.
 *
 * Frees a GList of PurpleMediaCodec and its contents.
 */
void purple_media_codec_list_free(GList *codecs);

/**
 * purple_media_codec_to_string:
 * @codec: The codec to create the string of.
 *
 * Creates a string representation of the codec.
 *
 * Returns: The new string representation.
 */
gchar *purple_media_codec_to_string(PurpleMediaCodec *codec);

G_END_DECLS

#endif /* PURPLE_MEDIA_CODEC_H */

mercurial