From 2b809fbf4090ae64d728988454c4f1b721f4c323 Mon Sep 17 00:00:00 2001
From: David Robillard
Atoms can and should be used anywhere values of various types must be stored or transmitted. The port type atom:AtomPort can be used to transmit atoms via ports. The atom:Sequence type in an atom:AtomPort replaces the LV2 event extension.
+href="../event/event.html">LV2 event extension.The types defined in this extension should be powerful enough to express almost any structure. Implementations SHOULD build structures out of the types @@ -38,8 +38,7 @@ implementation burden which harms interoperabilty, and should only be defined where absolutely necessary.
Implementing this extension requires a facility for mapping URIs to -integers, such as the LV2 URID -extension.
+integers, such as the LV2 URID extension.This extension only defines data-only features and properties and has no C -API of its own. The host provides all the relevant information to the plugin as options
+This extension defines features and properties but has no special purpose +API of its own. The host provides all the relevant information to the plugin +as options.
To require restrictions on the block length, plugins can require additional features: bufsz:boundedBlockLength, bufsz:powerOf2BlockLength, and diff --git a/lv2/lv2plug.in/ns/ext/midi/midi.ttl b/lv2/lv2plug.in/ns/ext/midi/midi.ttl index a9153e8..faddc36 100644 --- a/lv2/lv2plug.in/ns/ext/midi/midi.ttl +++ b/lv2/lv2plug.in/ns/ext/midi/midi.ttl @@ -20,8 +20,8 @@ controlling digital music devices.
For plugins that process MIDI (or other situations where MIDI is sent via a generic transport) the main type defined here, midi:MidiEvent, can be mapped to an integer and used as the type of an LV2 Atom or Event.
+href="../atom/atom.html#Atom">Atom or Event.This specification also defines a complete human and machine readable description of the MIDI standard (except for standard controller numbers). diff --git a/lv2/lv2plug.in/ns/ext/parameters/parameters.ttl b/lv2/lv2plug.in/ns/ext/parameters/parameters.ttl index 87ee8d6..8f05f74 100644 --- a/lv2/lv2plug.in/ns/ext/parameters/parameters.ttl +++ b/lv2/lv2plug.in/ns/ext/parameters/parameters.ttl @@ -11,10 +11,9 @@ lv2:documentation """
This vocabulary describes parameters common in audio processing software. A
parameter
is purely a metadata concept, unrelated to any particular code
-mechanism. Parameters are used to assign meaning to controls (e.g. using lv2:designation) so they
-can be used more intelligently or presented to the user more efficiently.
The main feature of this design is that the messages themselves are described in the same format as the data they work with. In particular, -messages can be serialised as an LV2 Object or in Turtle (or any -other RDF serialisation).
+messages can be serialised as a binary Object or in Turtle (or any other RDF +serialisation).The idea behind using a property-based interface for control is to prevent an an explosion of message types. Instead of a custom message for each action, @@ -37,9 +37,9 @@ One benefit of this approach is that a persistent state model is available
This specification is strictly metadata and does not define any binary mechanism, though it can be completely expressed by standard types in the LV2 Atom extension. Thus, hosts can -be expected to be capable of transmitting it between plugins, or between a -plugin and its UI, making it a good choice for advanced plugin control.
+href="../atom/atom.html">LV2 Atom extension. Thus, hosts can be expected +to be capable of transmitting it between plugins, or between a plugin and its +UI, making it a good choice for advanced plugin control. """ . patch:Ack diff --git a/lv2/lv2plug.in/ns/ext/state/state.ttl b/lv2/lv2plug.in/ns/ext/state/state.ttl index 751a6e3..a9b997c 100644 --- a/lv2/lv2plug.in/ns/ext/state/state.ttl +++ b/lv2/lv2plug.in/ns/ext/state/state.ttl @@ -45,10 +45,10 @@ single property. The host is free to implement property storage and retrieval in any way.Since value types are defined by URI, any type is possible. However, a set -of standard types is defined by the LV2 -Atom extension. Use of these types is recommended. Hosts MUST implement -at least atom:String, which -is simply a C string.
+of standard types is defined by the LV2 Atom +extension. Use of these types is recommended. Hosts MUST implement at least +atom:String, which is simply a C +string.Plugins are strongly encouraged to avoid creating files, instead storing all state as properties. However, occasionally the ability to create files is @@ -206,11 +205,10 @@ plugins.
Don't stop; set playing to false.
This extension does not define a dynamic mechanism for state access and -manipulation. The LV2 Patch -extension defines a generic set of messages which can be used to access or -manipulate properties, and the LV2 -Atom extension defines a port type and data container capable of -transmitting those messages.
+manipulation. The LV2 Patch extension +defines a generic set of messages which can be used to access or manipulate +properties, and the LV2 Atom extension defines +a port type and data container capable of transmitting those messages. """ . state:interface diff --git a/lv2/lv2plug.in/ns/ext/uri-map/uri-map.ttl b/lv2/lv2plug.in/ns/ext/uri-map/uri-map.ttl index 96acbcd..7f6b0e7 100644 --- a/lv2/lv2plug.in/ns/ext/uri-map/uri-map.ttl +++ b/lv2/lv2plug.in/ns/ext/uri-map/uri-map.ttl @@ -11,7 +11,7 @@This extension is deprecated. New -implementations should use LV2 URID +implementations should use LV2 URID instead.
This extension defines a simple mechanism for plugins to map URIs to diff --git a/lv2/lv2plug.in/ns/ext/urid/urid.ttl b/lv2/lv2plug.in/ns/ext/urid/urid.ttl index 3b8adcd..29b196a 100644 --- a/lv2/lv2plug.in/ns/ext/urid/urid.ttl +++ b/lv2/lv2plug.in/ns/ext/urid/urid.ttl @@ -15,10 +15,10 @@ thread without doing any string comparison. This allows for the extensibility of RDF but with the performance of integers.
This extension is intended as an improved and simplified replacement for the
-uri-map extension, since the
-map
context parameter has been found problematic. This extension is
-functionally equivalent to the uri-map extension with a NULL context. New
-implementations are encouraged to use this extension for URI mapping.
map+context parameter has been found problematic. This extension is functionally +equivalent to the uri-map extension with a NULL context. New implementations +are encouraged to use this extension for URI mapping. """ . urid:map diff --git a/lv2specgen/lv2specgen.py b/lv2specgen/lv2specgen.py index 37b2cef..9974265 100755 --- a/lv2specgen/lv2specgen.py +++ b/lv2specgen/lv2specgen.py @@ -277,28 +277,26 @@ def getComment(m, urinode, classlist, proplist, instalist): # Add links to code documentation for identifiers markup = linkify(markup) - # Replace ext:ClassName with link to appropriate fragment - rgx = re.compile(spec_pre + ':([A-Z][a-zA-Z0-9_-]*)') - def translateClassLink(match): + # Transform prefixed names like eg:something into links if possible + rgx = re.compile('([a-zA-Z0-9_-]+):([a-zA-Z0-9_-]+)') + namespaces = getNamespaces(m) + def translateLink(match): + text = match.group(0) + prefix = match.group(1) + name = match.group(2) curie = match.group(0) - name = curie[curie.find(':') + 1:] - uri = spec_ns + name - if rdflib.URIRef(uri) not in classlist: - print("warning: Link to undefined class %s\n" % curie) - return '%s' % (name, curie) - markup = rgx.sub(translateClassLink, markup) - - # Replace ext:instanceName with link to appropriate fragment - rgx = re.compile(spec_pre + ':([a-z][a-zA-Z0-9_-]*)') - def translateInstanceLink(match): - curie = match.group(0) - name = curie[curie.find(':') + 1:] - uri = spec_ns + name - if (rdflib.URIRef(uri) not in instalist and - rdflib.URIRef(uri) not in proplist): - print("warning: Link to undefined instance/property %s\n" % curie) - return '%s' % (name, curie) - markup = rgx.sub(translateInstanceLink, markup) + uri = rdflib.URIRef(spec_ns + name) + if prefix == spec_pre: + if not (uri in classlist or uri in instalist or uri in proplist): + print("warning: Link to undefined resource <%s>\n" % text) + return '%s' % (name, curie) + elif prefix in namespaces: + return '%s' % ( + namespaces[match.group(1)] + match.group(2), + match.group(0)) + else: + return text + markup = rgx.sub(translateLink, markup) if have_lxml: try: -- cgit v1.2.1