source: roaraudio/include/libroar/plugincontainer.h @ 5433:6a6c001574c0

Last change on this file since 5433:6a6c001574c0 was 5433:6a6c001574c0, checked in by phi, 12 years ago

updated comments

File size: 4.1 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#if 0
44struct roar_plugincontainer * roar_plugincontainer_new(struct roar_dl_librarypara * default_para);
45#endif
46
47/* Create a new plugin container.
48 * Takes host application's appname and abiversion.
49 */
50struct roar_plugincontainer * roar_plugincontainer_new_simple(const char * appname, const char * abiversion);
51
52// Increment the refrence counter.
53int roar_plugincontainer_ref(struct roar_plugincontainer * cont);
54/* Decrement the refrence counter.
55 * Unloads all plugins and frees all resources when there are no refreneces left.
56 */
57int roar_plugincontainer_unref(struct roar_plugincontainer * cont);
58
59/*
60 * stuff we still need:
61 * object creation, get plugin handle.
62 */
63
64// plugin loading and unloading:
65
66// Load a plugin by name.
67int                      roar_plugincontainer_load            (struct roar_plugincontainer * cont,
68                                                               const char * name,
69                                                               struct roar_dl_librarypara * para);
70
71/* Load a plugin by name with extra options.
72 * This is for advanced applications only.
73 */
74struct roar_dl_lhandle * roar_plugincontainer_load_lhandle    (struct roar_plugincontainer * cont,
75                                                               const char * name,
76                                                               int flags,
77                                                               int ra_init,
78                                                               struct roar_dl_librarypara * para);
79/* Unload a plugin by name.
80 * NOTE: The name here is from the plugin and may not match the name you load
81 *       the plugin with.
82 */
83int                      roar_plugincontainer_unload          (struct roar_plugincontainer * cont,
84                                                               const char * name);
85/* Load a plugin by roardl handle.
86 * This is for advanced applications only.
87 */
88int                      roar_plugincontainer_unload_lhandle  (struct roar_plugincontainer * cont,
89                                                               struct roar_dl_lhandle * lhandle);
90/* Post ra_init plugins not yet inited.
91 * NOTE: This uses the default para,
92 *       not the one given with roar_plugincontainer_load_lhandle().
93 * This is for advanced applications only.
94 */
95int                      roar_plugincontainer_ra_init         (struct roar_plugincontainer * cont);
96
97// appsched:
98// Trigger an application schedule event on all plugins.
99int                      roar_plugincontainer_appsched_trigger(struct roar_plugincontainer * cont, enum roar_dl_appsched_trigger trigger);
100
101#endif
102
103//ll
Note: See TracBrowser for help on using the repository browser.