summaryrefslogtreecommitdiff
path: root/protocols/EmLanProto/src/get_time.cpp
blob: f03b3965f91368650948ebcd5ba7c0759f472d48 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/*
Miranda ICQ: the free icq client for MS Windows 
Copyright (C) 2000-2  Richard Hughes, Roland Rabien & Tristan Van de Vreede

This program 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
of the License, or (at your option) any later version.

This program 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 this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
*/

#include "stdafx.h"


static int daysInMonth[]={31,28,31,30,31,30,31,31,30,31,30,31};
static int IsLeapYear(int year)
{
	if (year&3) return 0;
	if (year%100) return 1;
	if (year%400) return 0;
	return 1;
}

static DWORD YMDHMSToTime(int year,int month,int day,int hour,int minute,int second)
{
	DWORD ret=0;
	int i;

	for(i=1970;i<year;i++) ret+=365+IsLeapYear(i);
	for(i=0;i<month-1;i++) ret+=daysInMonth[i];
	if (month>2 && IsLeapYear(year)) ret++;
	ret+=day-1;
	ret*=24*3600;
	return ret+3600*hour+60*minute+second;
}


static DWORD TimestampLocalToGMT(DWORD from)
{
	FILETIME ft1,ft2;
	LARGE_INTEGER liFiletime;

	//this huge number is the difference between 1970 and 1601 in seconds
	//liFiletime.QuadPart=(11644473600i64+(__int64)from)*10000000;
	__int64 t = 11644473600;				
	liFiletime.QuadPart=(t+(__int64)from)*10000000;
	ft1.dwHighDateTime=liFiletime.HighPart;
	ft1.dwLowDateTime=liFiletime.LowPart;
	LocalFileTimeToFileTime(&ft1,&ft2);
	liFiletime.HighPart=ft2.dwHighDateTime;
	liFiletime.LowPart=ft2.dwLowDateTime;
	return (DWORD)(liFiletime.QuadPart/10000000-t);
}

DWORD get_time()
{
	SYSTEMTIME stime;
	GetSystemTime(&stime);
	return YMDHMSToTime(stime.wYear,stime.wMonth,stime.wDay,stime.wHour,stime.wMinute,stime.wSecond);
}