Mercurial > hg > piper-cpp
comparison vamp-client/PluginStub.h @ 192:458766b73e71
Merge pull request #3 from piper-audio/dev/step-and-block-size
Fix erroneous logic for handling step and block size in prior commit
author | Chris Cannam <cannam@all-day-breakfast.com> |
---|---|
date | Tue, 07 Feb 2017 09:51:29 +0000 |
parents | 52322dde68ea |
children | ad6025dc0b04 |
comparison
equal
deleted
inserted
replaced
188:90c962b68d7f | 192:458766b73e71 |
---|---|
51 namespace client { | 51 namespace client { |
52 | 52 |
53 class PluginStub : public Vamp::Plugin | 53 class PluginStub : public Vamp::Plugin |
54 { | 54 { |
55 enum State { | 55 enum State { |
56 Loaded, Configured, Finished, Failed | 56 /** |
57 * The plugin's corresponding Piper feature extractor has been | |
58 * loaded but no subsequent state change has happened. This is | |
59 * the initial state of PluginStub on construction, since it | |
60 * is associated with a pre-loaded handle. | |
61 */ | |
62 Loaded, | |
63 | |
64 /** | |
65 * The plugin has been configured, and the step and block size | |
66 * received from the host in its last call to initialise() | |
67 * match those that were returned in the configuration | |
68 * response (i.e. the server's desired step and block | |
69 * size). Our m_config record reflects these correct | |
70 * values. The plugin is ready to process. | |
71 */ | |
72 Configured, | |
73 | |
74 /** | |
75 * The plugin has been configured, but the step and block size | |
76 * received from the host in its last call to initialise() | |
77 * differ from those returned by the server in the | |
78 * configuration response. Our initialise() call therefore | |
79 * returned false, and the plugin cannot be used until the | |
80 * host calls initialise() again with the "correct" step and | |
81 * block size. Our m_config record reflects these correct | |
82 * values, so the host can retrieve them through | |
83 * getPreferredStepSize and getPreferredBlockSize. | |
84 */ | |
85 Misconfigured, | |
86 | |
87 /** | |
88 * The finish() function has been called and the plugin | |
89 * unloaded. No further plugin activity is possible. | |
90 */ | |
91 Finished, | |
92 | |
93 /** | |
94 * A call has failed unrecoverably. No further plugin activity | |
95 * is possible. | |
96 */ | |
97 Failed | |
57 }; | 98 }; |
58 | 99 |
59 public: | 100 public: |
60 PluginStub(PluginClient *client, | 101 PluginStub(PluginClient *client, |
61 std::string pluginKey, | 102 std::string pluginKey, |
155 size_t blockSize) { | 196 size_t blockSize) { |
156 | 197 |
157 if (m_state == Failed) { | 198 if (m_state == Failed) { |
158 throw std::logic_error("Plugin is in failed state"); | 199 throw std::logic_error("Plugin is in failed state"); |
159 } | 200 } |
201 | |
202 if (m_state == Misconfigured) { | |
203 if (int(stepSize) == m_config.framing.stepSize && | |
204 int(blockSize) == m_config.framing.blockSize) { | |
205 m_state = Configured; | |
206 return true; | |
207 } else { | |
208 return false; | |
209 } | |
210 } | |
211 | |
160 if (m_state != Loaded) { | 212 if (m_state != Loaded) { |
161 m_state = Failed; | 213 m_state = Failed; |
162 throw std::logic_error("Plugin has already been initialised"); | 214 throw std::logic_error("Plugin has already been initialised"); |
163 } | 215 } |
164 | 216 |
167 m_config.framing.blockSize = int(blockSize); | 219 m_config.framing.blockSize = int(blockSize); |
168 | 220 |
169 try { | 221 try { |
170 auto response = m_client->configure(this, m_config); | 222 auto response = m_client->configure(this, m_config); |
171 m_outputs = response.outputs; | 223 m_outputs = response.outputs; |
172 | 224 |
173 // Update with the new preferred step and block size now | 225 // Update with the new preferred step and block size now |
174 // that the plugin has taken into account its parameter | 226 // that the plugin has taken into account its parameter |
175 // settings. If the values passed in to initialise() | 227 // settings. If the values passed in to initialise() |
176 // weren't suitable, then this ensures that a subsequent | 228 // weren't suitable, then this ensures that a subsequent |
177 // call to getPreferredStepSize/BlockSize on this plugin | 229 // call to getPreferredStepSize/BlockSize on this plugin |
178 // object will at least get acceptable values from now on | 230 // object will at least get acceptable values from now on |
179 m_config.framing = response.framing; | 231 m_config.framing = response.framing; |
232 | |
233 // And if they didn't match up with the passed-in ones, | |
234 // lodge ourselves in Misconfigured state and report | |
235 // failure so as to provoke the host to call initialise() | |
236 // again before any processing. | |
237 if (m_config.framing.stepSize != int(stepSize) || | |
238 m_config.framing.blockSize != int(blockSize)) { | |
239 m_state = Misconfigured; | |
240 return false; | |
241 } | |
180 | 242 |
181 } catch (const std::exception &e) { | 243 } catch (const std::exception &e) { |
182 m_state = Failed; | 244 m_state = Failed; |
183 throw; | 245 throw; |
184 } | 246 } |
194 virtual void reset() { | 256 virtual void reset() { |
195 | 257 |
196 if (m_state == Failed) { | 258 if (m_state == Failed) { |
197 throw std::logic_error("Plugin is in failed state"); | 259 throw std::logic_error("Plugin is in failed state"); |
198 } | 260 } |
199 if (m_state == Loaded) { | 261 if (m_state == Loaded || m_state == Misconfigured) { |
200 // reset is a no-op if the plugin hasn't been initialised yet | 262 // reset is a no-op if the plugin hasn't been initialised yet |
201 return; | 263 return; |
202 } | 264 } |
203 | 265 |
204 try { | 266 try { |
266 Vamp::RealTime timestamp) { | 328 Vamp::RealTime timestamp) { |
267 | 329 |
268 if (m_state == Failed) { | 330 if (m_state == Failed) { |
269 throw std::logic_error("Plugin is in failed state"); | 331 throw std::logic_error("Plugin is in failed state"); |
270 } | 332 } |
271 if (m_state == Loaded) { | 333 if (m_state == Loaded || m_state == Misconfigured) { |
272 m_state = Failed; | 334 m_state = Failed; |
273 throw std::logic_error("Plugin has not been initialised"); | 335 throw std::logic_error("Plugin has not been initialised"); |
274 } | 336 } |
275 if (m_state == Finished) { | 337 if (m_state == Finished) { |
276 m_state = Failed; | 338 m_state = Failed; |
295 virtual FeatureSet getRemainingFeatures() { | 357 virtual FeatureSet getRemainingFeatures() { |
296 | 358 |
297 if (m_state == Failed) { | 359 if (m_state == Failed) { |
298 throw std::logic_error("Plugin is in failed state"); | 360 throw std::logic_error("Plugin is in failed state"); |
299 } | 361 } |
300 if (m_state == Loaded) { | 362 if (m_state == Loaded || m_state == Misconfigured) { |
301 m_state = Failed; | 363 m_state = Failed; |
302 throw std::logic_error("Plugin has not been configured"); | 364 throw std::logic_error("Plugin has not been configured"); |
303 } | 365 } |
304 if (m_state == Finished) { | 366 if (m_state == Finished) { |
305 m_state = Failed; | 367 m_state = Failed; |