--- /dev/null
+/* $Id: d1_utils.c,v 1.1 2006-07-06 12:42:21 marc Exp $
+ Copyright (C) 1995-2006
+ 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 <stdio.h>
+#include <assert.h>
+#include <stdlib.h>
+
+#include <yaz/log.h>
+#include <idzebra/data1.h>
+
+
+void data1_remove_node (data1_handle dh, data1_node *n)
+{
+ fprintf (stdout, "REMOVE tag %s \n", n->u.tag.tag);
+ /* n is first childen */
+ if(n->parent->child == n){
+ n->parent->child = n->next;
+
+ /* n is the only child */
+ if(! n->next){
+ n->parent->last_child = 0;
+ }
+ }
+ /* n is one of the following childrens */
+ else {
+ data1_node * before;
+
+ /* need to find sibling before me */
+ before = n->parent->child;
+ while (before->next != n)
+ before = before->next;
+
+ before->next = n->next;
+
+ /* n is last child of many */
+ if ( n->parent->last_child == n){
+ n->parent->last_child = before;
+ }
+ }
+ /* break pointers to root, parent and following siblings */
+ n->parent = 0;
+ n->root = 0;
+ n->next = 0;
+}
+
+void data1_remove_idzebra_subtree (data1_handle dh, data1_node *n)
+{
+ switch (n->which)
+ {
+ /*
+ case DATA1N_root:
+ break;
+ */
+ case DATA1N_tag:
+ if (!strcmp(n->u.tag.tag, "idzebra")){
+ if (n->u.tag.attributes){
+ data1_xattr *xattr = n->u.tag.attributes;
+
+ for (; xattr; xattr = xattr->next){
+ if (!strcmp(xattr->name, "xmlns")
+ & !strcmp(xattr->value,
+ "http://www.indexdata.dk/zebra/"))
+ data1_remove_node (dh, n);
+ }
+ }
+ }
+
+ break;
+ /*
+ case DATA1N_data:
+ break;
+ case DATA1N_comment:
+ break;
+ case DATA1N_preprocess:
+ break;
+ case DATA1N_variant:
+ break;
+ */
+ default:
+ break;
+ }
+ if (n->child)
+ data1_remove_idzebra_subtree (dh, n->child);
+ if (n->next)
+ data1_remove_idzebra_subtree (dh, n->next);
+ /*
+ else
+ {
+ if (n->parent && n->parent->last_child != n)
+ fprintf(out, "%*sWARNING: last_child=%p != %p\n", level, "",
+ n->parent->last_child, n);
+ }
+ */
+
+}
+
+
+
+/*
+ * Local variables:
+ * c-basic-offset: 4
+ * indent-tabs-mode: nil
+ * End:
+ * vim: shiftwidth=4 tabstop=8 expandtab
+ */
+
-/* $Id: data1.h,v 1.16 2006-07-06 11:40:24 adam Exp $
+/* $Id: data1.h,v 1.17 2006-07-06 12:42:22 marc Exp $
Copyright (C) 1995-2006
Index Data ApS
YAZ_EXPORT data1_node *data1_read_record(data1_handle dh,
int (*rf)(void *, char *, size_t),
void *fh, NMEM m);
+
+YAZ_EXPORT void data1_remove_node (data1_handle dh, data1_node *n);
+YAZ_EXPORT void data1_remove_idzebra_subtree (data1_handle dh, data1_node *n);
YAZ_EXPORT data1_tag *data1_gettagbynum(data1_handle dh,
data1_tagset *s,
int type, int value);
-/* $Id: recgrs.c,v 1.2 2006-07-06 11:40:25 adam Exp $
+/* $Id: recgrs.c,v 1.3 2006-07-06 12:42:22 marc Exp $
Copyright (C) 1995-2006
Index Data ApS
}
(*p->init)(p, &wrd);
+ /* data1_pr_tree(p->dh, n, stdout); */
+
return dumpkeys(n, p, &wrd);
}
/* ensure our data1 tree is UTF-8 */
data1_iconv (p->dh, mem, n, "UTF-8", data1_get_encoding(p->dh, n));
+
+ data1_remove_idzebra_subtree (p->dh, n);
+
#if 0
data1_pr_tree (p->dh, n, stdout);
#endif
}
data1_concat_text(p->dh, mem, node);
+ data1_remove_idzebra_subtree (p->dh, node);
+
#if 0
data1_pr_tree (p->dh, node, stdout);
#endif
-# $Id: Makefile.am,v 1.3 2006-07-03 14:27:21 adam Exp $
+# $Id: Makefile.am,v 1.4 2006-07-06 12:42:23 marc Exp $
-check_PROGRAMS = text grs.xml grs.marc
+check_PROGRAMS = text grs.xml grs.xml.idzebra grs.marc
TESTS = $(check_PROGRAMS)
-EXTRA_DIST = zebra.cfg record.xml record.mrc
+EXTRA_DIST = zebra.cfg record.xml record-idzebra.xml record.mrc
text_SOURCES = text.c
grs_xml_SOURCES = grs.xml.c
+grs_xml_idzebra_SOURCES = grs.xml.idzebra.c
grs_marc_SOURCES = grs.marc.c
AM_CPPFLAGS = -I$(top_srcdir)/include $(YAZINC)