134f9b3eeSRoland Mainz /***********************************************************************
234f9b3eeSRoland Mainz * *
334f9b3eeSRoland Mainz * This software is part of the ast package *
4*3e14f97fSRoger A. Faulkner * Copyright (c) 1985-2010 AT&T Intellectual Property *
534f9b3eeSRoland Mainz * and is licensed under the *
634f9b3eeSRoland Mainz * Common Public License, Version 1.0 *
734f9b3eeSRoland Mainz * by AT&T Intellectual Property *
834f9b3eeSRoland Mainz * *
934f9b3eeSRoland Mainz * A copy of the License is available at *
1034f9b3eeSRoland Mainz * http://www.opensource.org/licenses/cpl1.0.txt *
1134f9b3eeSRoland Mainz * (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9) *
1234f9b3eeSRoland Mainz * *
1334f9b3eeSRoland Mainz * Information and Software Systems Research *
1434f9b3eeSRoland Mainz * AT&T Research *
1534f9b3eeSRoland Mainz * Florham Park NJ *
1634f9b3eeSRoland Mainz * *
1734f9b3eeSRoland Mainz * Glenn Fowler <gsf@research.att.com> *
1834f9b3eeSRoland Mainz * David Korn <dgk@research.att.com> *
1934f9b3eeSRoland Mainz * Phong Vo <kpv@research.att.com> *
2034f9b3eeSRoland Mainz * *
2134f9b3eeSRoland Mainz ***********************************************************************/
2234f9b3eeSRoland Mainz #pragma prototyped
2334f9b3eeSRoland Mainz
2434f9b3eeSRoland Mainz #include <tmx.h>
2534f9b3eeSRoland Mainz #include <ctype.h>
2634f9b3eeSRoland Mainz
2734f9b3eeSRoland Mainz /*
2834f9b3eeSRoland Mainz * parse duration expression in s and return Time_t value
2934f9b3eeSRoland Mainz * if non-null, e points to the first unused char in s
3034f9b3eeSRoland Mainz * returns 0 with *e==s on error
3134f9b3eeSRoland Mainz */
3234f9b3eeSRoland Mainz
3334f9b3eeSRoland Mainz Time_t
tmxduration(const char * s,char ** e)3434f9b3eeSRoland Mainz tmxduration(const char* s, char** e)
3534f9b3eeSRoland Mainz {
3634f9b3eeSRoland Mainz Time_t ns;
3734f9b3eeSRoland Mainz Time_t ts;
3834f9b3eeSRoland Mainz Time_t now;
3934f9b3eeSRoland Mainz char* last;
4034f9b3eeSRoland Mainz char* t;
4134f9b3eeSRoland Mainz char* x;
4234f9b3eeSRoland Mainz Sfio_t* f;
4334f9b3eeSRoland Mainz int i;
4434f9b3eeSRoland Mainz
4534f9b3eeSRoland Mainz now = TMX_NOW;
4634f9b3eeSRoland Mainz while (isspace(*s))
4734f9b3eeSRoland Mainz s++;
4834f9b3eeSRoland Mainz if (*s == 'P' || *s == 'p')
4934f9b3eeSRoland Mainz ns = tmxdate(s, &last, now) - now;
5034f9b3eeSRoland Mainz else
5134f9b3eeSRoland Mainz {
5234f9b3eeSRoland Mainz ns = strtod(s, &last) * TMX_RESOLUTION;
5334f9b3eeSRoland Mainz if (*last && (f = sfstropen()))
5434f9b3eeSRoland Mainz {
5534f9b3eeSRoland Mainz sfprintf(f, "exact %s", s);
5634f9b3eeSRoland Mainz t = sfstruse(f);
5734f9b3eeSRoland Mainz ts = tmxdate(t, &x, now);
5834f9b3eeSRoland Mainz if ((i = x - t - 6) > (last - s))
5934f9b3eeSRoland Mainz {
6034f9b3eeSRoland Mainz last = (char*)s + i;
6134f9b3eeSRoland Mainz ns = ts - now;
6234f9b3eeSRoland Mainz }
6334f9b3eeSRoland Mainz else
6434f9b3eeSRoland Mainz {
6534f9b3eeSRoland Mainz sfprintf(f, "p%s", s);
6634f9b3eeSRoland Mainz t = sfstruse(f);
6734f9b3eeSRoland Mainz ts = tmxdate(t, &x, now);
6834f9b3eeSRoland Mainz if ((i = x - t - 1) > (last - s))
6934f9b3eeSRoland Mainz {
7034f9b3eeSRoland Mainz last = (char*)s + i;
7134f9b3eeSRoland Mainz ns = ts - now;
7234f9b3eeSRoland Mainz }
7334f9b3eeSRoland Mainz }
7434f9b3eeSRoland Mainz sfstrclose(f);
7534f9b3eeSRoland Mainz }
7634f9b3eeSRoland Mainz }
7734f9b3eeSRoland Mainz if (e)
7834f9b3eeSRoland Mainz *e = last;
7934f9b3eeSRoland Mainz return ns;
8034f9b3eeSRoland Mainz }
81