mirror of
https://github.com/ZDoom/fluidsynth.git
synced 2025-01-19 07:50:49 +00:00
require explicit unregistering of sequencer clients
This commit is contained in:
parent
5d3f727547
commit
e1a3e2468b
3 changed files with 25 additions and 0 deletions
|
@ -103,6 +103,7 @@ Changes in FluidSynth 2.0.0 concerning developers:
|
|||
- all public \c fluid_settings_* functions that return an integer which is not meant to be interpreted as bool consistently return either FLUID_OK or FLUID_FAILED
|
||||
- all public delete_* functions return void and are safe when called with NULL
|
||||
- all public functions consistently receive signed integers for soundfont ids, bank and program numbers
|
||||
- explicit client unregistering is required for fluid_sequencer_register_client() and fluid_sequencer_register_fluidsynth()
|
||||
- the shell command handler was decoupled internally, as a consequence the param list of new_fluid_server() and new_fluid_cmd_handler() was adapted
|
||||
- reverb: roomsize is now limited to an upper threshold of 1.0 to avoid exponential volume increase
|
||||
- use unique device names for the "audio.portaudio.device" setting
|
||||
|
|
|
@ -260,6 +260,9 @@ void fluid_seq_dotrace(fluid_sequencer_t* seq, char *fmt, ...) {}
|
|||
*
|
||||
* Clients can be sources or destinations of events. Sources don't need to
|
||||
* register a callback.
|
||||
*
|
||||
* @note The user must explicitly unregister any registered client with fluid_sequencer_unregister_client()
|
||||
* before deleting the sequencer!
|
||||
*/
|
||||
fluid_seq_id_t
|
||||
fluid_sequencer_register_client (fluid_sequencer_t* seq, const char *name,
|
||||
|
|
|
@ -71,6 +71,27 @@ delete_fluid_seqbind(fluid_seqbind_t* seqbind)
|
|||
/**
|
||||
* Registers a synthesizer as a destination client of the given sequencer.
|
||||
* The \a synth is registered with the name "fluidsynth".
|
||||
*
|
||||
* @warning Due to internal memory allocation, the user must explicitly unregister
|
||||
* the client by sending a fluid_event_unregistering(). Otherwise the behaviour is
|
||||
* undefined after either \p seq or \p synth is destroyed.
|
||||
@code{.cpp}
|
||||
fluid_seq_id_t seqid = fluid_sequencer_register_fluidsynth(seq, synth);
|
||||
|
||||
// ... do work
|
||||
|
||||
fluid_event_t* evt = new_fluid_event();
|
||||
fluid_event_set_source(evt, -1);
|
||||
fluid_event_set_dest(evt, seqid);
|
||||
fluid_event_unregistering(evt);
|
||||
|
||||
// unregister the "fluidsynth" client immediately
|
||||
fluid_sequencer_send_now(seq, evt);
|
||||
delete_fluid_event(evt);
|
||||
delete_fluid_synth(synth);
|
||||
delete_fluid_sequencer(seq);
|
||||
@endcode
|
||||
*
|
||||
* @param seq Sequencer instance
|
||||
* @param synth Synthesizer instance
|
||||
* @returns Sequencer client ID, or #FLUID_FAILED on error.
|
||||
|
|
Loading…
Reference in a new issue