This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.

168 lines
3.4 KiB
C
Raw Normal View History

2001-08-17 05:46:24 +00:00
/*****************************************************************************
*
2001-12-23 16:44:18 +00:00
* $Id$
2001-08-17 05:46:24 +00:00
* Purpose ...............: Calculate UTC offset
* Source ................: Eugene G. Crosser's ifmail package.
*
*****************************************************************************
2005-08-28 09:42:08 +00:00
* Copyright (C) 1997-2005
2001-08-17 05:46:24 +00:00
*
* Michiel Broek FIDO: 2:280/2802
* Beekmansbos 10
* 1971 BV IJmuiden
* the Netherlands
*
* This file is part of MBSE BBS.
*
* This BBS 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.
*
* MBSE BBS 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 MBSE BBS; see the file COPYING. If not, write to the Free
2003-08-15 20:05:34 +00:00
* Software Foundation, 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
2001-08-17 05:46:24 +00:00
*****************************************************************************/
2002-06-30 12:48:44 +00:00
#include "../config.h"
2004-02-21 14:24:03 +00:00
#include "mbselib.h"
2001-08-17 05:46:24 +00:00
/*
* Returns the offset from your location to UTC. So in the MET timezone
* this returns -60 (wintertime). People in the USA get positive results.
*/
2005-10-11 20:49:41 +00:00
int gmt_offset(time_t now)
2001-08-17 05:46:24 +00:00
{
2005-10-11 20:49:41 +00:00
struct tm ptm;
struct tm gtm;
int offset;
2001-08-17 05:46:24 +00:00
2005-10-11 20:49:41 +00:00
if (!now)
now = time(NULL);
ptm = *localtime(&now);
2001-08-17 05:46:24 +00:00
2005-10-11 20:49:41 +00:00
/*
* To get the timezone, compare localtime with GMT.
*/
gtm = *gmtime(&now);
2001-08-17 05:46:24 +00:00
2005-10-11 20:49:41 +00:00
/*
* Assume we are never more than 24 hours away.
*/
offset = gtm.tm_yday - ptm.tm_yday;
if (offset > 1)
offset = -24;
else if (offset < -1)
offset = 24;
else
offset *= 24;
2001-08-17 05:46:24 +00:00
2005-10-11 20:49:41 +00:00
/*
* Scale in the hours and minutes; ignore seconds.
*/
offset += gtm.tm_hour - ptm.tm_hour;
offset *= 60;
offset += gtm.tm_min - ptm.tm_min;
2001-08-17 05:46:24 +00:00
2005-10-11 20:49:41 +00:00
return offset;
2001-08-17 05:46:24 +00:00
}
/*
* Returns the TZUTC string, note that the sign is opposite from the
* function above.
*/
char *gmtoffset(time_t now)
{
static char buf[6]="+0000";
char sign;
int hr, min;
2005-10-11 20:49:41 +00:00
int offset;
2001-08-17 05:46:24 +00:00
offset = gmt_offset(now);
if (offset <= 0) {
sign = '+';
offset = -offset;
} else
sign = '-';
hr = offset / 60L;
min = offset % 60L;
if (sign == '-')
2005-08-28 13:34:43 +00:00
snprintf(buf, 6, "%c%02d%02d", sign, hr, min);
2001-08-17 05:46:24 +00:00
else
2005-08-28 13:34:43 +00:00
snprintf(buf, 6, "%02d%02d", hr, min);
2001-08-17 05:46:24 +00:00
return(buf);
}
char *str_time(time_t total)
{
static char buf[10];
int h, m;
memset(&buf, 0, sizeof(buf));
/*
* 0 .. 59 seconds
*/
if (total < (time_t)60) {
2005-08-28 13:34:43 +00:00
snprintf(buf, 10, "%2d.00s", (int)total);
2001-08-17 05:46:24 +00:00
return buf;
}
/*
* 1:00 .. 59:59 minutes:seconds
*/
if (total < (time_t)3600) {
h = total / 60;
m = total % 60;
2005-08-28 13:34:43 +00:00
snprintf(buf, 10, "%2d:%02d ", h, m);
2001-08-17 05:46:24 +00:00
return buf;
}
/*
* 1:00 .. 23:59 hours:minutes
*/
if (total < (time_t)86400) {
h = (total / 60) / 60;
m = (total / 60) % 60;
2005-08-28 13:34:43 +00:00
snprintf(buf, 10, "%2d:%02dm", h, m);
2001-08-17 05:46:24 +00:00
return buf;
}
/*
* 1/00 .. 30/23 days/hours
*/
if (total < (time_t)2592000) {
h = (total / 3600) / 24;
m = (total / 3600) % 24;
2005-08-28 13:34:43 +00:00
snprintf(buf, 10, "%2d/%02dh", h, m);
2001-08-17 05:46:24 +00:00
return buf;
}
2005-08-28 13:34:43 +00:00
snprintf(buf, 10, "N/A ");
2001-08-17 05:46:24 +00:00
return buf;
}
char *t_elapsed(time_t start, time_t end)
{
return str_time(end - start);
}