-/* $Id: d1_absyn.c,v 1.25 2006-05-19 13:49:33 adam Exp $
+/* $Id: d1_absyn.c,v 1.28 2006-08-14 10:40:06 adam Exp $
Copyright (C) 1995-2006
Index Data ApS
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.
+along with this program; if not, write to the Free Software
+Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
*/
#include <stdio.h>
return p->absyn;
p = p->next;
}
- return NULL;
+ return 0;
}
/* *ostrich*
We need to destroy DFAs, in xp_element (xelm) definitions
}
}
-data1_absyn *data1_absyn_add (data1_handle dh, const char *name)
+static data1_absyn *data1_read_absyn(data1_handle dh, const char *file,
+ enum DATA1_XPATH_INDEXING en);
+
+static data1_absyn *data1_absyn_add(data1_handle dh, const char *name,
+ enum DATA1_XPATH_INDEXING en)
{
char fname[512];
NMEM mem = data1_nmem_get (dh);
data1_absyn_cache p = (data1_absyn_cache)nmem_malloc (mem, sizeof(*p));
data1_absyn_cache *pp = data1_absyn_cache_get (dh);
- sprintf(fname, "%s.abs", name);
- p->absyn = data1_read_absyn (dh, fname, 0);
- p->name = nmem_strdup (mem, name);
+ sprintf(fname, "%.500s.abs", name);
+ p->absyn = data1_read_absyn(dh, fname, en);
+ p->name = nmem_strdup(mem, name);
p->next = *pp;
*pp = p;
return p->absyn;
}
-data1_absyn *data1_get_absyn (data1_handle dh, const char *name)
+data1_absyn *data1_get_absyn (data1_handle dh, const char *name,
+ enum DATA1_XPATH_INDEXING en)
{
data1_absyn *absyn;
if (!(absyn = data1_absyn_search (dh, name)))
- absyn = data1_absyn_add (dh, name);
+ absyn = data1_absyn_add (dh, name, en);
return absyn;
}
return p->attset;
p = p->next;
}
- return NULL;
+ return 0;
}
data1_attset *data1_attset_search_id (data1_handle dh, int id)
return p->attset;
p = p->next;
}
- return NULL;
+ return 0;
}
data1_attset *data1_attset_add (data1_handle dh, const char *name)
{
- char fname[512], aname[512];
NMEM mem = data1_nmem_get (dh);
data1_attset *attset;
-
- strcpy (aname, name);
- sprintf(fname, "%s.att", name);
- attset = data1_read_attset (dh, fname);
- if (!attset)
- {
- char *cp;
- attset = data1_read_attset (dh, name);
- if (attset && (cp = strrchr (aname, '.')))
- *cp = '\0';
- }
+
+ attset = data1_read_attset (dh, name);
if (!attset)
yaz_log (YLOG_WARN|YLOG_ERRNO, "Couldn't load attribute set %s", name);
else
nmem_malloc (mem, sizeof(*p));
data1_attset_cache *pp = data1_attset_cache_get (dh);
- attset->name = p->name = nmem_strdup (mem, aname);
+ attset->name = p->name = nmem_strdup(mem, name);
p->attset = attset;
p->next = *pp;
*pp = p;
return absyn->main_elements;
}
-data1_absyn *data1_read_absyn (data1_handle dh, const char *file,
- int file_must_exist)
+static data1_absyn *data1_read_absyn(data1_handle dh, const char *file,
+ enum DATA1_XPATH_INDEXING default_xpath)
{
data1_sub_elements *cur_elements = NULL;
data1_xpelement *cur_xpelement = NULL;
int argc;
char *argv[50], line[512];
- if (!(f = data1_path_fopen(dh, file, "r")))
- {
- yaz_log(YLOG_WARN|YLOG_ERRNO, "Couldn't open %s", file);
- if (file_must_exist)
- return 0;
- }
+ f = data1_path_fopen(dh, file, "r");
res = (data1_absyn *) nmem_malloc(data1_nmem_get(dh), sizeof(*res));
res->name = 0;
res->reference = VAL_NONE;
res->tagset = 0;
res->encoding = 0;
- res->enable_xpath_indexing = (f ? 0 : 1);
+ res->xpath_indexing =
+ (f ? DATA1_XPATH_INDEXING_DISABLE : default_xpath);
res->systags = 0;
systagsp = &res->systags;
tagset_childp = &res->tagset;
continue;
}
if (!strcmp(argv[1], "enable"))
- res->enable_xpath_indexing = 1;
+ res->xpath_indexing = DATA1_XPATH_INDEXING_ENABLE;
else if (!strcmp (argv[1], "disable"))
- res->enable_xpath_indexing = 0;
+ res->xpath_indexing = DATA1_XPATH_INDEXING_DISABLE;
else
{
yaz_log(YLOG_WARN, "%s:%d: Expecting disable/enable "
fix_element_ref (dh, res, cur_elements->elements);
}
*systagsp = 0;
- yaz_log(YLOG_DEBUG, "%s: data1_read_absyn end", file);
return res;
}
/*