wok-current diff liblrdf/stuff/raptor2.diff @ rev 18005
busybox: fix using 404 (not found) page; show URL in the page.
author | Aleksej Bobylev <al.bobylev@gmail.com> |
---|---|
date | Tue Apr 28 17:26:09 2015 +0300 (2015-04-28) |
parents | |
children |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/liblrdf/stuff/raptor2.diff Tue Apr 28 17:26:09 2015 +0300 1.3 @@ -0,0 +1,193 @@ 1.4 +--- src/Makefile.am 1.5 ++++ src/Makefile.am 1.6 +@@ -4,5 +4,5 @@ lib_LTLIBRARIES = liblrdf.la 1.7 + noinst_HEADERS = lrdf_md5.h md5_loc.h ladspa.h 1.8 + 1.9 + liblrdf_la_SOURCES = lrdf.c lrdf_multi.c md5.c 1.10 +-liblrdf_la_LIBADD = -lraptor 1.11 ++liblrdf_la_LIBADD = -lraptor2 1.12 + liblrdf_la_LDFLAGS = -version-info @LRDF_LIBTOOL_VERSION@ 1.13 +--- src/lrdf.c 1.14 ++++ src/lrdf.c 1.15 +@@ -18,6 +18,7 @@ 1.16 + static unsigned int lrdf_uid = 0; /* A unique(ish) id to append to genid's to 1.17 + * avoid clashses */ 1.18 + 1.19 ++static raptor_world *world = NULL; 1.20 + static lrdf_statement *triples = NULL; 1.21 + static lrdf_statement *free_triples; 1.22 + static lrdf_string_hash *resources_hash[LRDF_HASH_SIZE]; 1.23 +@@ -43,8 +44,7 @@ static void lrdf_remove_triple_hash(lrdf_triple_hash ** tbl, 1.24 + lrdf_hash hash, lrdf_statement * s); 1.25 + static void lrdf_add_closure_hash(lrdf_closure_hash ** tbl, 1.26 + lrdf_hash subject, lrdf_hash object); 1.27 +-static void lrdf_store(void *user_data, 1.28 +- const raptor_statement * statement); 1.29 ++static void lrdf_store(void *user_data, raptor_statement * statement); 1.30 + void lrdf_free_statements(lrdf_statement * s); 1.31 + void lrdf_copy_statement(lrdf_statement * from, lrdf_statement * to); 1.32 + void lrdf_rebuild_taxonomic_closure(lrdf_closure_hash ** fwd_tbl, 1.33 +@@ -71,7 +71,7 @@ void lrdf_init() 1.34 + unsigned int i; 1.35 + struct timeval tv; 1.36 + 1.37 +- raptor_init(); 1.38 ++ world = raptor_new_world(); 1.39 + lrdf_more_triples(256); 1.40 + 1.41 + /* A UID to add to genids to make them safer */ 1.42 +@@ -112,7 +112,8 @@ void lrdf_more_triples(int count) 1.43 + 1.44 + void lrdf_cleanup() 1.45 + { 1.46 +- raptor_finish(); 1.47 ++ raptor_free_world(world); 1.48 ++ world = NULL; 1.49 + 1.50 + lrdf_free_string_hash(resources_hash); 1.51 + lrdf_free_string_hash(literals_hash); 1.52 +@@ -232,26 +233,29 @@ void lrdf_remove_matches(lrdf_statement *pattern) 1.53 + } 1.54 + } 1.55 + 1.56 +-static void lrdf_store(void *user_data, const raptor_statement * statement) 1.57 ++static const char *lrdf_term_as_string(char *tmp, int tmp_len, 1.58 ++ const raptor_term *term) 1.59 ++{ 1.60 ++ switch (term->type) { 1.61 ++ case RAPTOR_TERM_TYPE_URI: 1.62 ++ return (const char *) raptor_uri_as_string(term->value.uri); 1.63 ++ case RAPTOR_TERM_TYPE_LITERAL: 1.64 ++ return (const char *) term->value.literal.string; 1.65 ++ case RAPTOR_TERM_TYPE_BLANK: 1.66 ++ snprintf(tmp, tmp_len, "_:%s.%x", term->value.blank.string, lrdf_uid); 1.67 ++ return tmp; 1.68 ++ default: 1.69 ++ return "(?)"; 1.70 ++ } 1.71 ++} 1.72 ++ 1.73 ++static void lrdf_store(void *user_data, raptor_statement * statement) 1.74 + { 1.75 + lrdf_statement *s = lrdf_alloc_statement(); 1.76 + char tmps[128], tmpp[128], tmpo[128]; 1.77 +- char *subj = (char *) statement->subject, 1.78 +- *pred = (char *) statement->predicate, 1.79 +- *obj = (char *) statement->object; 1.80 +- 1.81 +- if (statement->subject_type == RAPTOR_IDENTIFIER_TYPE_ANONYMOUS) { 1.82 +- snprintf(tmps, 127, "_:%s.%x", subj, lrdf_uid); 1.83 +- subj = tmps; 1.84 +- } 1.85 +- if (statement->predicate_type == RAPTOR_IDENTIFIER_TYPE_ANONYMOUS) { 1.86 +- snprintf(tmpp, 127, "_:%s.%x", pred, lrdf_uid); 1.87 +- pred = tmpp; 1.88 +- } 1.89 +- if (statement->object_type == RAPTOR_IDENTIFIER_TYPE_ANONYMOUS) { 1.90 +- snprintf(tmpo, 127, "_:%s.%x", obj, lrdf_uid); 1.91 +- obj = tmpo; 1.92 +- } 1.93 ++ const char *subj = lrdf_term_as_string(tmps, 128, statement->subject), 1.94 ++ *pred = lrdf_term_as_string(tmpp, 128, statement->predicate), 1.95 ++ *obj = lrdf_term_as_string(tmpo, 128, statement->object); 1.96 + 1.97 + s->shash = lrdf_gen_hash(subj); 1.98 + s->phash = lrdf_gen_hash(pred); 1.99 +@@ -261,7 +265,7 @@ static void lrdf_store(void *user_data, const raptor_statement * statement) 1.100 + 1.101 + s->subject = lrdf_check_hash(resources_hash, s->shash, subj); 1.102 + s->predicate = lrdf_check_hash(resources_hash, s->phash, pred); 1.103 +- if (statement->object_type == RAPTOR_IDENTIFIER_TYPE_LITERAL) { 1.104 ++ if (statement->object->type == RAPTOR_TERM_TYPE_LITERAL) { 1.105 + s->object = lrdf_check_hash(literals_hash, s->ohash, obj); 1.106 + s->object_type = lrdf_literal; 1.107 + } else { 1.108 +@@ -537,28 +541,22 @@ void lrdf_rebuild_taxonomic_closure(lrdf_closure_hash ** fwd_tbl, 1.109 + free(pathto); 1.110 + } 1.111 + 1.112 +-static void lrdf_error_handler(void *data, raptor_locator * locator, 1.113 +- const char *message); 1.114 ++static void lrdf_log_handler(void *data, raptor_log_message *message); 1.115 + 1.116 +-static void lrdf_error_handler(void *data, raptor_locator * locator, 1.117 +- const char *message) 1.118 ++static void lrdf_log_handler(void *data, raptor_log_message *message) 1.119 + { 1.120 +- fprintf(stderr, "liblrdf: error - "); 1.121 +- raptor_print_locator(stderr, locator); 1.122 +- fprintf(stderr, " - %s\n", message); 1.123 +- 1.124 +- raptor_parse_abort((raptor_parser*)data); 1.125 +-} 1.126 ++ const char *severity = "error"; 1.127 ++ if (message->level == RAPTOR_LOG_LEVEL_WARN) { 1.128 ++ severity = "warning"; 1.129 ++ } 1.130 + 1.131 +-static void lrdf_warning_handler(void *data, raptor_locator * locator, 1.132 +- const char *message); 1.133 ++ fprintf(stderr, "liblrdf: %s - ", severity); 1.134 ++ raptor_locator_print(message->locator, stderr); 1.135 ++ fprintf(stderr, " - %s\n", message->text); 1.136 + 1.137 +-static void lrdf_warning_handler(void *data, raptor_locator * locator, 1.138 +- const char *message) 1.139 +-{ 1.140 +- fprintf(stderr, "liblrdf: warning - "); 1.141 +- raptor_print_locator(stderr, locator); 1.142 +- fprintf(stderr, " - %s\n", message); 1.143 ++ if (message->level != RAPTOR_LOG_LEVEL_WARN) { 1.144 ++ raptor_parser_parse_abort((raptor_parser*)data); 1.145 ++ } 1.146 + } 1.147 + 1.148 + 1.149 +@@ -593,15 +591,15 @@ int lrdf_read_file_intl(const char *uri) 1.150 + lrdf_hash source; 1.151 + 1.152 + //printf("lrdf: reading %s\n", uri); 1.153 +- ruri = raptor_new_uri(uri); 1.154 +- furi = raptor_new_uri(uri); 1.155 ++ ruri = raptor_new_uri(world, (const unsigned char *) uri); 1.156 ++ furi = raptor_new_uri(world, (const unsigned char *) uri); 1.157 + source = lrdf_gen_hash(uri); 1.158 + lrdf_check_hash(resources_hash, source, uri); 1.159 + 1.160 + if (strstr(uri, ".rdf")) { 1.161 +- parser = raptor_new_parser("rdfxml"); 1.162 ++ parser = raptor_new_parser(world, "rdfxml"); 1.163 + } else { 1.164 +- parser = raptor_new_parser("ntriples"); 1.165 ++ parser = raptor_new_parser(world, "ntriples"); 1.166 + } 1.167 + if (!parser) { 1.168 + fprintf(stderr, "liblrdf: failed to create parser\n"); 1.169 +@@ -609,12 +607,11 @@ int lrdf_read_file_intl(const char *uri) 1.170 + return 1; 1.171 + } 1.172 + 1.173 +- raptor_set_error_handler(parser, parser, lrdf_error_handler); 1.174 +- raptor_set_warning_handler(parser, NULL, lrdf_warning_handler); 1.175 +- raptor_set_statement_handler(parser, &source, lrdf_store); 1.176 +- raptor_set_default_generate_id_parameters(parser, NULL, ++lrdf_uid); 1.177 ++ raptor_world_set_log_handler(world, parser, lrdf_log_handler); 1.178 ++ raptor_parser_set_statement_handler(parser, &source, lrdf_store); 1.179 ++ raptor_world_set_generate_bnodeid_parameters(world, NULL, ++lrdf_uid); 1.180 + 1.181 +- if (raptor_parse_file(parser, furi, ruri)) { 1.182 ++ if (raptor_parser_parse_file(parser, furi, ruri)) { 1.183 + raptor_free_uri(furi); 1.184 + raptor_free_uri(ruri); 1.185 + raptor_free_parser(parser); 1.186 +--- configure.ac 1.187 ++++ configure.ac 1.188 +@@ -18,7 +18,7 @@ 1.189 + AC_HEADER_STDC 1.190 + AC_CHECK_HEADERS([errno.h limits.h stdlib.h string.h unistd.h]) 1.191 + 1.192 +-PKG_CHECK_MODULES(RAPTOR, raptor >= 0.9.11) 1.193 ++PKG_CHECK_MODULES(RAPTOR, raptor2 >= 0.9.11) 1.194 + 1.195 + # Checks for typedefs, structures, and compiler characteristics. 1.196 + AC_C_CONST