diff options
| author | David Robillard <d@drobilla.net> | 2012-02-17 06:12:25 +0000 | 
|---|---|---|
| committer | David Robillard <d@drobilla.net> | 2012-02-17 06:12:25 +0000 | 
| commit | 9db204f703d338e7b6434fccdedb1050c9124bf6 (patch) | |
| tree | b106d8520cbef66efc48cff1e3fd5468c87db085 | |
| parent | 64f7c134aabf7b336b90cf3b8954a791ae91b546 (diff) | |
| download | lv2-9db204f703d338e7b6434fccdedb1050c9124bf6.tar.xz | |
Add LV2_Atom_Port_Buffer.
| -rw-r--r-- | lv2/lv2plug.in/ns/ext/atom/atom.h | 23 | ||||
| -rw-r--r-- | lv2/lv2plug.in/ns/ext/atom/atom.ttl | 11 | ||||
| -rw-r--r-- | plugins/eg-sampler.lv2/sampler.c | 12 | 
3 files changed, 37 insertions, 9 deletions
| diff --git a/lv2/lv2plug.in/ns/ext/atom/atom.h b/lv2/lv2plug.in/ns/ext/atom/atom.h index fd0279c..66f0490 100644 --- a/lv2/lv2plug.in/ns/ext/atom/atom.h +++ b/lv2/lv2plug.in/ns/ext/atom/atom.h @@ -196,6 +196,29 @@ typedef struct {  	/* Contents (a series of events) follow here. */  } LV2_Atom_Sequence; +/** +   The contents of an atom:AtomPort buffer. + +   This contains a pointer to an Atom, which is the data to be +   processed/written, as well as additional metadata.  This struct may be +   augmented in the future to add more metadata fields as they become +   necessary.  The initial version of this struct contains data, size, and +   capacity.  Implementations MUST check that any other fields they wish to use +   are actually present by comparing the size with the offset of that field, +   e.g.: + +   @code +   if (offsetof(LV2_Atom_Port_Buffer, field) < buf->size) { +       do_stuff_with(buf->field); +   } +   @endcode +*/ +typedef struct { +	LV2_Atom* data;      /** Pointer to data. */ +	uint32_t  size;      /** Total size of this struct. */ +	uint32_t  capacity;  /** Available space for data body. */ +} LV2_Atom_Port_Buffer; +  #ifdef __cplusplus  }  /* extern "C" */  #endif diff --git a/lv2/lv2plug.in/ns/ext/atom/atom.ttl b/lv2/lv2plug.in/ns/ext/atom/atom.ttl index b19425f..70a1252 100644 --- a/lv2/lv2plug.in/ns/ext/atom/atom.ttl +++ b/lv2/lv2plug.in/ns/ext/atom/atom.ttl @@ -389,9 +389,14 @@ atom:AtomPort  	rdfs:subClassOf lv2:Port ;  	rdfs:label "Atom Port" ;  	lv2:documentation """ -<p>A port which contains an lv2:Atom.  Ports of this type will be connected to -a 64-bit aligned LV2_Atom immediately followed by <code>size</code> bytes of -data.</p> +<p>A port which contains an lv2:Atom.  Ports of this type are connected to an +LV2_Atom_Port_Buffer, which contains a pointer to the port's Atom contents, as +well as other metadata (such as capacity, for output ports with variably sized +types).  The host MUST set all fields of LV2_Atom_Port_Buffer to appropriate +values before calling the plugin's run method.  LV2_Atom_Port_Buffer::capacity +must be set to the available space for the <em>body</em> of LV2_Atom_Port_Buffer::data, +i.e. the maximum possible value for its <code>size</code> field, which does +not include the LV2_Atom header.</p>  <p>This is an abstract port type with incomplete semantics which can not be  used directly as a port type.  Atom ports should be either a atom:ValuePort or diff --git a/plugins/eg-sampler.lv2/sampler.c b/plugins/eg-sampler.lv2/sampler.c index 65339c7..82a374c 100644 --- a/plugins/eg-sampler.lv2/sampler.c +++ b/plugins/eg-sampler.lv2/sampler.c @@ -82,9 +82,9 @@ typedef struct {  	Sample* sample;  	/* Ports */ -	float*             output_port; -	LV2_Atom_Sequence* control_port; -	LV2_Atom_Sequence* response_port; +	float*                output_port; +	LV2_Atom_Port_Buffer* control_port; +	LV2_Atom_Port_Buffer* notify_port;  	/* URIs */  	SamplerURIs uris; @@ -273,10 +273,10 @@ connect_port(LV2_Handle instance,  	switch (port) {  	case SAMPLER_CONTROL: -		plugin->control_port = (LV2_Atom_Sequence*)data; +		plugin->control_port = (LV2_Atom_Port_Buffer*)data;  		break;  	case SAMPLER_RESPONSE: -		plugin->response_port = (LV2_Atom_Sequence*)data; +		plugin->notify_port = (LV2_Atom_Port_Buffer*)data;  		break;  	case SAMPLER_OUT:  		plugin->output_port = (float*)data; @@ -386,7 +386,7 @@ run(LV2_Handle instance,  	float*     output      = plugin->output_port;  	/* Read incoming events */ -	LV2_SEQUENCE_FOREACH(plugin->control_port, i) { +	LV2_SEQUENCE_FOREACH((LV2_Atom_Sequence*)plugin->control_port->data, i) {  		LV2_Atom_Event* const ev = lv2_sequence_iter_get(i);  		if (ev->body.type == plugin->uris.midi_Event) {  			uint8_t* const data = (uint8_t* const)(ev + 1); |