mirror of
https://gitlab.gnome.org/GNOME/calls.git
synced 2025-01-08 12:55:32 +00:00
e81567786c
* Preliminary documentation of CallsCall and CallsMessageSource * Documentation and cleaning up of CallsCallData * Add data files and meson rules to create gtk-doc documentation * Move some macros from util.h to calls-message-source.h
78 lines
2.2 KiB
C
78 lines
2.2 KiB
C
/*
|
|
* Copyright (C) 2018 Purism SPC
|
|
*
|
|
* This file is part of Calls.
|
|
*
|
|
* Calls 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 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Calls 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 Calls. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Author: Bob Ham <bob.ham@puri.sm>
|
|
*
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
*/
|
|
|
|
#ifndef CALLS_MESSAGE_SOURCE_H__
|
|
#define CALLS_MESSAGE_SOURCE_H__
|
|
|
|
#include "util.h"
|
|
|
|
#include <glib-object.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define CALLS_TYPE_MESSAGE_SOURCE (calls_message_source_get_type ())
|
|
|
|
G_DECLARE_INTERFACE (CallsMessageSource, calls_message_source, CALLS, MESSAGE_SOURCE, GObject);
|
|
|
|
struct _CallsMessageSourceInterface
|
|
{
|
|
GTypeInterface parent_iface;
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
* CALLS_EMIT_MESSAGE:
|
|
* @obj: an object which can be cast to a #CallsMesssageSource
|
|
* @text: the message text as a string
|
|
* @type: the type of the message
|
|
*
|
|
* Emit a message signal with the specified information. This is a
|
|
* convenience macro for objects implementing interfaces that
|
|
* require #CallsMessageSource.
|
|
*
|
|
*/
|
|
#define CALLS_EMIT_MESSAGE(obj,text,type) \
|
|
g_signal_emit_by_name (CALLS_MESSAGE_SOURCE(obj), \
|
|
"message", text, type)
|
|
|
|
|
|
/**
|
|
* CALLS_ERROR:
|
|
* @obj: an object which can be cast to a #CallsMesssageSource
|
|
* @error: a pointer to a #GError containing the error message
|
|
*
|
|
* Emit a message signal with an error type, the text of which is
|
|
* contained as the message in a #GError. This is a convenience
|
|
* macro for objects implementing interfaces that require
|
|
* #CallsMessageSource.
|
|
*
|
|
*/
|
|
#define CALLS_ERROR(obj,error) \
|
|
CALLS_EMIT_MESSAGE (obj, error->message, GTK_MESSAGE_ERROR)
|
|
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* CALLS_MESSAGE_SOURCE_H__ */
|