charsets.c charsets.h \
client.c client.h connection.c connection.h host.h parameters.h \
dirent.c direntz.h marcmap.c marcmap.h marchash.c marchash.h \
- jenkins_hash.c jenkins_hash.h normalize_record.c normalize_record.h
+ jenkins_hash.c jenkins_hash.h normalize_record.c normalize_record.h \
+ normalize_cache.c normalize_cache.h
pazpar2_SOURCES = pazpar2.c
pazpar2_LDADD = libpazpar2.a $(YAZLIB)
yaz_log(YLOG_WARN, "No pz:requestsyntax for auto stylesheet");
}
}
- sdb->map = normalize_record_create(se->service, s);
+ sdb->map = normalize_cache_get(se->normalize_cache,
+ se->service, s);
if (!sdb->map)
return -1;
}
// Doesn't free memory associated with sdb -- nmem takes care of that
static void session_database_destroy(struct session_database *sdb)
{
- normalize_record_destroy(sdb->map);
sdb->map = 0;
}
case PZ_XSLT:
if (sdb->map)
{
- normalize_record_destroy(sdb->map);
sdb->map = 0;
}
break;
client_destroy(s->clients);
for (sdb = s->databases; sdb; sdb = sdb->next)
session_database_destroy(sdb);
+ normalize_cache_destroy(s->normalize_cache);
nmem_destroy(s->nmem);
service_destroy(s->service);
wrbuf_destroy(s->wrbuf);
session->watchlist[i].data = 0;
session->watchlist[i].fun = 0;
}
+ session->normalize_cache = normalize_cache_create();
+
return session;
}
--- /dev/null
+/* This file is part of Pazpar2.
+ Copyright (C) 2006-2009 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
+Software Foundation; either version 2, or (at your option) any later
+version.
+
+Pazpar2 is distributed in the hope that it will be useful, but WITHOUT ANY
+WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program; if not, write to the Free Software
+Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+*/
+
+#include <string.h>
+
+#include <yaz/yaz-util.h>
+#include <yaz/nmem.h>
+
+#if HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include "normalize_cache.h"
+
+#include "pazpar2_config.h"
+
+struct cached_item {
+ char *spec;
+ struct cached_item *next;
+ normalize_record_t nt;
+};
+
+struct normalize_cache_s {
+ struct cached_item *items;
+ NMEM nmem;
+};
+
+normalize_cache_t normalize_cache_create(void)
+{
+ NMEM nmem = nmem_create();
+ normalize_cache_t nc = nmem_malloc(nmem, sizeof(*nc));
+ nc->nmem = nmem;
+ nc->items = 0;
+ return nc;
+}
+
+normalize_record_t normalize_cache_get(normalize_cache_t nc,
+ struct conf_service *service,
+ const char *spec)
+{
+ normalize_record_t nt;
+ struct cached_item *ci = nc->items;
+ for (; ci; ci = ci->next)
+ if (!strcmp(spec, ci->spec))
+ return ci->nt;
+
+ nt = normalize_record_create(service, spec);
+ if (nt)
+ {
+ ci = nmem_malloc(nc->nmem, sizeof(*ci));
+ ci->next = nc->items;
+ nc->items = ci;
+ ci->nt = nt;
+ ci->spec = nmem_strdup(nc->nmem, spec);
+ }
+ return nt;
+}
+
+void normalize_cache_destroy(normalize_cache_t nc)
+{
+ if (nc)
+ {
+ struct cached_item *ci = nc->items;
+ for (; ci; ci = ci->next)
+ normalize_record_destroy(ci->nt);
+ nmem_destroy(nc->nmem);
+ }
+}
+
+/*
+ * Local variables:
+ * c-basic-offset: 4
+ * c-file-style: "Stroustrup"
+ * indent-tabs-mode: nil
+ * End:
+ * vim: shiftwidth=4 tabstop=8 expandtab
+ */
+
--- /dev/null
+/* This file is part of Pazpar2.
+ Copyright (C) 2006-2009 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
+Software Foundation; either version 2, or (at your option) any later
+version.
+
+Pazpar2 is distributed in the hope that it will be useful, but WITHOUT ANY
+WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program; if not, write to the Free Software
+Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+*/
+
+#ifndef NORMALIZE_CACHE_H
+#define NORMALIZE_CACHE_H
+
+#include "normalize_record.h"
+typedef struct normalize_cache_s *normalize_cache_t;
+
+normalize_cache_t normalize_cache_create(void);
+
+normalize_record_t normalize_cache_get(normalize_cache_t nc,
+ struct conf_service *service,
+ const char *spec);
+void normalize_cache_destroy(normalize_cache_t nc);
+
+#endif
+
+/*
+ * Local variables:
+ * c-basic-offset: 4
+ * c-file-style: "Stroustrup"
+ * indent-tabs-mode: nil
+ * End:
+ * vim: shiftwidth=4 tabstop=8 expandtab
+ */
+
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,
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++)
xsltFreeStylesheet(m->stylesheet);
}
nmem_destroy(nt->nmem);
-
- xfree(nt);
}
}
normalize_record_t normalize_record_create(struct conf_service *service,
const char *spec);
-const char *normalize_record_get_spec(normalize_record_t nt);
void normalize_record_destroy(normalize_record_t nt);
int normalize_record_transform(normalize_record_t nt, xmlDoc **doc,
- const char **parms);
+ const char **parms);
#endif
int total_merged;
int number_of_warnings_unknown_elements;
int number_of_warnings_unknown_metadata;
+ normalize_cache_t normalize_cache;
};
struct statistics {
#ifndef PAZPAR2_CONFIG_H
#define PAZPAR2_CONFIG_H
-#include "normalize_record.h"
+#include "normalize_cache.h"
#include <yaz/nmem.h>
#include "charsets.h"
"$(OBJDIR)\marcmap.obj" \
"$(OBJDIR)\marchash.obj" \
"$(OBJDIR)\normalize_record.obj" \
+ "$(OBJDIR)\normalize_cache.obj" \
"$(OBJDIR)\connection.obj"