- From: Toby Inkster <tai@g5n.co.uk>
- Date: Tue, 4 Jan 2011 19:26:47 +0000
- To: Semantic Web community <semantic-web@w3.org>, public-rdfa-wg@w3.org
SPARQL has a number of built-in functions like STR() and REGEX() which can be used in filters, and since SPARQL 1.1, can be bound as results. As well as the built-in functions, SPARQL can be extended with additional functions which are identified by URIs. While there's no requirement that those URIs be dereferencable, experience from linked data tells us that it's probably a good idea for them to be. But what should be the representation delivered when a client dereferences them? I've been writing a few extension functions for Gregory Williams' RDF::Query Perl SPARQL implementation recently, so I was pondering this question and stumbled upon what I think is a pretty good solution. Take for example, the function I've defined which takes no parameters and returns a UUID string as a literal. That function has the URI: http://buzzword.org.uk/2011/functions/util#uuid If you dereference that URI sending "Accept: application/ecmascript" you'll get an ECMAScript (JavaScript) implementation of the function, built on the RDF API which is currently being worked on by the RDFa Working Group. The ECMAScript implementations there aren't directly used by the Perl implementation - they just serve as documentation for the functions identified by the URIs. What do people think of this as a solution for documenting SPARQL extension functions? -- Toby A Inkster <mailto:mail@tobyinkster.co.uk> <http://tobyinkster.co.uk>
Received on Tuesday, 4 January 2011 19:28:41 UTC