1 /* GSequencer - Advanced GTK Sequencer
2 * Copyright (C) 2005-2019 Joël Krähemann
3 *
4 * This file is part of GSequencer.
5 *
6 * GSequencer is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * GSequencer is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with GSequencer. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include <ags/audio/recall/ags_prepare_channel.h>
21
22 void ags_prepare_channel_class_init(AgsPrepareChannelClass *prepare_channel);
23 void ags_prepare_channel_init(AgsPrepareChannel *prepare_channel);
24 void ags_prepare_channel_finalize(GObject *gobject);
25
26 /**
27 * SECTION:ags_prepare_channel
28 * @short_description: prepares channel
29 * @title: AgsPrepareChannel
30 * @section_id:
31 * @include: ags/audio/recall/ags_prepare_channel.h
32 *
33 * The #AgsPrepareChannel class provides ports to the effect processor.
34 */
35
36 static gpointer ags_prepare_channel_parent_class = NULL;
37
38 const gchar *ags_prepare_channel_plugin_name = "ags-prepare";
39
40 GType
ags_prepare_channel_get_type()41 ags_prepare_channel_get_type()
42 {
43 static volatile gsize g_define_type_id__volatile = 0;
44
45 if(g_once_init_enter (&g_define_type_id__volatile)){
46 GType ags_type_prepare_channel = 0;
47
48 static const GTypeInfo ags_prepare_channel_info = {
49 sizeof (AgsPrepareChannelClass),
50 NULL, /* base_init */
51 NULL, /* base_finalize */
52 (GClassInitFunc) ags_prepare_channel_class_init,
53 NULL, /* class_finalize */
54 NULL, /* class_data */
55 sizeof (AgsPrepareChannel),
56 0, /* n_preallocs */
57 (GInstanceInitFunc) ags_prepare_channel_init,
58 };
59
60 ags_type_prepare_channel = g_type_register_static(AGS_TYPE_RECALL_CHANNEL,
61 "AgsPrepareChannel",
62 &ags_prepare_channel_info,
63 0);
64
65 g_once_init_leave(&g_define_type_id__volatile, ags_type_prepare_channel);
66 }
67
68 return g_define_type_id__volatile;
69 }
70
71 void
ags_prepare_channel_class_init(AgsPrepareChannelClass * prepare_channel)72 ags_prepare_channel_class_init(AgsPrepareChannelClass *prepare_channel)
73 {
74 GObjectClass *gobject;
75
76 ags_prepare_channel_parent_class = g_type_class_peek_parent(prepare_channel);
77
78 /* GObjectClass */
79 gobject = (GObjectClass *) prepare_channel;
80
81 gobject->finalize = ags_prepare_channel_finalize;
82 }
83
84 void
ags_prepare_channel_init(AgsPrepareChannel * prepare_channel)85 ags_prepare_channel_init(AgsPrepareChannel *prepare_channel)
86 {
87 AGS_RECALL(prepare_channel)->name = "ags-prepare";
88 AGS_RECALL(prepare_channel)->version = AGS_RECALL_DEFAULT_VERSION;
89 AGS_RECALL(prepare_channel)->build_id = AGS_RECALL_DEFAULT_BUILD_ID;
90 AGS_RECALL(prepare_channel)->xml_type = "ags-prepare-channel";
91 }
92
93 void
ags_prepare_channel_finalize(GObject * gobject)94 ags_prepare_channel_finalize(GObject *gobject)
95 {
96 /* call parent */
97 G_OBJECT_CLASS(ags_prepare_channel_parent_class)->finalize(gobject);
98 }
99
100 /**
101 * ags_prepare_channel_new:
102 * @source: the #AgsChannel
103 *
104 * Create a new instance of #AgsPrepareChannel
105 *
106 * Returns: the new #AgsPrepareChannel
107 *
108 * Since: 3.0.0
109 */
110 AgsPrepareChannel*
ags_prepare_channel_new(AgsChannel * source)111 ags_prepare_channel_new(AgsChannel *source)
112 {
113 AgsPrepareChannel *prepare_channel;
114
115 prepare_channel = (AgsPrepareChannel *) g_object_new(AGS_TYPE_PREPARE_CHANNEL,
116 "source", source,
117 NULL);
118
119 return(prepare_channel);
120 }
121