recstr.c revision da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan/***********************************************************************
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* This software is part of the ast package *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* Copyright (c) 1985-2007 AT&T Knowledge Ventures *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* and is licensed under the *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* Common Public License, Version 1.0 *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* by AT&T Knowledge Ventures *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* A copy of the License is available at *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* http://www.opensource.org/licenses/cpl1.0.txt *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9) *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* Information and Software Systems Research *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* AT&T Research *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* Florham Park NJ *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* Glenn Fowler <gsf@research.att.com> *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* David Korn <dgk@research.att.com> *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan* Phong Vo <kpv@research.att.com> *
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan***********************************************************************/
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * return the record format descriptor given a format string
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * e!=0 set to the first unrecognized char after the format
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * REC_N_TYPE() returned on error
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * d[0xNN|delimiter] (delimited, newline default)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * [f][+]size (fixed length)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * v hN oN zN b|l i|n (variable length with size header)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * h header size in bytes (ibm V 4)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * o size offset in bytes (ibm V 0)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * z size length in bytes (ibm V 2)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * l|b little-endian or big-endian size (ibm V b (0))
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * i|n header included/not-included in size (ibm V i (1))
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalanrecstr(register const char* s, char** e)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan while (*s == ' ' || *s == '\t' || *s == ',')
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan if (*s == '0' && (*(s + 1) == 'x' || *(s + 1) == 'X'))
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan n = (int)strtol(s, &t, 0);
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan s = (const char*)t;
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan *e = (char*)s;
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan while (*++s == ' ' || *s == '\t' || *s == ',');
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan /*FALLTHROUGH*/
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan case '0': case '1': case '2': case '3': case '4':
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan case '5': case '6': case '7': case '8': case '9':
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan if (n > 0 && t > (char*)s)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan while (*++s == ' ' || *s == '\t' || *s == ',');
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan for (t = (char*)s; *t && *t != ' ' && *t != '\t' && *t != ','; t++);
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan if ((t - s) == 4)
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * TBD: look up name in method libraries
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan * and assign an integer index
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan while (*++s == ' ' || *s == '\t' || *s == ',');
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan n = strtol(s, &t, 0);
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan v = strtol(t, &t, 0);
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan case '0': case '1': case '2': case '3': case '4':
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan case '5': case '6': case '7': case '8': case '9':
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan a[n++] = strtol(s, &t, 0);
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan s = (const char*)t - 1;
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan *e = (char*)s;
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan return REC_V_RECORD(REC_V_TYPE(a[1], a[2], a[3], a[4], a[5]), a[0]);
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan *e = (char*)s + 1;
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan *e = (char*)s + 1;
b494511a9cf72b1fc4eb13a0e593f55c624ab829Venki Rajagopalan *e = (char*)s;