/* $Id: d1_handle.c,v 1.3 2002/12/16 20:27:18 adam Exp $ Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002 Index Data Aps This file is part of the Zebra server. Zebra 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. Zebra 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 Zebra; see the file LICENSE.zebra. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include #include struct data1_handle_info { WRBUF wrbuf; char *tab_path; char *tab_root; char *read_buf; int read_len; data1_absyn_cache absyn_cache; data1_attset_cache attset_cache; char *map_buf; int map_len; NMEM mem; int flags; }; data1_handle data1_create (void) { return data1_createx(0); } data1_handle data1_createx (int flags) { data1_handle p = (data1_handle)xmalloc (sizeof(*p)); if (!p) return NULL; p->tab_path = NULL; p->tab_root = NULL; p->wrbuf = wrbuf_alloc(); p->read_buf = NULL; p->read_len = 0; p->map_buf = NULL; p->map_len = 0; p->absyn_cache = NULL; p->attset_cache = NULL; p->mem = nmem_create (); p->flags = flags; return p; } NMEM data1_nmem_get (data1_handle dh) { return dh->mem; } data1_absyn_cache *data1_absyn_cache_get (data1_handle dh) { return &dh->absyn_cache; } data1_attset_cache *data1_attset_cache_get (data1_handle dh) { return &dh->attset_cache; } void data1_destroy (data1_handle dh) { if (!dh) return; /* *ostrich* We need to destroy DFAs, in xp_element (xelm) definitions pop, 2002-12-13 */ data1_absyn_destroy(dh); wrbuf_free (dh->wrbuf, 1); if (dh->tab_path) xfree (dh->tab_path); if (dh->tab_root) xfree (dh->tab_root); if (dh->read_buf) xfree (dh->read_buf); if (dh->map_buf) xfree (dh->map_buf); nmem_destroy (dh->mem); xfree (dh); } WRBUF data1_get_wrbuf (data1_handle dp) { return dp->wrbuf; } char **data1_get_read_buf (data1_handle dp, int **lenp) { *lenp = &dp->read_len; yaz_log (LOG_DEBUG, "data1_get_read_buf lenp=%u", **lenp); return &dp->read_buf; } char **data1_get_map_buf (data1_handle dp, int **lenp) { *lenp = &dp->map_len; yaz_log (LOG_DEBUG, "data1_get_map_buf lenp=%u", **lenp); return &dp->map_buf; } void data1_set_tabpath (data1_handle dp, const char *p) { xfree (dp->tab_path); dp->tab_path = NULL; if (p) dp->tab_path = xstrdup (p); } void data1_set_tabroot (data1_handle dp, const char *p) { xfree (dp->tab_root); dp->tab_root = NULL; if (p) dp->tab_root = xstrdup (p); } const char *data1_get_tabpath (data1_handle dp) { return dp->tab_path; } const char *data1_get_tabroot (data1_handle dp) { return dp->tab_root; } FILE *data1_path_fopen (data1_handle dh, const char *file, const char *mode) { const char *path = data1_get_tabpath(dh); const char *root = data1_get_tabroot(dh); return yaz_fopen (path, file, "r", root); } int data1_is_xmlmode(data1_handle dh) { return dh->flags & DATA1_FLAG_XML; }