X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Frecord.h;h=0e396a2433c0de5235f1300037e73002b7d4c2f7;hb=541b55d47e25948f632382f7b96f1fffad00ca7f;hp=bbba218ce9aa8f3f965dc0d2a00d7f4d9b44e0d9;hpb=3670a21abc40afe784b2127c4d831471761747a0;p=pazpar2-moved-to-github.git diff --git a/src/record.h b/src/record.h index bbba218..0e396a2 100644 --- a/src/record.h +++ b/src/record.h @@ -1,4 +1,4 @@ -/* $Id: record.h,v 1.2 2007-04-20 14:37:17 marc Exp $ +/* $Id: record.h,v 1.8 2007-04-27 11:56:41 marc Exp $ Copyright (c) 2006-2007, Index Data. This file is part of Pazpar2. @@ -25,7 +25,7 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA struct record; struct client; - +struct conf_service; union data_types { char *text; @@ -35,38 +35,88 @@ union data_types { } number; }; + + struct record_metadata { union data_types data; - struct record_metadata *next; // next item of this name + // next item of this name + struct record_metadata *next; }; +union data_types * data_types_assign(NMEM nmem, + union data_types ** data1, + union data_types data2); + + struct record { struct client *client; - struct record_metadata **metadata; // Array mirrors list of metadata fields in config - union data_types **sortkeys; // Array mirrors list of sortkey fields in config - struct record *next; // Next in cluster of merged records + // Array mirrors list of metadata fields in config + struct record_metadata **metadata; + // Array mirrors list of sortkey fields in config + union data_types **sortkeys; + // Next in cluster of merged records + struct record *next; }; struct record * record_create(NMEM nmem, int num_metadata, int num_sortkeys); -struct record_metadata * record_add_metadata_fieldno(NMEM nmem, - struct record * record, - int fieldno, - union data_types data); +struct record_metadata * record_metadata_create(NMEM nmem); + +struct record_metadata * record_metadata_insert(NMEM nmem, + struct record_metadata ** rmd, + union data_types data); + + +struct record_metadata * record_add_metadata_field_id(NMEM nmem, + struct record * record, + int field_id, + union data_types data); + + +struct record_metadata * record_add_metadata(NMEM nmem, + struct record * record, + struct conf_service * service, + const char * name, + union data_types data); + + +struct client * record_assign_client(struct record * record, + struct client *client); + + + +union data_types * record_assign_sortkey_field_id(NMEM nmem, + struct record * record, + int field_id, + union data_types data); + + +union data_types * record_assign_sortkey(NMEM nmem, + struct record * record, + struct conf_service * service, + const char * name, + union data_types data); + + + struct record_cluster { - struct record_metadata **metadata; // Array mirrors list of metadata fields in config + // Array mirrors list of metadata fields in config + struct record_metadata **metadata; union data_types **sortkeys; char *merge_key; int relevance; int *term_frequency_vec; - int recid; // Set-specific ID for this record + // Set-specific ID for this record + int recid; struct record *records; }; + + #endif // RECORD_H /*