Rasqal RDF Query Library Manual | ||||
---|---|---|---|---|
Top | Description |
typedef rasqal_literal; enum rasqal_literal_type; rasqal_literal * rasqal_new_typed_literal (rasqal_world *world
,rasqal_literal_type type
,const unsigned char *string
); rasqal_literal * rasqal_new_boolean_literal (rasqal_world *world
,int value
); rasqal_literal * rasqal_new_datetime_literal_from_datetime (rasqal_world *world
,rasqal_xsd_datetime *dt
); rasqal_literal * rasqal_new_decimal_literal (rasqal_world *world
,const char *string
); rasqal_literal * rasqal_new_decimal_literal_from_decimal (rasqal_world *world
,const char *string
,rasqal_xsd_decimal *decimal
); rasqal_literal * rasqal_new_double_literal (rasqal_world *world
,double d
); rasqal_literal * rasqal_new_float_literal (rasqal_world *world
,float f
); rasqal_literal * rasqal_new_floating_literal (rasqal_world *world
,rasqal_literal_type type
,double d
); rasqal_literal * rasqal_new_integer_literal (rasqal_world *world
,rasqal_literal_type type
,int integer
); rasqal_literal * rasqal_new_numeric_literal_from_long (rasqal_world *world
,rasqal_literal_type type
,long value Param3
); rasqal_literal * rasqal_new_pattern_literal (rasqal_world *world
,const char *pattern
,const char *flags
); rasqal_literal * rasqal_new_simple_literal (rasqal_world *world
,rasqal_literal_type type
,const char *string
); rasqal_literal * rasqal_new_string_literal (rasqal_world *world
,const char *string
,const char *language
,raptor_uri *datatype
,const unsigned char *datatype_qname
); rasqal_literal * rasqal_new_uri_literal (rasqal_world *world
,raptor_uri *uri
); rasqal_literal * rasqal_new_variable_literal (rasqal_world *world
,rasqal_variable *variable
); rasqal_literal * rasqal_new_literal_from_literal (rasqal_literal *l
); void rasqal_free_literal (rasqal_literal *l
); rasqal_literal * rasqal_literal_as_node (rasqal_literal *l
); const unsigned char * rasqal_literal_as_counted_string (rasqal_literal *l
,size_t *len_p
,int flags
,int *error_p
); const unsigned char * rasqal_literal_as_string (rasqal_literal *l
); const unsigned char * rasqal_literal_as_string_flags (rasqal_literal *l
,int flags
,int *error_p
); rasqal_variable * rasqal_literal_as_variable (rasqal_literal *l
); int rasqal_literal_compare (rasqal_literal *l1
,rasqal_literal *l2
,int flags
,int *error_p
); raptor_uri * rasqal_literal_datatype (rasqal_literal *l
); int rasqal_literal_equals (rasqal_literal *l1
,rasqal_literal *l2
); char * rasqal_literal_get_language (rasqal_literal *l
); rasqal_literal_type rasqal_literal_get_rdf_term_type (rasqal_literal *l
); rasqal_literal_type rasqal_literal_get_type (rasqal_literal *l
); int rasqal_literal_is_rdf_literal (rasqal_literal *l
); int rasqal_literal_print (rasqal_literal *l
,FILE *fh
); void rasqal_literal_print_type (rasqal_literal *l
,FILE *fh
); const char * rasqal_literal_type_label (rasqal_literal_type type
); int rasqal_literal_same_term (rasqal_literal *l1
,rasqal_literal *l2
); rasqal_literal * rasqal_literal_value (rasqal_literal *l
);
A class for handling RDF terms (URI, blank nodes, strings, datatyped literals) as well as those natively used in a query such as boolean, double, floating, integer, regex pattern and variables.
typedef enum { /* internal */ RASQAL_LITERAL_UNKNOWN, RASQAL_LITERAL_BLANK, RASQAL_LITERAL_URI, RASQAL_LITERAL_STRING, RASQAL_LITERAL_XSD_STRING, RASQAL_LITERAL_BOOLEAN, RASQAL_LITERAL_INTEGER, RASQAL_LITERAL_FLOAT, RASQAL_LITERAL_DOUBLE, RASQAL_LITERAL_DECIMAL, RASQAL_LITERAL_DATETIME, /* internal */ RASQAL_LITERAL_FIRST_XSD = RASQAL_LITERAL_XSD_STRING, /* internal */ RASQAL_LITERAL_LAST_XSD = RASQAL_LITERAL_DATETIME, RASQAL_LITERAL_UDT, RASQAL_LITERAL_PATTERN, RASQAL_LITERAL_QNAME, RASQAL_LITERAL_VARIABLE, /* internal */ RASQAL_LITERAL_INTEGER_SUBTYPE, RASQAL_LITERAL_DATE, /* internal */ RASQAL_LITERAL_LAST = RASQAL_LITERAL_DATE } rasqal_literal_type;
Types of literal.
The order in the enumeration is significant as it encodes the SPARQL term ordering conditions:
Blank Nodes << IRIs << RDF literals << typed literals
which coresponds to in enum values
BLANK << URI << STRING << (BOOLEAN | INTEGER | DOUBLE | FLOAT | DECIMAL | DATETIME | XSD_STRING)
(RASQAL_LITERAL_FIRST_XSD ... RASQAL_LITERAL_LAST_XSD)
Not used (internal): PATTERN, QNAME, VARIABLE
See rasqal_literal_compare()
when used with flags
RASQAL_COMPARE_XQUERY
Internal. | |
RDF blank node literal (SPARQL r:bNode) | |
RDF URI Literal (SPARQL r:URI) | |
RDF Plain Literal - no datatype (SPARQL r:Literal) | |
String xsd:string | |
Boolean literal xsd:boolean. | |
Integer literal xsd:integer. | |
Floating point literal xsd:float. | |
Double floating point literal xsd:double. | |
Decimal integer xsd:decimal. | |
Date/Time literal xsd:dateTime. | |
Internal. | |
Internal. | |
User defined typed literal with unknown datatype URI | |
Pattern literal for a regex. | |
XML Qname literal. | |
Variable literal. | |
Internal. | |
Date literal xsd:date. | |
Internal. |
rasqal_literal * rasqal_new_typed_literal (rasqal_world *world
,rasqal_literal_type type
,const unsigned char *string
);
Constructor - Create a new Rasqal integer literal from a string
The integer decimal number is turned into a rasqal integer literal and given a datatype of xsd:integer
|
rasqal world object |
|
Type of literal such as RASQAL_LITERAL_INTEGER or RASQAL_LITERAL_BOOLEAN |
|
lexical form - ownership not taken |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_boolean_literal (rasqal_world *world
,int value
);
Constructor - Create a new Rasqal boolean literal.
|
rasqal world object |
|
non-0 for true, 0 for false |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_datetime_literal_from_datetime (rasqal_world *world
,rasqal_xsd_datetime *dt
);
Constructor - Create a new Rasqal datetime literal from an existing datetime.
Takes ownership of dt
|
rasqal world object |
|
rasqal XSD Datetime |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_decimal_literal (rasqal_world *world
,const char *string
);
Constructor - Create a new Rasqal decimal literal.
|
rasqal world object |
|
decimal literal |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_decimal_literal_from_decimal (rasqal_world *world
,const char *string
,rasqal_xsd_decimal *decimal
);
Constructor - Create a new Rasqal decimal literal.
|
rasqal world object |
|
decimal literal string |
|
rasqal XSD Decimal |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_double_literal (rasqal_world *world
,double d
);
Constructor - Create a new Rasqal double literal.
|
rasqal world object |
|
double literal |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_float_literal (rasqal_world *world
,float f
);
Constructor - Create a new Rasqal float literal.
Deprecated
: Use rasqal_new_floating_literal()
with type
RASQAL_LITERAL_FLOAT and double value.
|
rasqal world object |
|
float literal |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_floating_literal (rasqal_world *world
,rasqal_literal_type type
,double d
);
Constructor - Create a new Rasqal float literal from a double.
|
rasqal world object |
|
type - RASQAL_LITERAL_FLOAT or RASQAL_LITERAL_DOUBLE |
|
floating literal (double) |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_integer_literal (rasqal_world *world
,rasqal_literal_type type
,int integer
);
Constructor - Create a new Rasqal integer literal.
The integer decimal number is turned into a rasqal integer literal and given a datatype of xsd:integer
|
rasqal world object |
|
Type of literal such as RASQAL_LITERAL_INTEGER or RASQAL_LITERAL_BOOLEAN |
|
int value |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_numeric_literal_from_long (rasqal_world *world
,rasqal_literal_type type
,long value Param3
);
Constructor - Create a new Rasqal numeric literal from a long.
The value is turned into a rasqal integer or decimal literal and given a datatype of xsd:integer
|
rasqal world object |
|
Type of literal such as RASQAL_LITERAL_INTEGER or RASQAL_LITERAL_BOOLEAN |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_pattern_literal (rasqal_world *world
,const char *pattern
,const char *flags
);
Constructor - Create a new Rasqal pattern literal.
The pattern and flags are input parameters and are stored in the literal, not copied. They are freed also on failure. The set of flags recognised depends on the regex library and the query language.
|
rasqal world object |
|
regex pattern |
|
regex flags |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_simple_literal (rasqal_world *world
,rasqal_literal_type type
,const char *string
);
Constructor - Create a new Rasqal simple literal.
The string is an input parameter and is stored in the literal, not copied. It is freed also on failure.
|
rasqal world object |
|
RASQAL_LITERAL_BLANK or RASQAL_LITERAL_BLANK_QNAME |
|
the UTF-8 string value to store |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_string_literal (rasqal_world *world
,const char *string
,const char *language
,raptor_uri *datatype
,const unsigned char *datatype_qname
);
Constructor - Create a new Rasqal string literal.
All parameters are input parameters and if present are stored in the literal, not copied. They are freed also on failure.
The datatype and datatype_qname parameters are alternatives; the qname is a datatype that cannot be resolved till later since the prefixes have not yet been declared or checked.
If the string literal is datatyped and of certain types recognised it may be converted to a different literal type.
|
rasqal world object |
|
UTF-8 string lexical form |
|
RDF language (xml:lang) (or NULL) |
|
datatype URI (or NULL for plain literal) |
|
datatype qname string (or NULL for plain literal) |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_uri_literal (rasqal_world *world
,raptor_uri *uri
);
Constructor - Create a new Rasqal URI literal from a raptor URI.
The uri is an input parameter and is stored in the literal, not copied. The uri is freed also on failure.
|
rasqal world object |
|
raptor_uri uri |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_variable_literal (rasqal_world *world
,rasqal_variable *variable
);
Constructor - Create a new Rasqal variable literal.
variable is an input parameter and stored in the literal, not copied.
|
rasqal_world object |
|
rasqal_variable to use |
Returns : |
New rasqal_literal or NULL on failure |
rasqal_literal * rasqal_new_literal_from_literal (rasqal_literal *l
);
Copy Constructor - create a new rasqal_literal object from an existing rasqal_literal object.
|
rasqal_literal object to copy or NULL |
Returns : |
a new rasqal_literal object or NULL if l was NULL. |
void rasqal_free_literal (rasqal_literal *l
);
Destructor - destroy an rasqal_literal object.
|
rasqal_literal object |
rasqal_literal * rasqal_literal_as_node (rasqal_literal *l
);
Turn a literal into a new RDF string, URI or blank literal.
|
rasqal_literal object |
Returns : |
the new rasqal_literal or NULL on failure or if the literal was an unbound variable. |
const unsigned char * rasqal_literal_as_counted_string (rasqal_literal *l
,size_t *len_p
,int flags
,int *error_p
);
Return a counted string format of a literal according to flags.
flag bits affects conversion: RASQAL_COMPARE_XQUERY: use XQuery conversion rules
If error
is not NULL, *error is set to non-0 on error
|
rasqal_literal object |
|
pointer to store length of string (or NULL) |
|
comparison flags |
|
pointer to error |
Returns : |
pointer to a shared string format of the literal. |
const unsigned char * rasqal_literal_as_string (rasqal_literal *l
);
Return the string format of a literal.
|
rasqal_literal object |
Returns : |
pointer to a shared string format of the literal. |
const unsigned char * rasqal_literal_as_string_flags (rasqal_literal *l
,int flags
,int *error_p
);
Return the string format of a literal according to flags.
flag bits affects conversion: RASQAL_COMPARE_XQUERY: use XQuery conversion rules
If error
is not NULL, *error is set to non-0 on error
|
rasqal_literal object |
|
comparison flags |
|
pointer to error |
Returns : |
pointer to a shared string format of the literal. |
rasqal_variable * rasqal_literal_as_variable (rasqal_literal *l
);
Get the variable inside a literal.
|
rasqal_literal object |
Returns : |
the rasqal_variable or NULL if the literal is not a variable |
int rasqal_literal_compare (rasqal_literal *l1
,rasqal_literal *l2
,int flags
,int *error_p
);
Compare two literals with type promotion.
The two literals are compared across their range. If the types are not the same, they are promoted. If one is a double or float, the other is promoted to double, otherwise for integers, otherwise to strings (all literals have a string value).
The comparison returned is as for strcmp, first before second returns <0. equal returns 0, and first after second returns >0. For URIs, the string value is used for the comparsion.
flag bits affects comparisons: RASQAL_COMPARE_NOCASE: use case independent string comparisons RASQAL_COMPARE_XQUERY: use XQuery comparison and type promotion rules RASQAL_COMPARE_RDF: use RDF term comparison RASQAL_COMPARE_URI: allow comparison of URIs (typically for SPARQL ORDER)
If error
is not NULL, *error is set to non-0 on error
|
rasqal_literal first literal |
|
rasqal_literal second literal |
|
comparison flags |
|
pointer to error |
Returns : |
<0, 0, or >0 as described above. |
raptor_uri * rasqal_literal_datatype (rasqal_literal *l
);
Get the datatype URI of a literal
|
rasqal_literal object |
Returns : |
shared pointer to raptor_uri of datatype or NULL on failure or no value |
int rasqal_literal_equals (rasqal_literal *l1
,rasqal_literal *l2
);
Compare two literals with no type promotion.
If the l2 data literal value is a boolean, it will match the string "true" or "false" in the first literal l1.
|
rasqal_literal literal |
|
rasqal_literal data literal |
Returns : |
non-0 if equal |
char * rasqal_literal_get_language (rasqal_literal *l
);
Get the language of a literal (if set)
|
literal |
Returns : |
the literal language or NULL |
rasqal_literal_type rasqal_literal_get_rdf_term_type (rasqal_literal *l
);
Get the RDF term type of a literal
An RDF term can be one of three choices: 1. URI: RASQAL_LITERAL_URI 2. literal: RASQAL_LITERAL_STRING 3. blank node: RASQAL_LITERAL_BLANK
Other non RDF-term cases include: NULL pointer, invalid literal, unknown type, a variable or other special cases (such as XML QName or Regex pattern) which all turn into RASQAL_LITERAL_UNKNOWN
|
literal |
Returns : |
type or RASQAL_LITERAL_UNKNOWN if cannot be an RDF term |
rasqal_literal_type rasqal_literal_get_type (rasqal_literal *l
);
Get the type of a literal
|
literal |
Returns : |
the rasqal literal type or RASQAL_LITERAL_UNKNOWN if l is NULL |
int rasqal_literal_is_rdf_literal (rasqal_literal *l
);
Check if a literal is any RDF term literal - plain or typed literal
|
rasqal_literal literal |
Returns : |
non-0 if the value is an RDF term literal |
int rasqal_literal_print (rasqal_literal *l
,FILE *fh
);
Print a Rasqal literal in a debug format.
The print debug format may change in any release.
|
the rasqal_literal object |
|
the FILE handle to print to |
Returns : |
non-0 on failure |
void rasqal_literal_print_type (rasqal_literal *l
,FILE *fh
);
Print a string form for a rasqal literal type.
|
the rasqal_literal object |
|
the FILE* handle to print to |
const char * rasqal_literal_type_label (rasqal_literal_type type
);
Get a label for the rasqal literal type
|
the rasqal_literal_type object |
Returns : |
the label (shared string) or NULL if type is out of range or unknown |
int rasqal_literal_same_term (rasqal_literal *l1
,rasqal_literal *l2
);
Check if literals are same term (URI, literal, blank)
|
rasqal_literal literal |
|
rasqal_literal data literal |
Returns : |
non-0 if same |
rasqal_literal * rasqal_literal_value (rasqal_literal *l
);
Get the literal value looking up any variables needed
|
rasqal_literal object |
Returns : |
literal value or NULL if has no value |