Skip to content

Commit

Permalink
Work on active and processing state documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
Trinitou committed Dec 5, 2023
1 parent 1e09a99 commit 05923e3
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 13 deletions.
5 changes: 2 additions & 3 deletions include/clap/ext/audio-ports.h
Original file line number Diff line number Diff line change
Expand Up @@ -65,15 +65,14 @@ typedef struct clap_audio_port_info {
clap_id in_place_pair;
} clap_audio_port_info_t;

// The audio ports scan has to be done while the plugin is deactivated.
typedef struct clap_plugin_audio_ports {
// Number of ports, for either input or output
// [main-thread]
// [main-thread & !active]
uint32_t(CLAP_ABI *count)(const clap_plugin_t *plugin, bool is_input);

// Get info about an audio port.
// Returns true on success and stores the result into info.
// [main-thread]
// [main-thread & !active]
bool(CLAP_ABI *get)(const clap_plugin_t *plugin,
uint32_t index,
bool is_input,
Expand Down
5 changes: 2 additions & 3 deletions include/clap/ext/note-ports.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,15 +38,14 @@ typedef struct clap_note_port_info {
char name[CLAP_NAME_SIZE]; // displayable name, i18n?
} clap_note_port_info_t;

// The note ports scan has to be done while the plugin is deactivated.
typedef struct clap_plugin_note_ports {
// Number of ports, for either input or output.
// [main-thread]
// [main-thread & !active]
uint32_t(CLAP_ABI *count)(const clap_plugin_t *plugin, bool is_input);

// Get info about a note port.
// Returns true on success and stores the result into info.
// [main-thread]
// [main-thread & !active]
bool(CLAP_ABI *get)(const clap_plugin_t *plugin,
uint32_t index,
bool is_input,
Expand Down
2 changes: 1 addition & 1 deletion include/clap/ext/thread-pool.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ typedef struct clap_host_thread_pool {
// Returns true if the host did execute all the tasks, false if it rejected the request.
// The host should check that the plugin is within the process call, and if not, reject the exec
// request.
// [audio-thread]
// [audio-thread & active & processing]
bool(CLAP_ABI *request_exec)(const clap_host_t *host, uint32_t num_tasks);
} clap_host_thread_pool_t;

Expand Down
12 changes: 6 additions & 6 deletions include/clap/plugin.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,35 +60,35 @@ typedef struct clap_plugin {
// the [min, max] range, which is bounded by [1, INT32_MAX].
// Once activated the latency and port configuration must remain constant, until deactivation.
// Returns true on success.
// [main-thread & !active_state]
// [main-thread & !active]
bool(CLAP_ABI *activate)(const struct clap_plugin *plugin,
double sample_rate,
uint32_t min_frames_count,
uint32_t max_frames_count);
// [main-thread & active_state]
// [main-thread & active]
void(CLAP_ABI *deactivate)(const struct clap_plugin *plugin);

// Call start processing before processing.
// Returns true on success.
// [audio-thread & active_state & !processing_state]
// [audio-thread & active & !processing]
bool(CLAP_ABI *start_processing)(const struct clap_plugin *plugin);

// Call stop processing before sending the plugin to sleep.
// [audio-thread & active_state & processing_state]
// [audio-thread & active & processing]
void(CLAP_ABI *stop_processing)(const struct clap_plugin *plugin);

// - Clears all buffers, performs a full reset of the processing state (filters, oscillators,
// envelopes, lfo, ...) and kills all voices.
// - The parameter's value remain unchanged.
// - clap_process.steady_time may jump backward.
//
// [audio-thread & active_state]
// [audio-thread & active]
void(CLAP_ABI *reset)(const struct clap_plugin *plugin);

// process audio, events, ...
// All the pointers coming from clap_process_t and its nested attributes,
// are valid until process() returns.
// [audio-thread & active_state & processing_state]
// [audio-thread & active & processing]
clap_process_status(CLAP_ABI *process)(const struct clap_plugin *plugin,
const clap_process_t *process);

Expand Down

0 comments on commit 05923e3

Please sign in to comment.