xref: /onnv-gate/usr/src/lib/libast/common/tm/tmxduration.c (revision 12068:08a39a083754)
110898Sroland.mainz@nrubsig.org /***********************************************************************
210898Sroland.mainz@nrubsig.org *                                                                      *
310898Sroland.mainz@nrubsig.org *               This software is part of the ast package               *
4*12068SRoger.Faulkner@Oracle.COM *          Copyright (c) 1985-2010 AT&T Intellectual Property          *
510898Sroland.mainz@nrubsig.org *                      and is licensed under the                       *
610898Sroland.mainz@nrubsig.org *                  Common Public License, Version 1.0                  *
710898Sroland.mainz@nrubsig.org *                    by AT&T Intellectual Property                     *
810898Sroland.mainz@nrubsig.org *                                                                      *
910898Sroland.mainz@nrubsig.org *                A copy of the License is available at                 *
1010898Sroland.mainz@nrubsig.org *            http://www.opensource.org/licenses/cpl1.0.txt             *
1110898Sroland.mainz@nrubsig.org *         (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9)         *
1210898Sroland.mainz@nrubsig.org *                                                                      *
1310898Sroland.mainz@nrubsig.org *              Information and Software Systems Research               *
1410898Sroland.mainz@nrubsig.org *                            AT&T Research                             *
1510898Sroland.mainz@nrubsig.org *                           Florham Park NJ                            *
1610898Sroland.mainz@nrubsig.org *                                                                      *
1710898Sroland.mainz@nrubsig.org *                 Glenn Fowler <gsf@research.att.com>                  *
1810898Sroland.mainz@nrubsig.org *                  David Korn <dgk@research.att.com>                   *
1910898Sroland.mainz@nrubsig.org *                   Phong Vo <kpv@research.att.com>                    *
2010898Sroland.mainz@nrubsig.org *                                                                      *
2110898Sroland.mainz@nrubsig.org ***********************************************************************/
2210898Sroland.mainz@nrubsig.org #pragma prototyped
2310898Sroland.mainz@nrubsig.org 
2410898Sroland.mainz@nrubsig.org #include <tmx.h>
2510898Sroland.mainz@nrubsig.org #include <ctype.h>
2610898Sroland.mainz@nrubsig.org 
2710898Sroland.mainz@nrubsig.org /*
2810898Sroland.mainz@nrubsig.org  * parse duration expression in s and return Time_t value
2910898Sroland.mainz@nrubsig.org  * if non-null, e points to the first unused char in s
3010898Sroland.mainz@nrubsig.org  * returns 0 with *e==s on error
3110898Sroland.mainz@nrubsig.org  */
3210898Sroland.mainz@nrubsig.org 
3310898Sroland.mainz@nrubsig.org Time_t
tmxduration(const char * s,char ** e)3410898Sroland.mainz@nrubsig.org tmxduration(const char* s, char** e)
3510898Sroland.mainz@nrubsig.org {
3610898Sroland.mainz@nrubsig.org 	Time_t		ns;
3710898Sroland.mainz@nrubsig.org 	Time_t		ts;
3810898Sroland.mainz@nrubsig.org 	Time_t		now;
3910898Sroland.mainz@nrubsig.org 	char*		last;
4010898Sroland.mainz@nrubsig.org 	char*		t;
4110898Sroland.mainz@nrubsig.org 	char*		x;
4210898Sroland.mainz@nrubsig.org 	Sfio_t*		f;
4310898Sroland.mainz@nrubsig.org 	int		i;
4410898Sroland.mainz@nrubsig.org 
4510898Sroland.mainz@nrubsig.org 	now = TMX_NOW;
4610898Sroland.mainz@nrubsig.org 	while (isspace(*s))
4710898Sroland.mainz@nrubsig.org 		s++;
4810898Sroland.mainz@nrubsig.org 	if (*s == 'P' || *s == 'p')
4910898Sroland.mainz@nrubsig.org 		ns = tmxdate(s, &last, now) - now;
5010898Sroland.mainz@nrubsig.org 	else
5110898Sroland.mainz@nrubsig.org 	{
5210898Sroland.mainz@nrubsig.org 		ns = strtod(s, &last) * TMX_RESOLUTION;
5310898Sroland.mainz@nrubsig.org 		if (*last && (f = sfstropen()))
5410898Sroland.mainz@nrubsig.org 		{
5510898Sroland.mainz@nrubsig.org 			sfprintf(f, "exact %s", s);
5610898Sroland.mainz@nrubsig.org 			t = sfstruse(f);
5710898Sroland.mainz@nrubsig.org 			ts = tmxdate(t, &x, now);
5810898Sroland.mainz@nrubsig.org 			if ((i = x - t - 6) > (last - s))
5910898Sroland.mainz@nrubsig.org 			{
6010898Sroland.mainz@nrubsig.org 				last = (char*)s + i;
6110898Sroland.mainz@nrubsig.org 				ns = ts - now;
6210898Sroland.mainz@nrubsig.org 			}
6310898Sroland.mainz@nrubsig.org 			else
6410898Sroland.mainz@nrubsig.org 			{
6510898Sroland.mainz@nrubsig.org 				sfprintf(f, "p%s", s);
6610898Sroland.mainz@nrubsig.org 				t = sfstruse(f);
6710898Sroland.mainz@nrubsig.org 				ts = tmxdate(t, &x, now);
6810898Sroland.mainz@nrubsig.org 				if ((i = x - t - 1) > (last - s))
6910898Sroland.mainz@nrubsig.org 				{
7010898Sroland.mainz@nrubsig.org 					last = (char*)s + i;
7110898Sroland.mainz@nrubsig.org 					ns = ts - now;
7210898Sroland.mainz@nrubsig.org 				}
7310898Sroland.mainz@nrubsig.org 			}
7410898Sroland.mainz@nrubsig.org 			sfstrclose(f);
7510898Sroland.mainz@nrubsig.org 		}
7610898Sroland.mainz@nrubsig.org 	}
7710898Sroland.mainz@nrubsig.org 	if (e)
7810898Sroland.mainz@nrubsig.org 		*e = last;
7910898Sroland.mainz@nrubsig.org 	return ns;
8010898Sroland.mainz@nrubsig.org }
81