Mercurial > hg > vamp-website
comparison code-doc/PluginLoader_8h-source.html @ 0:351c4ebce5f9 website
* Move website from vamp-website/trunk to plain website
author | cannam |
---|---|
date | Mon, 22 Sep 2008 13:01:46 +0000 |
parents | |
children | cc0be37dc9d3 |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:351c4ebce5f9 |
---|---|
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | |
2 <html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> | |
3 <title>VampPluginSDK: PluginLoader.h Source File</title> | |
4 <link href="doxygen.css" rel="stylesheet" type="text/css"> | |
5 <link href="tabs.css" rel="stylesheet" type="text/css"> | |
6 </head><body> | |
7 <!-- Generated by Doxygen 1.5.5 --> | |
8 <div class="navigation" id="top"> | |
9 <div class="tabs"> | |
10 <ul> | |
11 <li><a href="main.html"><span>Main Page</span></a></li> | |
12 <li><a href="namespaces.html"><span>Namespaces</span></a></li> | |
13 <li><a href="annotated.html"><span>Classes</span></a></li> | |
14 <li class="current"><a href="files.html"><span>Files</span></a></li> | |
15 <li><a href="dirs.html"><span>Directories</span></a></li> | |
16 </ul> | |
17 </div> | |
18 <div class="navpath"><a class="el" href="dir_5b77fce4b90561041d958141b45c7c55.html">vamp-sdk</a> » <a class="el" href="dir_fa454903fff8cd477733ebe28a3468c0.html">hostext</a> | |
19 </div> | |
20 </div> | |
21 </div> | |
22 <h1>PluginLoader.h</h1><a href="PluginLoader_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */</span> | |
23 <a name="l00002"></a>00002 | |
24 <a name="l00003"></a>00003 <span class="comment">/*</span> | |
25 <a name="l00004"></a>00004 <span class="comment"> Vamp</span> | |
26 <a name="l00005"></a>00005 <span class="comment"></span> | |
27 <a name="l00006"></a>00006 <span class="comment"> An API for audio analysis and feature extraction plugins.</span> | |
28 <a name="l00007"></a>00007 <span class="comment"></span> | |
29 <a name="l00008"></a>00008 <span class="comment"> Centre for Digital Music, Queen Mary, University of London.</span> | |
30 <a name="l00009"></a>00009 <span class="comment"> Copyright 2006-2007 Chris Cannam and QMUL.</span> | |
31 <a name="l00010"></a>00010 <span class="comment"> </span> | |
32 <a name="l00011"></a>00011 <span class="comment"> Permission is hereby granted, free of charge, to any person</span> | |
33 <a name="l00012"></a>00012 <span class="comment"> obtaining a copy of this software and associated documentation</span> | |
34 <a name="l00013"></a>00013 <span class="comment"> files (the "Software"), to deal in the Software without</span> | |
35 <a name="l00014"></a>00014 <span class="comment"> restriction, including without limitation the rights to use, copy,</span> | |
36 <a name="l00015"></a>00015 <span class="comment"> modify, merge, publish, distribute, sublicense, and/or sell copies</span> | |
37 <a name="l00016"></a>00016 <span class="comment"> of the Software, and to permit persons to whom the Software is</span> | |
38 <a name="l00017"></a>00017 <span class="comment"> furnished to do so, subject to the following conditions:</span> | |
39 <a name="l00018"></a>00018 <span class="comment"></span> | |
40 <a name="l00019"></a>00019 <span class="comment"> The above copyright notice and this permission notice shall be</span> | |
41 <a name="l00020"></a>00020 <span class="comment"> included in all copies or substantial portions of the Software.</span> | |
42 <a name="l00021"></a>00021 <span class="comment"></span> | |
43 <a name="l00022"></a>00022 <span class="comment"> THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,</span> | |
44 <a name="l00023"></a>00023 <span class="comment"> EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF</span> | |
45 <a name="l00024"></a>00024 <span class="comment"> MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND</span> | |
46 <a name="l00025"></a>00025 <span class="comment"> NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR</span> | |
47 <a name="l00026"></a>00026 <span class="comment"> ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF</span> | |
48 <a name="l00027"></a>00027 <span class="comment"> CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION</span> | |
49 <a name="l00028"></a>00028 <span class="comment"> WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.</span> | |
50 <a name="l00029"></a>00029 <span class="comment"></span> | |
51 <a name="l00030"></a>00030 <span class="comment"> Except as contained in this notice, the names of the Centre for</span> | |
52 <a name="l00031"></a>00031 <span class="comment"> Digital Music; Queen Mary, University of London; and Chris Cannam</span> | |
53 <a name="l00032"></a>00032 <span class="comment"> shall not be used in advertising or otherwise to promote the sale,</span> | |
54 <a name="l00033"></a>00033 <span class="comment"> use or other dealings in this Software without prior written</span> | |
55 <a name="l00034"></a>00034 <span class="comment"> authorization.</span> | |
56 <a name="l00035"></a>00035 <span class="comment">*/</span> | |
57 <a name="l00036"></a>00036 | |
58 <a name="l00037"></a>00037 <span class="preprocessor">#ifndef _VAMP_PLUGIN_LOADER_H_</span> | |
59 <a name="l00038"></a>00038 <span class="preprocessor"></span><span class="preprocessor">#define _VAMP_PLUGIN_LOADER_H_</span> | |
60 <a name="l00039"></a>00039 <span class="preprocessor"></span> | |
61 <a name="l00040"></a>00040 <span class="preprocessor">#include <vector></span> | |
62 <a name="l00041"></a>00041 <span class="preprocessor">#include <string></span> | |
63 <a name="l00042"></a>00042 <span class="preprocessor">#include <map></span> | |
64 <a name="l00043"></a>00043 | |
65 <a name="l00044"></a>00044 <span class="preprocessor">#include "<a class="code" href="PluginWrapper_8h.html">PluginWrapper.h</a>"</span> | |
66 <a name="l00045"></a>00045 | |
67 <a name="l00046"></a>00046 <span class="keyword">namespace </span>Vamp { | |
68 <a name="l00047"></a>00047 | |
69 <a name="l00048"></a>00048 <span class="keyword">class </span>Plugin; | |
70 <a name="l00049"></a>00049 | |
71 <a name="l00050"></a>00050 <span class="keyword">namespace </span>HostExt { | |
72 <a name="l00051"></a>00051 | |
73 <a name="l00069"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html">00069</a> <span class="keyword">class </span><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html" title="Vamp::HostExt::PluginLoader is a convenience class for discovering and loading Vamp...">PluginLoader</a> | |
74 <a name="l00070"></a>00070 { | |
75 <a name="l00071"></a>00071 <span class="keyword">public</span>: | |
76 <a name="l00076"></a>00076 <span class="keyword">static</span> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html" title="Vamp::HostExt::PluginLoader is a convenience class for discovering and loading Vamp...">PluginLoader</a> *<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#dbb5c8855697a24be890e4f107e26b0e" title="Obtain a pointer to the singleton instance of PluginLoader.">getInstance</a>(); | |
77 <a name="l00077"></a>00077 | |
78 <a name="l00098"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#473645bbb3ac5c1a0da2f0f482947c4d">00098</a> <span class="keyword">typedef</span> std::string <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#473645bbb3ac5c1a0da2f0f482947c4d" title="PluginKey is a string type that is used to identify a plugin uniquely within the...">PluginKey</a>; | |
79 <a name="l00099"></a>00099 | |
80 <a name="l00104"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#0d48b76e4f995110f53e0feeb23f733a">00104</a> <span class="keyword">typedef</span> std::vector<PluginKey> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#0d48b76e4f995110f53e0feeb23f733a" title="PluginKeyList is a sequence of plugin keys, such as returned by listPlugins().">PluginKeyList</a>; | |
81 <a name="l00105"></a>00105 | |
82 <a name="l00116"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#d6a39aa0c79d8d9209eb0b8dfe9d1364">00116</a> <span class="keyword">typedef</span> std::vector<std::string> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#d6a39aa0c79d8d9209eb0b8dfe9d1364" title="PluginCategoryHierarchy is a sequence of general-&gt;specific category names, as...">PluginCategoryHierarchy</a>; | |
83 <a name="l00117"></a>00117 | |
84 <a name="l00122"></a>00122 <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#0d48b76e4f995110f53e0feeb23f733a" title="PluginKeyList is a sequence of plugin keys, such as returned by listPlugins().">PluginKeyList</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ec450c2928b1ae5318d45972722dd16b" title="Search for all available Vamp plugins, and return a list of them in the order in...">listPlugins</a>(); | |
85 <a name="l00123"></a>00123 | |
86 <a name="l00166"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe3494">00166</a> <span class="keyword">enum</span> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe3494" title="AdapterFlags contains a set of values that may be OR&#39;d together to indicate in...">AdapterFlags</a> { | |
87 <a name="l00167"></a>00167 | |
88 <a name="l00168"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe3494763a9a0caf512d9671b90c05c2808a09">00168</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe3494763a9a0caf512d9671b90c05c2808a09">ADAPT_INPUT_DOMAIN</a> = 0x01, | |
89 <a name="l00169"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe349454c43b85382d78e8ea8da192bce3a139">00169</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe349454c43b85382d78e8ea8da192bce3a139">ADAPT_CHANNEL_COUNT</a> = 0x02, | |
90 <a name="l00170"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe34945c0c389797922630a6b54ffd1eed21f1">00170</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe34945c0c389797922630a6b54ffd1eed21f1">ADAPT_BUFFER_SIZE</a> = 0x04, | |
91 <a name="l00171"></a>00171 | |
92 <a name="l00172"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe34948220529e851ae30d37f413c40a389e08">00172</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe34948220529e851ae30d37f413c40a389e08">ADAPT_ALL_SAFE</a> = 0x03, | |
93 <a name="l00173"></a>00173 | |
94 <a name="l00174"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe34943b1e08415c0cbc96f7900eac955ad6d0">00174</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#ff3ee11692ce25e0dfb904324cbe34943b1e08415c0cbc96f7900eac955ad6d0">ADAPT_ALL</a> = 0xff | |
95 <a name="l00175"></a>00175 }; | |
96 <a name="l00176"></a>00176 | |
97 <a name="l00194"></a>00194 <a class="code" href="classVamp_1_1Plugin.html" title="Vamp::Plugin is a base class for plugin instance classes that provide feature extraction...">Plugin</a> *<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#2154970381343edef629482bdafea7e2" title="Load a Vamp plugin, given its identifying key.">loadPlugin</a>(<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#473645bbb3ac5c1a0da2f0f482947c4d" title="PluginKey is a string type that is used to identify a plugin uniquely within the...">PluginKey</a> key, | |
98 <a name="l00195"></a>00195 <span class="keywordtype">float</span> inputSampleRate, | |
99 <a name="l00196"></a>00196 <span class="keywordtype">int</span> adapterFlags = 0); | |
100 <a name="l00197"></a>00197 | |
101 <a name="l00203"></a>00203 <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#473645bbb3ac5c1a0da2f0f482947c4d" title="PluginKey is a string type that is used to identify a plugin uniquely within the...">PluginKey</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#cc6865d27825c100d7b6f9ed6ecf5207" title="Given a Vamp plugin library name and plugin identifier, return the corresponding...">composePluginKey</a>(std::string libraryName, | |
102 <a name="l00204"></a>00204 std::string identifier); | |
103 <a name="l00205"></a>00205 | |
104 <a name="l00215"></a>00215 <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#d6a39aa0c79d8d9209eb0b8dfe9d1364" title="PluginCategoryHierarchy is a sequence of general-&gt;specific category names, as...">PluginCategoryHierarchy</a> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#d5c594142ff058bd70e66247d45cd86e" title="Return the category hierarchy for a Vamp plugin, given its identifying key.">getPluginCategory</a>(<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#473645bbb3ac5c1a0da2f0f482947c4d" title="PluginKey is a string type that is used to identify a plugin uniquely within the...">PluginKey</a> plugin); | |
105 <a name="l00216"></a>00216 | |
106 <a name="l00221"></a>00221 std::string <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#592d6b4c6edaa369407e833f56e4a4de" title="Return the file path of the dynamic library from which the given plugin will be loaded...">getLibraryPathForPlugin</a>(<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#473645bbb3ac5c1a0da2f0f482947c4d" title="PluginKey is a string type that is used to identify a plugin uniquely within the...">PluginKey</a> plugin); | |
107 <a name="l00222"></a>00222 | |
108 <a name="l00223"></a>00223 <span class="keyword">protected</span>: | |
109 <a name="l00224"></a>00224 <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#5ab9e0281244bef7976c6c0ce1a55c24">PluginLoader</a>(); | |
110 <a name="l00225"></a>00225 <span class="keyword">virtual</span> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#9e092d864efdc0f16c032bfb25e76dea">~PluginLoader</a>(); | |
111 <a name="l00226"></a>00226 | |
112 <a name="l00227"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#c12254d823f6d63cb8ce82a07bdcb072">00227</a> <span class="keyword">class </span><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader_1_1Impl.html">Impl</a>; | |
113 <a name="l00228"></a>00228 <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader_1_1Impl.html">Impl</a> *<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#c12254d823f6d63cb8ce82a07bdcb072">m_impl</a>; | |
114 <a name="l00229"></a>00229 | |
115 <a name="l00230"></a><a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#aa4eae58ddbadf6537a95dbb6e957187">00230</a> <span class="keyword">static</span> <a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html" title="Vamp::HostExt::PluginLoader is a convenience class for discovering and loading Vamp...">PluginLoader</a> *<a class="code" href="classVamp_1_1HostExt_1_1PluginLoader.html#aa4eae58ddbadf6537a95dbb6e957187">m_instance</a>; | |
116 <a name="l00231"></a>00231 }; | |
117 <a name="l00232"></a>00232 | |
118 <a name="l00233"></a>00233 } | |
119 <a name="l00234"></a>00234 | |
120 <a name="l00235"></a>00235 } | |
121 <a name="l00236"></a>00236 | |
122 <a name="l00237"></a>00237 <span class="preprocessor">#endif</span> | |
123 <a name="l00238"></a>00238 <span class="preprocessor"></span> | |
124 </pre></div></div> | |
125 <hr size="1"><address style="text-align: right;"><small>Generated on Wed Jul 9 11:36:07 2008 for VampPluginSDK by | |
126 <a href="http://www.doxygen.org/index.html"> | |
127 <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.5 </small></address> | |
128 </body> | |
129 </html> |