X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=src%2Fsrwutil.c;h=493a7a34bd52df292f253817266788865542796f;hb=7fc72f3ae149e416a297ef1f55c09271056e98f1;hp=40c9735d1acb85960f06c88e90b417f16ecfb181;hpb=4df8de77ce5d4d97a9d5588f49a5c8298183776e;p=yaz-moved-to-github.git diff --git a/src/srwutil.c b/src/srwutil.c index 40c9735..493a7a3 100644 --- a/src/srwutil.c +++ b/src/srwutil.c @@ -39,30 +39,37 @@ char *yaz_encode_sru_dbpath_odr(ODR out, const char *db) return dst; } -Z_AttributeList *yaz_use_attribute_create(ODR o, const char *name) +Z_AttributeElement *yaz_string_element_create(ODR o, int type, + const char *value) { - Z_AttributeList *attributes= (Z_AttributeList *) - odr_malloc(o, sizeof(*attributes)); - Z_AttributeElement ** elements; - attributes->num_attributes = 1; - elements = (Z_AttributeElement**) - odr_malloc(o, attributes->num_attributes * sizeof(*elements)); - elements[0] = (Z_AttributeElement*) odr_malloc(o,sizeof(**elements)); - elements[0]->attributeType = odr_intdup(o, 1); - elements[0]->attributeSet = odr_nullval(); - elements[0]->which = Z_AttributeValue_complex; - elements[0]->value.complex = (Z_ComplexAttribute *) + Z_AttributeElement *element = (Z_AttributeElement*) + odr_malloc(o, sizeof(*element)); + element->attributeType = odr_intdup(o, type); + element->attributeSet = 0; + element->which = Z_AttributeValue_complex; + element->value.complex = (Z_ComplexAttribute *) odr_malloc(o, sizeof(Z_ComplexAttribute)); - elements[0]->value.complex->num_list = 1; - elements[0]->value.complex->list = (Z_StringOrNumeric **) + element->value.complex->num_list = 1; + element->value.complex->list = (Z_StringOrNumeric **) odr_malloc(o, 1 * sizeof(Z_StringOrNumeric *)); - elements[0]->value.complex->list[0] = (Z_StringOrNumeric *) + element->value.complex->list[0] = (Z_StringOrNumeric *) odr_malloc(o, sizeof(Z_StringOrNumeric)); - elements[0]->value.complex->list[0]->which = Z_StringOrNumeric_string; - elements[0]->value.complex->list[0]->u.string = odr_strdup(o, name); - elements[0]->value.complex->semanticAction = 0; - elements[0]->value.complex->num_semanticAction = 0; - attributes->attributes = elements; + element->value.complex->list[0]->which = Z_StringOrNumeric_string; + element->value.complex->list[0]->u.string = odr_strdup(o, value); + element->value.complex->semanticAction = 0; + element->value.complex->num_semanticAction = 0; + return element; +} + +Z_AttributeList *yaz_use_attribute_create(ODR o, const char *name) +{ + Z_AttributeList *attributes = (Z_AttributeList *) + odr_malloc(o, sizeof(*attributes)); + + attributes->num_attributes = 1; + attributes->attributes = (Z_AttributeElement**) + odr_malloc(o, sizeof(*attributes->attributes)); + attributes->attributes[0] = yaz_string_element_create(o, 1, name); return attributes; } @@ -376,9 +383,9 @@ int yaz_sru_decode(Z_HTTP_Request *hreq, Z_SRW_PDU **srw_pdu, !yaz_strcmp_del("application/x-www-form-urlencoded", content_type, "; "))) { + char *db = "Default"; const char *p0 = hreq->path, *p1; #if YAZ_HAVE_XML2 - char *db = "Default"; const char *operation = 0; char *version = 0; char *query = 0;