X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fmarcdisp.c;h=53d4e81eeefa87e8f8d1eca91daa3d8246aec72b;hp=186f70872dba48cb769744b24cc100ce8a657722;hb=c54a5790984e8bd597a8ccd4d1d2d0cae6da8af3;hpb=f450fc48c1ab271aa0bd45d96e46dd2e0f2d9523 diff --git a/src/marcdisp.c b/src/marcdisp.c index 186f708..53d4e81 100644 --- a/src/marcdisp.c +++ b/src/marcdisp.c @@ -163,7 +163,7 @@ void yaz_marc_add_controlfield_xml(yaz_marc_t mt, const xmlNode *ptr_tag, n->u.controlfield.data = nmem_text_node_cdata(ptr_data, mt->nmem); } -void yaz_marc_add_controlfield_turbo_xml(yaz_marc_t mt, const char *tag, +void yaz_marc_add_controlfield_turbo_xml(yaz_marc_t mt, char *tag, const xmlNode *ptr_data) { struct yaz_marc_node *n = yaz_marc_add_node(mt); @@ -241,6 +241,33 @@ void yaz_marc_add_datafield(yaz_marc_t mt, const char *tag, mt->subfield_pp = &n->u.datafield.subfields; } +char *element_name_encode(yaz_marc_t mt, WRBUF buffer, char *code_data, size_t code_len) { + // TODO Map special codes to something possible for XML ELEMENT names + + int encode = 0; + int index = 0; + for (index = 0; index < code_len; index++) { + if (!((code_data[index] >= '0' && code_data[index] <= '9') || + (code_data[index] >= 'a' && code_data[index] <= 'z') || + (code_data[index] >= 'A' && code_data[index] <= 'Z'))) + encode = 1; + } + if (!encode) { + wrbuf_iconv_write(buffer, mt->iconv_cd, code_data, code_len); + } + else { + char temp[2*code_len + 1]; + wrbuf_puts(buffer, "-"); + int index; + for (index = 0; index < code_len; index++) { + sprintf(temp, "%02X", (unsigned char) code_data[index] & 0xFF); + temp[2] = 0; + wrbuf_puts(buffer, temp); + }; + yaz_log(YLOG_WARN, "Using numeric value in element name: %s", wrbuf_cstr(buffer)); + } +} + #if YAZ_HAVE_XML2 void yaz_marc_add_datafield_xml(yaz_marc_t mt, const xmlNode *ptr_tag, const char *indicator, size_t indicator_len) @@ -576,6 +603,7 @@ const char *record_name[2] = { "record", "r"}; const char *leader_name[2] = { "leader", "l"}; const char *controlfield_name[2]= { "controlfield", "c"}; const char *datafield_name[2] = { "datafield", "d"}; +const char *indicator_name[2] = { "ind", "i"}; const char *subfield_name[2] = { "subfield", "s"}; @@ -586,7 +614,7 @@ const char *subfield_name[2] = { "subfield", "s"}; \param format record format (e.g. "MARC21") \param type record type (e.g. "Bibliographic") */ -static int yaz_marc_write_marcxml_ns2(yaz_marc_t mt, WRBUF wr, +static int yaz_marc_write_marcxml_ns1(yaz_marc_t mt, WRBUF wr, const char *ns, const char *format, const char *type) @@ -611,9 +639,10 @@ static int yaz_marc_write_marcxml_ns2(yaz_marc_t mt, WRBUF wr, if (mt->enable_collection != no_collection) { - if (mt->enable_collection == collection_first) + if (mt->enable_collection == collection_first) { wrbuf_printf(wr, "<%s xmlns=\"%s\">\n", collection_name[turbo], ns); - mt->enable_collection = collection_second; + mt->enable_collection = collection_second; + } wrbuf_printf(wr, "<%s", record_name[turbo]); } else @@ -632,42 +661,26 @@ static int yaz_marc_write_marcxml_ns2(yaz_marc_t mt, WRBUF wr, switch(n->which) { case YAZ_MARC_DATAFIELD: - wrbuf_printf(wr, " <%s", datafield_name[turbo]); - if (!turbo) { + + wrbuf_printf(wr, " <%s", datafield_name[turbo]); + if (!turbo) wrbuf_printf(wr, " tag=\""); - wrbuf_iconv_write_cdata(wr, mt->iconv_cd, n->u.datafield.tag, + wrbuf_iconv_write_cdata(wr, mt->iconv_cd, n->u.datafield.tag, strlen(n->u.datafield.tag)); - wrbuf_printf(wr, "\""); - if (n->u.datafield.indicator) - { - int i; - for (i = 0; n->u.datafield.indicator[i]; i++) - { - wrbuf_printf(wr, " ind%d=\"", i+1); - wrbuf_iconv_write_cdata(wr, mt->iconv_cd, - n->u.datafield.indicator+i, 1); - wrbuf_iconv_puts(wr, mt->iconv_cd, "\""); - } - } - wrbuf_printf(wr, ">\n"); - } else { - wrbuf_iconv_write_cdata(wr, mt->iconv_cd, n->u.datafield.tag, - strlen(n->u.datafield.tag)); - // Write tag - wrbuf_printf(wr, ">\n"); - if (n->u.datafield.indicator) - { - int i; - for (i = 0; n->u.datafield.indicator[i]; i++) - { - wrbuf_printf(wr, " ", i+1); - wrbuf_iconv_write_cdata(wr, mt->iconv_cd, - n->u.datafield.indicator+i, 1); - wrbuf_printf(wr, "", i+1); - wrbuf_puts(wr, "\n"); - } - } + if (!turbo) + wrbuf_printf(wr, "\""); + if (n->u.datafield.indicator) + { + int i; + for (i = 0; n->u.datafield.indicator[i]; i++) + { + wrbuf_printf(wr, " %s%d=\"", indicator_name[turbo], i+1); + wrbuf_iconv_write_cdata(wr, mt->iconv_cd, + n->u.datafield.indicator+i, 1); + wrbuf_iconv_puts(wr, mt->iconv_cd, "\""); + } } + wrbuf_printf(wr, ">\n"); for (s = n->u.datafield.subfields; s; s = s->next) { size_t using_code_len = get_subfield_len(mt, s->code_data, @@ -679,19 +692,25 @@ static int yaz_marc_write_marcxml_ns2(yaz_marc_t mt, WRBUF wr, s->code_data, using_code_len); wrbuf_iconv_puts(wr, mt->iconv_cd, "\">"); } else { - // TODO check this. encode special characters. - wrbuf_iconv_write_cdata(wr, mt->iconv_cd, - s->code_data, using_code_len); - wrbuf_puts(wr, ">\n"); + element_name_encode(mt, wr, s->code_data, using_code_len); + wrbuf_puts(wr, ">"); } wrbuf_iconv_write_cdata(wr, mt->iconv_cd, s->code_data + using_code_len, strlen(s->code_data + using_code_len)); marc_iconv_reset(mt, wr); - wrbuf_printf(wr, "", subfield_name[turbo]); - wrbuf_puts(wr, "\n"); + wrbuf_printf(wr, "iconv_cd, + s->code_data, using_code_len); + wrbuf_puts(wr, ">\n"); } - wrbuf_printf(wr, " \n", datafield_name[turbo]); + wrbuf_printf(wr, " iconv_cd, n->u.datafield.tag, + strlen(n->u.datafield.tag)); + wrbuf_printf(wr, ">\n", datafield_name[turbo]); break; case YAZ_MARC_CONTROLFIELD: wrbuf_printf(wr, " <%s", controlfield_name[turbo]); @@ -711,8 +730,12 @@ static int yaz_marc_write_marcxml_ns2(yaz_marc_t mt, WRBUF wr, n->u.controlfield.data, strlen(n->u.controlfield.data)); marc_iconv_reset(mt, wr); - wrbuf_printf(wr, "", controlfield_name[turbo]); - wrbuf_puts(wr, "\n"); + wrbuf_printf(wr, "iconv_cd, n->u.controlfield.tag, + strlen(n->u.controlfield.tag)); + wrbuf_puts(wr, ">\n"); break; case YAZ_MARC_COMMENT: wrbuf_printf(wr, "