source: roaraudio/include/libroar/plugincontainer.h @ 5436:a29ea4926470

Last change on this file since 5436:a29ea4926470 was 5436:a29ea4926470, checked in by phi, 12 years ago

allows the use of costume para parameters

File size: 4.2 KB
Line 
1//plugincontainer.h:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2008-2012
5 *
6 *  This file is part of libroar a part of RoarAudio,
7 *  a cross-platform sound system for both, home and professional use.
8 *  See README for details.
9 *
10 *  This file is free software; you can redistribute it and/or modify
11 *  it under the terms of the GNU General Public License version 3
12 *  as published by the Free Software Foundation.
13 *
14 *  libroar is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *  GNU General Public License for more details.
18 *
19 *  You should have received a copy of the GNU General Public License
20 *  along with this software; see the file COPYING.  If not, write to
21 *  the Free Software Foundation, 51 Franklin Street, Fifth Floor,
22 *  Boston, MA 02110-1301, USA.
23 *
24 *  NOTE for everyone want's to change something and send patches:
25 *  read README and HACKING! There a addition information on
26 *  the license of this document you need to read before you send
27 *  any patches.
28 *
29 *  NOTE for uses of non-GPL (LGPL,...) software using libesd, libartsc
30 *  or libpulse*:
31 *  The libs libroaresd, libroararts and libroarpulse link this lib
32 *  and are therefore GPL. Because of this it may be illigal to use
33 *  them with any software that uses libesd, libartsc or libpulse*.
34 */
35
36#ifndef _LIBROARPLUGINCONTAINER_H_
37#define _LIBROARPLUGINCONTAINER_H_
38
39#include "libroar.h"
40
41struct roar_plugincontainer;
42
43/* Create a new plugin container.
44 * Takes a default parameter set.
45 */
46struct roar_plugincontainer * roar_plugincontainer_new(struct roar_dl_librarypara * default_para);
47
48/* Create a new plugin container.
49 * Takes host application's appname and abiversion.
50 */
51struct roar_plugincontainer * roar_plugincontainer_new_simple(const char * appname, const char * abiversion);
52
53// Increment the refrence counter.
54int roar_plugincontainer_ref(struct roar_plugincontainer * cont);
55/* Decrement the refrence counter.
56 * Unloads all plugins and frees all resources when there are no refreneces left.
57 */
58int roar_plugincontainer_unref(struct roar_plugincontainer * cont);
59
60/*
61 * stuff we still need:
62 * object creation, get plugin handle.
63 */
64
65// plugin loading and unloading:
66
67// Load a plugin by name.
68int                      roar_plugincontainer_load            (struct roar_plugincontainer * cont,
69                                                               const char * name,
70                                                               struct roar_dl_librarypara * para);
71
72/* Load a plugin by name with extra options.
73 * This is for advanced applications only.
74 */
75struct roar_dl_lhandle * roar_plugincontainer_load_lhandle    (struct roar_plugincontainer * cont,
76                                                               const char * name,
77                                                               int flags,
78                                                               int ra_init,
79                                                               struct roar_dl_librarypara * para);
80/* Unload a plugin by name.
81 * NOTE: The name here is from the plugin and may not match the name you load
82 *       the plugin with.
83 */
84int                      roar_plugincontainer_unload          (struct roar_plugincontainer * cont,
85                                                               const char * name);
86/* Load a plugin by roardl handle.
87 * This is for advanced applications only.
88 */
89int                      roar_plugincontainer_unload_lhandle  (struct roar_plugincontainer * cont,
90                                                               struct roar_dl_lhandle * lhandle);
91/* Post ra_init plugins not yet inited.
92 * NOTE: This uses the default para,
93 *       not the one given with roar_plugincontainer_load_lhandle().
94 * This is for advanced applications only.
95 */
96int                      roar_plugincontainer_ra_init         (struct roar_plugincontainer * cont);
97
98// appsched:
99// Trigger an application schedule event on all plugins.
100int                      roar_plugincontainer_appsched_trigger(struct roar_plugincontainer * cont, enum roar_dl_appsched_trigger trigger);
101
102#endif
103
104//ll
Note: See TracBrowser for help on using the repository browser.