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