/* This file is part of Pazpar2.
- Copyright (C) 2006-2009 Index Data
+ Copyright (C) 2006-2010 Index Data
Pazpar2 is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
struct normalize_record_s {
struct normalize_step *steps;
- char *spec;
NMEM nmem;
};
-const char *normalize_record_get_spec(normalize_record_t nt)
-{
- if (nt)
- return nt->spec;
- return 0;
-}
-
-normalize_record_t normalize_record_create(struct conf_service *service,
+normalize_record_t normalize_record_create(struct conf_config *conf,
const char *spec)
{
- normalize_record_t nt = xmalloc(sizeof(*nt));
- struct normalize_step **m;
+ NMEM nmem = nmem_create();
+ normalize_record_t nt = nmem_malloc(nmem, sizeof(*nt));
+ struct normalize_step **m = &nt->steps;
int i, num;
int no_errors = 0;
char **stylesheets;
- nt->nmem = nmem_create();
-
- nt->spec = nmem_strdup(nt->nmem, spec);
-
- m = &nt->steps;
+ nt->nmem = nmem;
nmem_strsplit(nt->nmem, ",", spec, &stylesheets, &num);
for (i = 0; i < num; i++)
{
- WRBUF fname = conf_get_fname(service, stylesheets[i]);
+ WRBUF fname = conf_get_fname(conf, stylesheets[i]);
*m = nmem_malloc(nt->nmem, sizeof(**m));
(*m)->marcmap = NULL;
xsltFreeStylesheet(m->stylesheet);
}
nmem_destroy(nt->nmem);
-
- xfree(nt);
}
}
int normalize_record_transform(normalize_record_t nt, xmlDoc **doc,
- const char **parms)
+ const char **parms)
{
- struct normalize_step *m;
- for (m = nt->steps; m; m = m->next)
+ if (nt)
{
- xmlNodePtr root = 0;
- xmlDoc *new;
- if (m->stylesheet)
- {
- new = xsltApplyStylesheet(m->stylesheet, *doc, parms);
- }
- else if (m->marcmap)
- {
- new = marcmap_apply(m->marcmap, *doc);
- }
-
- root = xmlDocGetRootElement(new);
-
- if (!new || !root || !root->children)
- {
- if (new)
- xmlFreeDoc(new);
- xmlFreeDoc(*doc);
- return -1;
- }
- xmlFreeDoc(*doc);
- *doc = new;
+ struct normalize_step *m;
+ for (m = nt->steps; m; m = m->next)
+ {
+ xmlNodePtr root = 0;
+ xmlDoc *ndoc;
+ if (m->stylesheet)
+ ndoc = xsltApplyStylesheet(m->stylesheet, *doc, parms);
+ else if (m->marcmap)
+ ndoc = marcmap_apply(m->marcmap, *doc);
+ else
+ ndoc = 0;
+ xmlFreeDoc(*doc);
+ *doc = 0;
+
+ if (ndoc)
+ root = xmlDocGetRootElement(ndoc);
+
+ if (ndoc && root && root->children)
+ *doc = ndoc;
+ else
+ {
+ if (ndoc)
+ xmlFreeDoc(ndoc);
+ return -1;
+ }
+ }
}
return 0;
}