1 /* GSequencer - Advanced GTK Sequencer
2  * Copyright (C) 2005-2020 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 #ifndef __AGS_RECALL_CHANNEL_H__
21 #define __AGS_RECALL_CHANNEL_H__
22 
23 #include <glib.h>
24 #include <glib-object.h>
25 
26 #include <ags/libags.h>
27 
28 #include <ags/audio/ags_channel.h>
29 #include <ags/audio/ags_recall.h>
30 #include <ags/audio/ags_recall_audio.h>
31 
32 G_BEGIN_DECLS
33 
34 #define AGS_TYPE_RECALL_CHANNEL                (ags_recall_channel_get_type())
35 #define AGS_RECALL_CHANNEL(obj)                (G_TYPE_CHECK_INSTANCE_CAST((obj), AGS_TYPE_RECALL_CHANNEL, AgsRecallChannel))
36 #define AGS_RECALL_CHANNEL_CLASS(class)        (G_TYPE_CHECK_CLASS_CAST((class), AGS_TYPE_RECALL_CHANNEL, AgsRecallChannelClass))
37 #define AGS_IS_RECALL_CHANNEL(obj)             (G_TYPE_CHECK_INSTANCE_TYPE ((obj), AGS_TYPE_RECALL_CHANNEL))
38 #define AGS_IS_RECALL_CHANNEL_CLASS(class)     (G_TYPE_CHECK_CLASS_TYPE ((class), AGS_TYPE_RECALL_CHANNEL))
39 #define AGS_RECALL_CHANNEL_GET_CLASS(obj)      (G_TYPE_INSTANCE_GET_CLASS ((obj), AGS_TYPE_RECALL_CHANNEL, AgsRecallChannelClass))
40 
41 typedef struct _AgsRecallChannel AgsRecallChannel;
42 typedef struct _AgsRecallChannelClass AgsRecallChannelClass;
43 
44 struct _AgsRecallChannel
45 {
46   AgsRecall recall;
47 
48   AgsRecallAudio *recall_audio;
49 
50   AgsChannel *destination;
51   AgsChannel *source;
52 };
53 
54 struct _AgsRecallChannelClass
55 {
56   AgsRecallClass recall;
57 };
58 
59 GType ags_recall_channel_get_type();
60 
61 AgsChannel* ags_recall_channel_get_destination(AgsRecallChannel *recall_channel);
62 void ags_recall_channel_set_destination(AgsRecallChannel *recall_channel,
63 					AgsChannel *destination);
64 
65 AgsChannel* ags_recall_channel_get_source(AgsRecallChannel *recall_channel);
66 void ags_recall_channel_set_source(AgsRecallChannel *recall_channel,
67 				   AgsChannel *source);
68 
69 GList* ags_recall_channel_find_channel(GList *recall_channel, AgsChannel *source);
70 
71 AgsRecallChannel* ags_recall_channel_new();
72 
73 G_END_DECLS
74 
75 #endif /*__AGS_RECALL_CHANNEL_H__*/
76