X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fattribute.c;h=e37e3a0b8e35b6279c8f5a283b8e4146a4408cb7;hb=4df7866a571bf540cb320b62e6eec6f7e81b65dd;hp=9e8f327581d662cbabca6df2298e31ed7414eb52;hpb=4478d785b7769691261005c98063b98a5a5971b3;p=idzebra-moved-to-github.git diff --git a/index/attribute.c b/index/attribute.c index 9e8f327..e37e3a0 100644 --- a/index/attribute.c +++ b/index/attribute.c @@ -1,5 +1,5 @@ -/* $Id: attribute.c,v 1.26 2006-08-14 10:40:15 adam Exp $ - Copyright (C) 1995-2006 +/* $Id: attribute.c,v 1.30 2007-04-16 21:54:37 adam Exp $ + Copyright (C) 1995-2007 Index Data ApS This file is part of the Zebra server. @@ -28,6 +28,7 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #include #include #include "index.h" +#include static data1_att *getatt(data1_attset *p, int att) { @@ -45,7 +46,7 @@ static data1_att *getatt(data1_attset *p, int att) return 0; } -static int att_getentbyatt(ZebraHandle zi, oid_value set, int att, +static int att_getentbyatt(ZebraHandle zi, const int *set, int att, const char **name) { data1_att *r; @@ -69,7 +70,7 @@ ZEBRA_RES zebra_attr_list_get_ord(ZebraHandle zh, Z_AttributeList *attr_list, zinfo_index_category_t cat, int index_type, - oid_value curAttributeSet, + const int *curAttributeSet, int *ord) { int use_value = -1; @@ -123,7 +124,7 @@ ZEBRA_RES zebra_apt_get_ord(ZebraHandle zh, Z_AttributesPlusTerm *zapt, int index_type, const char *xpath_use, - oid_value curAttributeSet, + const int *curAttributeSet, int *ord) { ZEBRA_RES res = ZEBRA_OK; @@ -181,20 +182,18 @@ ZEBRA_RES zebra_sort_get_ord(ZebraHandle zh, { AttrType structure; int structure_value; + attr_init_AttrList(&structure, sortAttributes->list, 4); *numerical = 0; structure_value = attr_find(&structure, 0); if (structure_value == 109) *numerical = 1; - - if (zebra_attr_list_get_ord(zh, sortAttributes->list, - zinfo_index_category_sort, - 's', VAL_BIB1, ord)== ZEBRA_OK) - return ZEBRA_OK; - if (zebra_attr_list_get_ord(zh, sortAttributes->list, - zinfo_index_category_sort, - 'S', VAL_BIB1, ord)== ZEBRA_OK) + + if (zebra_attr_list_get_ord( + zh, sortAttributes->list, + zinfo_index_category_sort, + -1 /* any index */, yaz_oid_attset_bib_1, ord) == ZEBRA_OK) return ZEBRA_OK; return ZEBRA_FAIL; }