* Sebastian Hammer, Adam Dickmeiss
*
* $Log: regxread.c,v $
- * Revision 1.14 1998-03-05 08:41:00 adam
+ * Revision 1.17 1998-07-01 10:13:51 adam
+ * Minor fix.
+ *
+ * Revision 1.16 1998/06/30 15:15:09 adam
+ * Tags are trimmed: white space removed before- and after the tag.
+ *
+ * Revision 1.15 1998/06/30 12:55:45 adam
+ * Bug fix.
+ *
+ * Revision 1.14 1998/03/05 08:41:00 adam
* Implemented rule contexts.
*
* Revision 1.13 1997/12/12 06:33:58 adam
#include <stdio.h>
#include <assert.h>
#include <string.h>
+#include <ctype.h>
#include <tpath.h>
#include <zebrautl.h>
char *nb = xmalloc (elen + res->u.data.len);
memcpy (nb, res->u.data.data, res->u.data.len);
memcpy (nb + res->u.data.len, ebuf, elen);
- if (res->u.data.len > DATA1_LOCALDATA)
- xfree (res->u.data.data);
res->u.data.data = nb;
res->destroy = destroy_data;
}
d1_stack[++(*d1_level)] = NULL;
}
+static void tagStrip (const char **tag, int *len)
+{
+ int i;
+
+ for (i = *len; i > 0 && isspace((*tag)[i-1]); --i)
+ ;
+ *len = i;
+ for (i = 0; i < *len && isspace((*tag)[i]); i++)
+ ;
+ *tag += i;
+ *len -= i;
+}
+
static void tagBegin (struct lexSpec *spec,
data1_node **d1_stack, int *d1_level,
const char *tag, int len)
logf (LOG_WARN, "in element begin. No record type defined");
return ;
}
-
+ tagStrip (&tag, &len);
+
res = data1_mk_node (spec->dh, spec->m);
res->parent = parent;
res->which = DATA1N_tag;
data1_node **d1_stack, int *d1_level,
const char *tag, int len)
{
+ tagStrip (&tag, &len);
while (*d1_level > 1)
{
(*d1_level)--;
return NULL;
}
}
+ curLexSpec->dh = p->dh;
if (!p->offset)
{
curLexSpec->f_win_start = 0;