-/* $Id: database.c,v 1.14 2007-04-11 18:42:25 quinn Exp $
+/* $Id: database.c,v 1.15 2007-04-11 19:55:57 quinn Exp $
Copyright (c) 2006-2007, Index Data.
This file is part of Pazpar2.
char hostport[256];
char *dbname;
+ yaz_log(YLOG_LOG, "New database: %s", id);
if (!nmem)
nmem = nmem_create();
if (doc)
return;
db->ccl_map = ccl_qual_mk();
for (s = db->settings[PZ_CCLMAP]; s; s = s->next)
- if (!*s->user)
+ {
+ char *p = strchr(s->name + 3, ':');
+ if (!p)
{
- char *p = strchr(s->name + 3, ':');
- if (!p)
- {
- yaz_log(YLOG_FATAL, "Malformed cclmap name: %s", s->name);
- exit(1);
- }
- p++;
- ccl_qual_fitem(db->ccl_map, s->value, p);
+ yaz_log(YLOG_FATAL, "Malformed cclmap name: %s", s->name);
+ exit(1);
}
+ p++;
+ ccl_qual_fitem(db->ccl_map, s->value, p);
+ }
}
// Initialize YAZ Map structures for MARC-based targets
if (!db->settings)
return;
for (s = db->settings[PZ_NATIVESYNTAX]; s; s = s->next)
- if (!*s->user && !strcmp(s->value, "iso2709"))
+ if (!strcmp(s->value, "iso2709"))
{
char *encoding = "marc-8s";
yaz_iconv_t cm;
db->yaz_marc = yaz_marc_create();
yaz_marc_subfield_str(db->yaz_marc, "\t");
// See if a native encoding is specified
- for (s = db->settings[PZ_ENCODING]; s; s = s->next)
- if (!*s->user)
- {
- encoding = s->value;
- break;
- }
+ if ((s = db->settings[PZ_ENCODING]))
+ {
+ encoding = s->value;
+ break;
+ }
if (!(cm = yaz_iconv_open("utf-8", encoding)))
{
yaz_log(YLOG_FATAL, "Unable to map from %s to UTF-8", encoding);
if (!db->settings)
return;
for (s = db->settings[PZ_XSLT]; s; s = s->next)
- if (!*s->user)
- {
- char **stylesheets;
- struct database_retrievalmap **m = &db->map;
- int num, i;
+ {
+ char **stylesheets;
+ struct database_retrievalmap **m = &db->map;
+ int num, i;
- nmem_strsplit(nmem, ",", s->value, &stylesheets, &num);
- for (i = 0; i < num; i++)
+ nmem_strsplit(nmem, ",", s->value, &stylesheets, &num);
+ for (i = 0; i < num; i++)
+ {
+ (*m) = nmem_malloc(nmem, sizeof(**m));
+ (*m)->next = 0;
+ if (!((*m)->stylesheet = conf_load_stylesheet(stylesheets[i])))
{
- (*m) = nmem_malloc(nmem, sizeof(**m));
- (*m)->next = 0;
- if (!((*m)->stylesheet = conf_load_stylesheet(stylesheets[i])))
- {
- yaz_log(YLOG_FATAL, "Unable to load stylesheet: %s",
- stylesheets[i]);
- exit(1);
- }
- m = &(*m)->next;
+ yaz_log(YLOG_FATAL, "Unable to load stylesheet: %s",
+ stylesheets[i]);
+ exit(1);
}
- break;
+ m = &(*m)->next;
}
- if (!s)
+ }
+ if (!db->map)
yaz_log(YLOG_WARN, "No Normalization stylesheet for target %s", db->url);
}
-/* $Id: settings.c,v 1.13 2007-04-11 18:42:25 quinn Exp $
+/* $Id: settings.c,v 1.14 2007-04-11 19:55:57 quinn Exp $
Copyright (c) 2006-2007, Index Data.
This file is part of Pazpar2.
struct setting set;
char nameb[1024];
char targetb[1024];
- char userb[1024];
char valueb[1024];
// Copy everything into a temporary buffer -- we decide
set.precedence = atoi((char *) precedencea);
else
set.precedence = 0;
- set.user = userb;
- if (user)
- strcpy(userb, user);
- else if (usera)
- strcpy(userb, (const char *) usera);
- else
- set.user = "";
if (target)
strcpy(targetb, target);
else
id->precedence = 0;
id->name = "pz:id";
id->target = id->value = db->url;
- id->user = "";
id->next = 0;
db->settings[PZ_ID] = id;
}
// with the same name.
for (s = db->settings[offset], sp = &db->settings[offset]; s;
sp = &s->next, s = s->next)
- if (!strcmp(s->user, set->user) && !strcmp(s->name, set->name))
+ if (!strcmp(s->name, set->name))
{
if (s->precedence < set->precedence)
// We discard the value (nmem keeps track of the space)
new->target = nmem_strdup(nmem, set->target);
new->name = nmem_strdup(nmem, set->name);
new->value = nmem_strdup(nmem, set->value);
- new->user = nmem_strdup(nmem, set->user);
new->next = db->settings[offset];
db->settings[offset] = new;
}