X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fconfig.h;h=33014df45140bd40342f684748f0873b09f81847;hb=9f15a2646ae6c666ac16c2d779afc3ee205df069;hp=a84b7de80c582c9beaec2325ee4e72c87ed041ff;hpb=0845e34105333ff6828a01d8813f5738fbf8b9a9;p=pazpar2-moved-to-github.git diff --git a/src/config.h b/src/config.h index a84b7de..33014df 100644 --- a/src/config.h +++ b/src/config.h @@ -1,4 +1,4 @@ -/* $Id: config.h,v 1.17 2007-04-18 15:09:51 marc Exp $ +/* $Id: config.h,v 1.18 2007-04-19 11:57:53 marc Exp $ Copyright (c) 2006-2007, Index Data. This file is part of Pazpar2. @@ -34,6 +34,23 @@ enum conf_sortkey_type Metadata_sortkey_string // Flat string }; +enum conf_metadata_type + { + Metadata_type_generic, // Generic text field + Metadata_type_number, // A number + Metadata_type_year // A number + }; + +enum conf_metadata_merge + { + Metadata_merge_no, // Don't merge + Metadata_merge_unique, // Include unique elements in merged block + Metadata_merge_longest, // Include the longest (strlen) value + Metadata_merge_range, // Store value as a range of lowest-highest + Metadata_merge_all // Just include all elements found + }; + + // Describes known metadata elements and how they are to be manipulated // An array of these structure provides a 'map' against which // discovered metadata elements are matched. It also governs storage, @@ -48,22 +65,21 @@ struct conf_metadata // values >1 give additional significance to a field int sortkey_offset; // -1 if it's not a sortkey, otherwise index // into service/record_cluster->sortkey array - enum - { - Metadata_type_generic, // Generic text field - Metadata_type_number, // A number - Metadata_type_year // A number - } type; - enum - { - Metadata_merge_no, // Don't merge - Metadata_merge_unique, // Include unique elements in merged block - Metadata_merge_longest, // Include the longest (strlen) value - Metadata_merge_range, // Store value as a range of lowest-highest - Metadata_merge_all // Just include all elements found - } merge; + enum conf_metadata_type type; + enum conf_metadata_merge merge; }; + +struct conf_metadata * conf_metadata_create(NMEM nmem, + const char *name, + enum conf_metadata_type type, + enum conf_metadata_merge merge, + int brief, + int termlist, + int rank, + int sortkey_offset); + + // Controls sorting struct conf_sortkey { @@ -83,6 +99,19 @@ struct conf_service struct conf_sortkey *sortkeys; }; +struct conf_service * conf_service_create(NMEM nmem); + +struct conf_metadata* conf_service_add_metadata(NMEM nmem, + struct conf_service *service, + const char *name, + enum conf_metadata_type type, + enum conf_metadata_merge merge, + int brief, + int termlist, + int rank, + int sortkey_offset); + + struct conf_server { char *host;