2000-05-06 21:34:20 +02:00
|
|
|
/****************************************************************/
|
|
|
|
/* */
|
|
|
|
/* systime.c */
|
|
|
|
/* */
|
|
|
|
/* DOS/C Date/Time Functions */
|
|
|
|
/* */
|
|
|
|
/* Copyright (c) 1998 */
|
|
|
|
/* Pasquale J. Villani */
|
|
|
|
/* All Rights Reserved */
|
|
|
|
/* */
|
|
|
|
/* This file is part of DOS-C. */
|
|
|
|
/* */
|
|
|
|
/* DOS-C 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. */
|
|
|
|
/* */
|
|
|
|
/* DOS-C 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 DOS-C; see the file COPYING. If not, */
|
|
|
|
/* write to the Free Software Foundation, 675 Mass Ave, */
|
|
|
|
/* Cambridge, MA 02139, USA. */
|
|
|
|
/****************************************************************/
|
|
|
|
|
|
|
|
#include "portab.h"
|
|
|
|
#include "time.h"
|
|
|
|
#include "date.h"
|
|
|
|
#include "globals.h"
|
|
|
|
|
|
|
|
#ifdef VERSION_STRINGS
|
|
|
|
static BYTE *RcsId = "$Id$";
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* $Log$
|
2000-05-25 22:56:23 +02:00
|
|
|
* Revision 1.3 2000/05/25 20:56:21 jimtabor
|
|
|
|
* Fixed project history
|
|
|
|
*
|
2000-05-08 06:30:00 +02:00
|
|
|
* Revision 1.2 2000/05/08 04:30:00 jimtabor
|
|
|
|
* Update CVS to 2020
|
2000-05-06 21:34:20 +02:00
|
|
|
*
|
2000-05-25 22:56:23 +02:00
|
|
|
* Revision 1.1.1.1 2000/05/06 19:34:53 jhall1
|
|
|
|
* The FreeDOS Kernel. A DOS kernel that aims to be 100% compatible with
|
|
|
|
* MS-DOS. Distributed under the GNU GPL.
|
|
|
|
*
|
2000-05-06 21:34:20 +02:00
|
|
|
* Revision 1.3 1999/05/04 16:40:30 jprice
|
|
|
|
* ror4 date fix
|
|
|
|
*
|
|
|
|
* Revision 1.2 1999/04/12 03:21:18 jprice
|
|
|
|
* more ror4 patches. Changes for multi-block IO
|
|
|
|
*
|
|
|
|
* Revision 1.1.1.1 1999/03/29 15:41:34 jprice
|
|
|
|
* New version without IPL.SYS
|
|
|
|
*
|
|
|
|
* Revision 1.5 1999/02/08 05:55:58 jprice
|
|
|
|
* Added Pat's 1937 kernel patches
|
|
|
|
*
|
|
|
|
* Revision 1.4 1999/02/04 03:14:07 jprice
|
|
|
|
* Formating. Added comments.
|
|
|
|
*
|
|
|
|
* Revision 1.3 1999/02/01 01:48:41 jprice
|
|
|
|
* Clean up; Now you can use hex numbers in config.sys. added config.sys screen function to change screen mode (28 or 43/50 lines)
|
|
|
|
*
|
|
|
|
* Revision 1.2 1999/01/22 04:13:27 jprice
|
|
|
|
* Formating
|
|
|
|
*
|
|
|
|
* Revision 1.1.1.1 1999/01/20 05:51:01 jprice
|
|
|
|
* Imported sources
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Rev 1.6 06 Dec 1998 8:47:30 patv
|
|
|
|
* Bug fixes.
|
|
|
|
*
|
|
|
|
* Rev 1.5 04 Jan 1998 23:15:22 patv
|
|
|
|
* Changed Log for strip utility
|
|
|
|
*
|
|
|
|
* Rev 1.4 03 Jan 1998 8:36:50 patv
|
|
|
|
* Converted data area to SDA format
|
|
|
|
*
|
|
|
|
* Rev 1.3 29 May 1996 21:03:40 patv
|
|
|
|
* bug fixes for v0.91a
|
|
|
|
*
|
|
|
|
* Rev 1.2 19 Feb 1996 3:21:34 patv
|
|
|
|
* Added NLS, int2f and config.sys processing
|
|
|
|
*
|
|
|
|
* Rev 1.1 01 Sep 1995 17:54:16 patv
|
|
|
|
* First GPL release.
|
|
|
|
*
|
|
|
|
* Rev 1.0 02 Jul 1995 8:32:20 patv
|
|
|
|
* Initial revision.
|
|
|
|
*/
|
|
|
|
|
|
|
|
static WORD days[2][13] =
|
|
|
|
{
|
|
|
|
{0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365},
|
|
|
|
{0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366}
|
|
|
|
};
|
|
|
|
|
|
|
|
static WORD ndays[2][13] =
|
|
|
|
{
|
|
|
|
/* 1 2 3 4 5 6 7 8 9 10 11 12 */
|
|
|
|
{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
|
|
|
|
{0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
|
|
|
|
};
|
|
|
|
|
|
|
|
extern BYTE
|
|
|
|
Month,
|
|
|
|
DayOfMonth,
|
|
|
|
DayOfWeek;
|
|
|
|
|
|
|
|
extern COUNT
|
|
|
|
Year,
|
|
|
|
YearsSince1980;
|
|
|
|
|
|
|
|
extern request
|
|
|
|
ClkReqHdr;
|
|
|
|
|
|
|
|
VOID DosGetTime(BYTE FAR * hp, BYTE FAR * mp, BYTE FAR * sp, BYTE FAR * hdp)
|
|
|
|
{
|
|
|
|
ClkReqHdr.r_length = sizeof(request);
|
|
|
|
ClkReqHdr.r_command = C_INPUT;
|
|
|
|
ClkReqHdr.r_count = sizeof(struct ClockRecord);
|
|
|
|
ClkReqHdr.r_trans = (BYTE FAR *) (&ClkRecord);
|
|
|
|
ClkReqHdr.r_status = 0;
|
|
|
|
execrh((request FAR *) & ClkReqHdr, (struct dhdr FAR *)clock);
|
|
|
|
if (ClkReqHdr.r_status & S_ERROR)
|
|
|
|
return;
|
|
|
|
|
|
|
|
*hp = ClkRecord.clkHours;
|
|
|
|
*mp = ClkRecord.clkMinutes;
|
|
|
|
*sp = ClkRecord.clkSeconds;
|
|
|
|
*hdp = ClkRecord.clkHundredths;
|
|
|
|
}
|
|
|
|
|
|
|
|
COUNT DosSetTime(BYTE FAR * hp, BYTE FAR * mp, BYTE FAR * sp, BYTE FAR * hdp)
|
|
|
|
{
|
|
|
|
DosGetDate((BYTE FAR *) & DayOfWeek, (BYTE FAR *) & Month,
|
|
|
|
(BYTE FAR *) & DayOfMonth, (COUNT FAR *) & Year);
|
|
|
|
|
|
|
|
ClkRecord.clkHours = *hp;
|
|
|
|
ClkRecord.clkMinutes = *mp;
|
|
|
|
ClkRecord.clkSeconds = *sp;
|
|
|
|
ClkRecord.clkHundredths = *hdp;
|
|
|
|
|
|
|
|
YearsSince1980 = Year - 1980;
|
|
|
|
ClkRecord.clkDays = DayOfMonth - 1
|
|
|
|
+ days[is_leap_year(Year)][Month - 1]
|
|
|
|
+ ((YearsSince1980) * 365)
|
|
|
|
+ ((YearsSince1980 + 3) / 4);
|
|
|
|
|
|
|
|
ClkReqHdr.r_length = sizeof(request);
|
|
|
|
ClkReqHdr.r_command = C_OUTPUT;
|
|
|
|
ClkReqHdr.r_count = sizeof(struct ClockRecord);
|
|
|
|
ClkReqHdr.r_trans = (BYTE FAR *) (&ClkRecord);
|
|
|
|
ClkReqHdr.r_status = 0;
|
|
|
|
execrh((request FAR *) & ClkReqHdr, (struct dhdr FAR *)clock);
|
|
|
|
if (ClkReqHdr.r_status & S_ERROR)
|
|
|
|
return char_error(&ClkReqHdr, (struct dhdr FAR *)clock);
|
|
|
|
return SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID DosGetDate(wdp, mp, mdp, yp)
|
|
|
|
BYTE FAR *wdp,
|
|
|
|
FAR * mp,
|
|
|
|
FAR * mdp;
|
|
|
|
COUNT FAR *yp;
|
|
|
|
{
|
|
|
|
COUNT count,
|
|
|
|
c;
|
|
|
|
|
|
|
|
ClkReqHdr.r_length = sizeof(request);
|
|
|
|
ClkReqHdr.r_command = C_INPUT;
|
|
|
|
ClkReqHdr.r_count = sizeof(struct ClockRecord);
|
|
|
|
ClkReqHdr.r_trans = (BYTE FAR *) (&ClkRecord);
|
|
|
|
ClkReqHdr.r_status = 0;
|
|
|
|
execrh((request FAR *) & ClkReqHdr, (struct dhdr FAR *)clock);
|
|
|
|
if (ClkReqHdr.r_status & S_ERROR)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (Year = 1980, c = ClkRecord.clkDays; c > 0;)
|
|
|
|
{
|
|
|
|
count = is_leap_year(Year) ? 366 : 365;
|
|
|
|
if (c >= count)
|
|
|
|
{
|
|
|
|
++Year;
|
|
|
|
c -= count;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* c contains the days left and count the number of days for */
|
|
|
|
/* that year. Use this to index the table. */
|
|
|
|
Month = 1;
|
|
|
|
while (c >= ndays[count == 366][Month])
|
|
|
|
{
|
|
|
|
c -= ndays[count == 366][Month];
|
|
|
|
++Month;
|
|
|
|
}
|
|
|
|
|
|
|
|
*mp = Month;
|
|
|
|
*mdp = c + 1;
|
|
|
|
*yp = Year;
|
|
|
|
|
|
|
|
/* Day of week is simple. Take mod 7, add 2 (for Tuesday */
|
|
|
|
/* 1-1-80) and take mod again */
|
|
|
|
|
|
|
|
DayOfWeek = (ClkRecord.clkDays % 7 + 2) % 7;
|
|
|
|
*wdp = DayOfWeek;
|
|
|
|
}
|
|
|
|
|
|
|
|
COUNT DosSetDate(mp, mdp, yp)
|
|
|
|
BYTE FAR *mp,
|
|
|
|
FAR * mdp;
|
|
|
|
COUNT FAR *yp;
|
|
|
|
{
|
|
|
|
Month = *mp;
|
|
|
|
DayOfMonth = *mdp;
|
|
|
|
Year = *yp;
|
|
|
|
if (Year < 1980 || Year > 2099
|
|
|
|
|| Month < 1 || Month > 12
|
|
|
|
|| DayOfMonth < 1 || DayOfMonth > ndays[is_leap_year(Year)][Month])
|
|
|
|
return DE_INVLDDATA;
|
|
|
|
|
|
|
|
DosGetTime((BYTE FAR *) & ClkRecord.clkHours,
|
|
|
|
(BYTE FAR *) & ClkRecord.clkMinutes,
|
|
|
|
(BYTE FAR *) & ClkRecord.clkSeconds,
|
|
|
|
(BYTE FAR *) & ClkRecord.clkHundredths);
|
|
|
|
|
|
|
|
YearsSince1980 = Year - 1980;
|
|
|
|
ClkRecord.clkDays = DayOfMonth - 1
|
|
|
|
+ days[is_leap_year(Year)][Month - 1]
|
|
|
|
+ ((YearsSince1980) * 365)
|
|
|
|
+ ((YearsSince1980 + 3) / 4);
|
|
|
|
|
|
|
|
ClkReqHdr.r_length = sizeof(request);
|
|
|
|
ClkReqHdr.r_command = C_OUTPUT;
|
|
|
|
ClkReqHdr.r_count = sizeof(struct ClockRecord);
|
|
|
|
ClkReqHdr.r_trans = (BYTE FAR *) (&ClkRecord);
|
|
|
|
ClkReqHdr.r_status = 0;
|
|
|
|
execrh((request FAR *) & ClkReqHdr, (struct dhdr FAR *)clock);
|
|
|
|
if (ClkReqHdr.r_status & S_ERROR)
|
|
|
|
return char_error(&ClkReqHdr, (struct dhdr FAR *)clock);
|
|
|
|
return SUCCESS;
|
|
|
|
}
|