1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
|
/* GSequencer - Advanced GTK Sequencer
* Copyright (C) 2005-2019 Joël Krähemann
*
* This file is part of GSequencer.
*
* GSequencer 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.
*
* GSequencer 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 GSequencer. If not, see <http://www.gnu.org/licenses/>.
*/
#include <ags/object/ags_applicable.h>
void ags_applicable_base_init(AgsApplicableInterface *ginterface);
/**
* SECTION:ags_applicable
* @short_description: unique access to applicable objects
* @title: AgsApplicable
* @section_id: AgsApplicable
* @include: ags/object/ags_applicable.h
*
* The #AgsApplicable interface gives you a unique access to applicable objects.
*/
GType
ags_applicable_get_type()
{
static gsize g_define_type_id__static = 0;
if(g_once_init_enter(&g_define_type_id__static)){
GType ags_type_applicable = 0;
static const GTypeInfo ags_applicable_info = {
sizeof(AgsApplicableInterface),
(GBaseInitFunc) ags_applicable_base_init,
NULL, /* base_finalize */
};
ags_type_applicable = g_type_register_static(G_TYPE_INTERFACE,
"AgsApplicable", &ags_applicable_info,
0);
g_once_init_leave(&g_define_type_id__static, ags_type_applicable);
}
return(g_define_type_id__static);
}
void
ags_applicable_base_init(AgsApplicableInterface *ginterface)
{
/* empty */
}
/**
* ags_applicable_set_update:
* @applicable: an #AgsApplicable
* @update: if %TRUE do ::reset after ::apply
*
* Update behaviour.
*
* Since: 3.0.0
*/
void
ags_applicable_set_update(AgsApplicable *applicable, gboolean update)
{
AgsApplicableInterface *applicable_interface;
g_return_if_fail(AGS_IS_APPLICABLE(applicable));
applicable_interface = AGS_APPLICABLE_GET_INTERFACE(applicable);
g_return_if_fail(applicable_interface->set_update);
applicable_interface->set_update(applicable, update);
}
/**
* ags_applicable_apply:
* @applicable: an #AgsApplicable
*
* Apply all changes done so far.
*
* Since: 3.0.0
*/
void
ags_applicable_apply(AgsApplicable *applicable)
{
AgsApplicableInterface *applicable_interface;
g_return_if_fail(AGS_IS_APPLICABLE(applicable));
applicable_interface = AGS_APPLICABLE_GET_INTERFACE(applicable);
g_return_if_fail(applicable_interface->apply);
applicable_interface->apply(applicable);
}
/**
* ags_applicable_reset:
* @applicable: an #AgsApplicable
*
* Reset all changes within the user interface.
*
* Since: 3.0.0
*/
void
ags_applicable_reset(AgsApplicable *applicable)
{
AgsApplicableInterface *applicable_interface;
g_return_if_fail(AGS_IS_APPLICABLE(applicable));
applicable_interface = AGS_APPLICABLE_GET_INTERFACE(applicable);
g_return_if_fail(applicable_interface->reset);
applicable_interface->reset(applicable);
}
|