Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CLAP 1.1.9 #325

Merged
merged 40 commits into from
Oct 23, 2023
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
aa55758
gui extension: use !floating tag for some more embedded-only methods
Trinitou Mar 15, 2023
d8f2f33
gui extension: use !floating tag for resize_hints methods as well
Trinitou Mar 15, 2023
ce8ee4a
Merge pull request #315 from Trinitou/gui_method_tags
abique Mar 15, 2023
fab73da
Merge branch 'main' into next
abique Mar 24, 2023
f6d86a7
clarify what the `plugin_path` is on macOS
abique Mar 24, 2023
111858d
Rework audio ports configuration and surround / ambisonic
abique May 23, 2023
c04dae5
Update changelog
abique May 23, 2023
007a107
update changelog
abique May 23, 2023
d2cf8b1
Update include/clap/ext/draft/configurable-audio-ports.h
abique May 23, 2023
a4e1605
Introduce incremental state
abique Jul 7, 2023
cc53c04
Initial take on undo support
abique Jul 7, 2023
5c9612d
undo: try to clarify the call sequence and use change_id instead of id
abique Jul 10, 2023
b768df6
Adding compile test for version macros
jatinchowdhury18 Jul 10, 2023
5c8b26d
Trying to get msvc build happening on CI
jatinchowdhury18 Jul 10, 2023
d23d576
Add MSVC bypass for getting C++ version macro
jatinchowdhury18 Jul 10, 2023
e661d1c
Different strategy for definitions check
jatinchowdhury18 Jul 10, 2023
92f4a63
Update include/clap/ext/draft/undo.h
abique Jul 11, 2023
9d53955
Merge pull request #337 from jatinchowdhury18/cpp-version-macros-msvc
abique Jul 13, 2023
fe8d233
Fix typo
xris1658 Jul 19, 2023
66cb67f
Merge pull request #339 from xris1658/next
abique Jul 20, 2023
6062f41
Fix various typos
luzpaz Aug 6, 2023
40881b7
Merge pull request #342 from luzpaz/typos
abique Aug 7, 2023
ed43574
Merge pull request #336 from abique/undo
abique Aug 15, 2023
c56eaa9
specify the sample size to be used when activating the audio port
abique Aug 15, 2023
094da6e
Merge branch 'next' into incremental-state
abique Aug 15, 2023
c1c4910
Merge pull request #335 from abique/incremental-state
abique Aug 15, 2023
48803fe
Cleanup changelog
abique Aug 15, 2023
dcd29e3
clarify latency is defined in samples
defiantnerd Oct 11, 2023
ac69248
Merge pull request #353 from defiantnerd/defiantnerd-next-1
abique Oct 11, 2023
f9dffdd
Remove undo and incremental state as the design isn't ready yet and n…
abique Oct 17, 2023
92d7ebe
Forgot to remove this include
abique Oct 17, 2023
18922fa
Update version.h to 1.1.9
abique Oct 17, 2023
4a2aefc
Clarify ambisonic enums
Trinitou Oct 17, 2023
b31b26a
Update include/clap/ext/draft/surround.h
abique Oct 18, 2023
989f1e6
Merge pull request #355 from Trinitou/ambisonic-enums
abique Oct 18, 2023
98df453
Doc.
abique Oct 18, 2023
093141f
remove is_dry_run and make two functions instead
abique Oct 18, 2023
08d6b5e
Doc.
abique Oct 18, 2023
548f6fb
README: Re-phrase the mentioning of ABI
deeedob Oct 19, 2023
e912f06
Merge pull request #356 from deeedob/next
abique Oct 23, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions ChangeLog.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,15 @@
# Changes in 1.1.10
abique marked this conversation as resolved.
Show resolved Hide resolved

* [surround.h](include/clap/ext/draft/surround.h): simplify the design
* [ambisonic.h](include/clap/ext/draft/ambisonic.h): simplify the design
* [configurable-audio-ports.h](include/clap/ext/draft/configurable-audio-ports.h): simplify the design
* [gui.h](include/clap/ext/gui.h): documentation clarifications
* [entry.h](include/clap/entry.h): documentation clarifications
abique marked this conversation as resolved.
Show resolved Hide resolved

# Changes in 1.1.9

* [entry.h](include/clap/entry.h): clarify what the `plugin_path` is on macOS

# Changes in 1.1.8

* [params.h](include/clap/ext/params.h): document how persisting parameter values between sessions should be implemented
Expand Down
2 changes: 2 additions & 0 deletions include/clap/entry.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,8 @@ typedef struct clap_plugin_entry {
//
// If init() returns false, then the host must not call deinit() nor any other clap
// related symbols from the DSO.
//
// plugin_path is the path to the DSO (Linux, Windows), or the bundle (macOS).
abique marked this conversation as resolved.
Show resolved Hide resolved
bool(CLAP_ABI *init)(const char *plugin_path);

// No more calls into the DSO must be made after calling deinit().
Expand Down
19 changes: 12 additions & 7 deletions include/clap/ext/draft/ambisonic.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

// This extension can be used to specify the channel mapping used by the plugin.

static CLAP_CONSTEXPR const char CLAP_EXT_AMBISONIC[] = "clap.ambisonic.draft/2";
static CLAP_CONSTEXPR const char CLAP_EXT_AMBISONIC[] = "clap.ambisonic.draft/3";

static CLAP_CONSTEXPR const char CLAP_PORT_AMBISONIC[] = "ambisonic";

Expand All @@ -28,21 +28,26 @@ enum {
CLAP_AMBISONIC_NORMALIZATION_N2D = 4,
};

typedef struct clap_ambisonic_info {
typedef struct clap_ambisonic_config {
uint32_t ordering;
uint32_t normalization;
} clap_ambisonic_info_t;
} clap_ambisonic_config_t;

typedef struct clap_plugin_ambisonic {
// Returns true if the given configuration is supported.
// [main-thread]
bool(CLAP_ABI *is_config_supported)(const clap_plugin_t *plugin,
const clap_ambisonic_config_t *config);

// Returns true on success
//
// config_id: the configuration id, see clap_plugin_audio_ports_config.
// If config_id is CLAP_INVALID_ID, then this function queries the current port info.
// [main-thread]
bool(CLAP_ABI *get_info)(const clap_plugin_t *plugin,
bool is_input,
uint32_t port_index,
clap_ambisonic_info_t *info);
bool(CLAP_ABI *get_config)(const clap_plugin_t *plugin,
bool is_input,
uint32_t port_index,
clap_ambisonic_config_t *config);

} clap_plugin_ambisonic_t;

Expand Down
30 changes: 9 additions & 21 deletions include/clap/ext/draft/configurable-audio-ports.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,9 @@ extern "C" {
// This extension lets the host configure the plugin's input and output audio ports.
// This is a "push" approach to audio ports configuration.
static CLAP_CONSTEXPR const char CLAP_EXT_CONFIGURABLE_AUDIO_PORTS[] =
"clap.configurable-audio-ports.draft0";
"clap.configurable-audio-ports.draft1";
abique marked this conversation as resolved.
Show resolved Hide resolved

typedef struct clap_audio_port_configuration_request {
// When true, allows the plugin to pick a similar port configuration instead
// if the requested one can't be applied.
bool is_best_effort;

// Identifies the port by is_input and port_index
bool is_input;
uint32_t port_index;
Expand All @@ -30,27 +26,19 @@ typedef struct clap_audio_port_configuration_request {
// - CLAP_PORT_MONO: (discard)
// - CLAP_PORT_STEREO: (discard)
// - CLAP_PORT_SURROUND: const uint8_t *channel_map
// - CLAP_PORT_AMBISONIC: const clap_ambisonic_info_t *info
// - CLAP_PORT_AMBISONIC: const clap_ambisonic_config_t *info
const void *port_details;
} clap_audio_port_configuration_request_t;

typedef struct clap_plugin_configurable_audio_ports {
// Some ports may not be configurable, or simply the result of another port configuration.
// For example if you have a simple delay plugin, then the output port must have the exact
// same type as the input port; in that example, we consider the output port type to be a
// function (identity) of the input port type.
// [main-thread && !active]
bool(CLAP_ABI *is_port_configurable)(const clap_plugin_t *plugin,
bool is_input,
uint32_t port_index);

// Submit a bunch of configuration requests which will atomically be applied together,
// or discarded together.
// If is_dry_run is true, then checks if the configuration can be applied.
// If is_dry_run is true, then applies the configuration.
abique marked this conversation as resolved.
Show resolved Hide resolved
// Returns true if applied.
abique marked this conversation as resolved.
Show resolved Hide resolved
// [main-thread && !active]
bool(CLAP_ABI *request_configuration)(
const clap_plugin_t *plugin,
const struct clap_audio_port_configuration_request *requests,
uint32_t request_count);
bool(CLAP_ABI *apply_configuration)(const clap_plugin_t *plugin,
abique marked this conversation as resolved.
Show resolved Hide resolved
abique marked this conversation as resolved.
Show resolved Hide resolved
const struct clap_audio_port_configuration_request *requests,
uint32_t request_count,
bool is_dry_run);
} clap_plugin_configurable_audio_ports_t;

#ifdef __cplusplus
Expand Down
18 changes: 9 additions & 9 deletions include/clap/ext/draft/surround.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
// 3. host calls clap_plugin_surround->get_channel_map()
// 4. host activates the plugin and can start processing audio

static CLAP_CONSTEXPR const char CLAP_EXT_SURROUND[] = "clap.surround.draft/3";
static CLAP_CONSTEXPR const char CLAP_EXT_SURROUND[] = "clap.surround.draft/4";

static CLAP_CONSTEXPR const char CLAP_PORT_SURROUND[] = "surround";

Expand Down Expand Up @@ -54,21 +54,21 @@ enum {
};

typedef struct clap_plugin_surround {
// Stores into the channel_map array, the surround identifier of each channel.
// Checks if a given channel mask is supported.
// The channel mask is a bitmask, for example:
// (1 << CLAP_SURROUND_FL) | (1 << CLAP_SURROUND_FR) | ...
// [main-thread]
bool(CLAP_ABI *is_channel_mask_supported)(const clap_plugin_t *plugin, uint64_t channel_mask);

// Stores the surround identifier of each channel into the channel_map array.
// Returns the number of elements stored in channel_map.
//
// config_id: the configuration id, see clap_plugin_audio_ports_config.
// If config_id is CLAP_INVALID_ID, then this function queries the current port info.
// channel_map_capacity should be greater or equal to the channel count of the given port.
abique marked this conversation as resolved.
Show resolved Hide resolved
// [main-thread]
uint32_t(CLAP_ABI *get_channel_map)(const clap_plugin_t *plugin,
bool is_input,
uint32_t port_index,
uint8_t *channel_map,
uint32_t channel_map_capacity);

// Informs the plugin that the host preferred channel map has changed.
// [main-thread]
void(CLAP_ABI *changed)(const clap_plugin_t *plugin);
} clap_plugin_surround_t;

typedef struct clap_host_surround {
Expand Down
17 changes: 7 additions & 10 deletions include/clap/ext/gui.h
Original file line number Diff line number Diff line change
Expand Up @@ -147,28 +147,25 @@ typedef struct clap_plugin_gui {
bool(CLAP_ABI *get_size)(const clap_plugin_t *plugin, uint32_t *width, uint32_t *height);

// Returns true if the window is resizeable (mouse drag).
// Only for embedded windows.
// [main-thread]
// [main-thread & !floating]
bool(CLAP_ABI *can_resize)(const clap_plugin_t *plugin);

// Returns true if the plugin can provide hints on how to resize the window.
// [main-thread]
// [main-thread & !floating]
bool(CLAP_ABI *get_resize_hints)(const clap_plugin_t *plugin, clap_gui_resize_hints_t *hints);

// If the plugin gui is resizable, then the plugin will calculate the closest
// usable size which fits in the given size.
// This method does not change the size.
//
// Only for embedded windows.
//
// Returns true if the plugin could adjust the given size.
// [main-thread]
// [main-thread & !floating]
bool(CLAP_ABI *adjust_size)(const clap_plugin_t *plugin, uint32_t *width, uint32_t *height);

// Sets the window size. Only for embedded windows.
// Sets the window size.
//
// Returns true if the plugin could resize its window to the given size.
// [main-thread]
// [main-thread & !floating]
bool(CLAP_ABI *set_size)(const clap_plugin_t *plugin, uint32_t width, uint32_t height);

// Embeds the plugin window into the given window.
Expand Down Expand Up @@ -204,7 +201,7 @@ typedef struct clap_plugin_gui {

typedef struct clap_host_gui {
// The host should call get_resize_hints() again.
// [thread-safe]
// [thread-safe & !floating]
void(CLAP_ABI *resize_hints_changed)(const clap_host_t *host);

/* Request the host to resize the client area to width, height.
Expand All @@ -215,7 +212,7 @@ typedef struct clap_host_gui {
* acknowledged the request and will process it asynchronously. If the request then can't be
* satisfied then the host will call set_size() to revert the operation.
*
* [thread-safe] */
* [thread-safe & !floating] */
bool(CLAP_ABI *request_resize)(const clap_host_t *host, uint32_t width, uint32_t height);

/* Request the host to show the plugin gui.
Expand Down