9864238d36f652ac939b2cd5a081b8e8bce43868
[pazpar2-moved-to-github.git] / src / record.c
1 /* This file is part of Pazpar2.
2    Copyright (C) 2006-2008 Index Data
3
4 Pazpar2 is free software; you can redistribute it and/or modify it under
5 the terms of the GNU General Public License as published by the Free
6 Software Foundation; either version 2, or (at your option) any later
7 version.
8
9 Pazpar2 is distributed in the hope that it will be useful, but WITHOUT ANY
10 WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12 for more details.
13
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
17
18 */
19
20 /* $Id: record.c,v 1.10 2007-06-13 21:29:04 adam Exp $ */
21
22
23 #include <string.h>
24
25 #include <yaz/yaz-util.h>
26 #include <yaz/nmem.h>
27
28 #if HAVE_CONFIG_H
29 #include <cconfig.h>
30 #endif
31
32 //#define CONFIG_NOEXTERNS
33 #include "config.h"
34 #include "record.h"
35
36
37
38 union data_types * data_types_assign(NMEM nmem, 
39                                      union data_types ** data1, 
40                                      union data_types data2)
41 {
42     // assert(nmem);
43
44     if (!data1)
45         return 0;
46
47     if (!*data1){
48         if (!nmem)
49             return 0;
50         else
51             *data1  = nmem_malloc(nmem, sizeof(union data_types));
52     }
53     
54     **data1 = data2;
55     return *data1;
56 }
57
58
59 struct record * record_create(NMEM nmem, int num_metadata, int num_sortkeys,
60                               struct client *client, int position)
61 {
62     struct record * record = 0;
63     int i = 0;
64     
65     // assert(nmem);
66
67     record = nmem_malloc(nmem, sizeof(struct record));
68
69     record->next = 0;
70     record->client = client;
71
72     record->metadata 
73         = nmem_malloc(nmem, 
74                       sizeof(struct record_metadata*) * num_metadata);
75     for (i = 0; i < num_metadata; i++)
76         record->metadata[i] = 0;
77     
78     record->sortkeys  
79         = nmem_malloc(nmem, 
80                       sizeof(union data_types*) * num_sortkeys);
81     for (i = 0; i < num_sortkeys; i++)
82         record->sortkeys[i] = 0;
83
84     record->position = position;
85     
86     return record;
87 }
88
89 struct record_metadata * record_metadata_create(NMEM nmem)
90 {
91     struct record_metadata * rec_md 
92         = nmem_malloc(nmem, sizeof(struct record_metadata));
93     rec_md->next = 0;
94     return rec_md;
95 }
96
97
98 struct record_metadata * record_metadata_insert(NMEM nmem, 
99                                                 struct record_metadata ** rmd,
100                                                 union data_types data)
101 {
102     struct record_metadata * tmp_rmd = 0;
103     // assert(nmem);
104
105     if(!rmd)
106         return 0;
107
108     // construct new record_metadata
109     tmp_rmd  = nmem_malloc(nmem, sizeof(struct record_metadata));
110     tmp_rmd->data = data;
111
112
113     // insert in *rmd's place, moving *rmd one down the list
114     tmp_rmd->next = *rmd;
115     *rmd = tmp_rmd;
116
117     return *rmd;
118 }
119
120 struct record_metadata * record_add_metadata_field_id(NMEM nmem, 
121                                                      struct record * record,
122                                                      int field_id, 
123                                                      union data_types data)
124 {
125     if (field_id < 0 || !record || !record->metadata)
126         return 0;
127
128     return record_metadata_insert(nmem, &(record->metadata[field_id]), data);
129 }
130
131
132 struct record_metadata * record_add_metadata(NMEM nmem, 
133                                              struct record * record,
134                                              struct conf_service * service,
135                                              const char * name,
136                                              union data_types data)
137 {
138     int field_id = 0;
139
140     if (!record || !record->metadata || !service || !name)  
141         return 0;
142     
143     field_id = conf_service_metadata_field_id(service, name);
144
145     if (-1 == field_id)
146         return 0;
147     
148     return record_metadata_insert(nmem, &(record->metadata[field_id]), data);
149 }
150
151
152
153
154
155
156 union data_types * record_assign_sortkey_field_id(NMEM nmem, 
157                                                struct record * record,
158                                                int field_id, 
159                                                union data_types data)
160 {
161     if (field_id < 0 || !record || !record->sortkeys)
162         return 0;
163
164     return data_types_assign(nmem, &(record->sortkeys[field_id]), data);
165 }
166
167
168
169 union data_types * record_assign_sortkey(NMEM nmem, 
170                                       struct record * record,
171                                       struct conf_service * service,
172                                       const char * name,
173                                       union data_types data)
174 {
175     int field_id = 0;
176
177     if (!record || !service || !name)  
178         return 0;
179     
180     field_id = conf_service_sortkey_field_id(service, name);
181
182     if (!(-1 < field_id) || !(field_id < service->num_sortkeys))
183         return 0;
184
185     return record_assign_sortkey_field_id(nmem, record, field_id, data);
186 }
187
188
189
190 /*
191  * Local variables:
192  * c-basic-offset: 4
193  * indent-tabs-mode: nil
194  * End:
195  * vim: shiftwidth=4 tabstop=8 expandtab
196  */