#define _POSIX_C_SOURCE 200809L
#include <errno.h>
#include <time.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define YYYYMMDDhhmmss 0
#define YYMMDDhhmmss 1
#define ssmmhhDDMMYYYY 2
#define ssmmhhDDMMYY 3
int chars_to_int(const char * s, unsigned int n)
{
int rv = 0;
while (n--)
{
if (*s >= 48 && *s <= 57)
{
rv = 10 * rv + (*s-48);
}
else if (*s == 32)
{
// gently handle space
rv *= 10;
}
else
{
return -1;
}
++s;
}
return rv;
}
/**
* Convert a string in one of the following formats into a (possibly negative) offset of seconds.
* +hhmm
* -hhmm
* 2Bhhmm
* 2Dhhmm
* 2bhhmm
* 2dhhmm
*
* where h and m are digits representing hours and minutes
*
* @param input String in one of the formats
* @return true and the offset in seconds if input matches one of the formats
* false and 0 if it does not
*/
int string_to_offset(const char * input)
{
int offset = 0;
int sign = 0;
if (len == 5)
{
offset = 1;
if (input[0] == '+')
{
// +hhmm
sign = +1;
}
else if (input[0] == '-')
{
// -hhmm
sign = -1;
}
}
else if (len == 6 && input[0] == '2')
{
offset = 2;
if (input[1] == 'B' || input[1] == 'b')
{
// 2Bhhmm or 2bhhmm
sign = +1;
}
if (input[1] == 'D' || input[1] == 'd')
{
// 2Dhhmm or 2Dhhmm
sign = -1;
}
}
if (offset != 0 && sign != 0)
{
return (sign * (3600 * chars_to_int(input+offset,2) + 60 * chars_to_int(input+offset+2, 2)));
}
else
{
return -1;
}
}
// Return the current century.
int current_century()
{
int current_century = -1;
if (current_century == -1)
{
time_t rawtime;
struct tm * timeinfo;
current_century = (1900+timeinfo->tm_year)/100;
}
return current_century;
}
// Return the current year.
int current_year()
{
int current_year = -1;
if (current_year == -1)
{
time_t rawtime;
struct tm * timeinfo;
current_year = 1900+timeinfo->tm_year;
}
return current_year;
}
/**
* Add a century to a year, so that the year is max 20 years in the future and max 80 years in the past
*
* @param year The last two digits of the year
* @return The four digit year as int.
*/
int add_century(int year)
{
static const int yearsInFuture = 20;
int currentYear = current_year();
int proposedYear = year + 100*current_century();
if (proposedYear - currentYear > yearsInFuture)
{
// Too far in future, e.g. current year = 2101, year = 99 (proposedYear = 2199)
proposedYear = proposedYear - 100;
}
else if (currentYear - proposedYear > 100 - yearsInFuture)
{
// Too far in the past, e.g. current year = 2099, year = 00 (proposedYear = 2000)
proposedYear = proposedYear + 100;
}
return proposedYear;
}
/**
* Converts a string representing a local date/time to the native time_t type.
* The timezone of the date/time string is indicated by the timezone string which
* may either be in [+-]hhmm or 2[bBdD]hhmm format or may be any timezone recognized
* by the underlying C-library (e.g. "GMT+2").
*
* @param time The string representing the date/time.
* @param timezone The offset compared to UTC represented by the time or the timezone time refers to
* @param format The format in which the date/time is stored in the string
* @return The time in native time_t type
*/
time_t localtime_to_time_t
(const char * time, const char * timezone
, int format
){
//time_t rv;
//////////////
struct tm timeinfo;
switch (format)
{
case YYYYMMDDhhmmss:
timeinfo.
tm_year = chars_to_int
(time + 0, 4) - 1900; timeinfo.
tm_mon = chars_to_int
(time + 4, 2) - 1; timeinfo.
tm_mday = chars_to_int
(time + 6, 2); timeinfo.
tm_hour = chars_to_int
(time + 8, 2); timeinfo.
tm_min = chars_to_int
(time + 10, 2); timeinfo.
tm_sec = chars_to_int
(time + 12, 2); break;
case YYMMDDhhmmss:
timeinfo.
tm_year = add_century
(chars_to_int
(time + 0, 2)) - 1900; timeinfo.
tm_mon = chars_to_int
(time + 2, 2) - 1; timeinfo.
tm_mday = chars_to_int
(time + 4, 2); timeinfo.
tm_hour = chars_to_int
(time + 6, 2); timeinfo.
tm_min = chars_to_int
(time + 8, 2); timeinfo.
tm_sec = chars_to_int
(time + 10, 2); break;
case ssmmhhDDMMYYYY:
timeinfo.
tm_sec = chars_to_int
(time, 2); timeinfo.
tm_min = chars_to_int
(time + 2, 2); timeinfo.
tm_hour = chars_to_int
(time + 4, 2); timeinfo.
tm_mday = chars_to_int
(time + 6, 2); timeinfo.
tm_mon = chars_to_int
(time + 8, 2) - 1; timeinfo.
tm_year = chars_to_int
(time + 10, 4) - 1900; break;
case ssmmhhDDMMYY:
timeinfo.
tm_sec = chars_to_int
(time, 2); timeinfo.
tm_min = chars_to_int
(time + 2, 2); timeinfo.
tm_hour = chars_to_int
(time + 4, 2); timeinfo.
tm_mday = chars_to_int
(time + 6, 2); timeinfo.
tm_mon = chars_to_int
(time + 8, 2) - 1; timeinfo.
tm_year = add_century
(chars_to_int
(time + 0, 2)) - 1900; break;
}
printf("%d\n", timeinfo.
tm_mday);
/////////////
timeinfo.tm_isdst = -1;
int timezone_offset = string_to_offset(timezone);
if (timezone_offset) {
printf("%d\n", timezone_offset
); }
if (timezone_offset > -1)
{
// timezone is an offset
// TZEnv utc("UTC");
//////////////////////////
//char dup_tz[strlen(tz) + 1];
//strcpy(dup_tz, tz);
//puts(dup_tz);
if (tz) {
}
//setenv("TZ", "", 1); // TZ empty refers to UTC
//tzset();
///////////////////////////
// errno = 0;
// rv = mktime(&timeinfo) - timezone_offset;
// int saved_errno = errno;
// setenv("TZ", dup_tz, 1);
// errno = saved_errno;
} else {
return 99999;
}
//if (rv == -1) return -1;
return 0;
}
int main(void) {
time_t epoch = localtime_to_time_t("181218213533", "2b0200", YYMMDDhhmmss);
printf("%lld\n", (long long) epoch
);
return 0;
}
#define _POSIX_C_SOURCE 200809L
#include <errno.h>

#include <time.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define YYYYMMDDhhmmss 0
#define YYMMDDhhmmss 1
#define ssmmhhDDMMYYYY 2
#define ssmmhhDDMMYY 3

int chars_to_int(const char * s, unsigned int n)
{
	int rv = 0;
	while (n--)
	{
		if (*s >= 48 && *s <= 57)
		{
			rv = 10 * rv + (*s-48);
		}
		else if (*s == 32)
		{
			// gently handle space
			rv *= 10;
		}
		else
		{
			return -1;
		}
		++s;
	}
	return rv;
}

/**
 * Convert a string in one of the following formats into a (possibly negative) offset of seconds.
 * +hhmm
 * -hhmm
 * 2Bhhmm
 * 2Dhhmm
 * 2bhhmm
 * 2dhhmm
 *
 * where h and m are digits representing hours and minutes
 *
 * @param input String in one of the formats
 * @return true and the offset in seconds if input matches one of the formats
 *         false and 0 if it does not
 */
int string_to_offset(const char * input)
{
	int len = strlen(input);
	int offset = 0;
	int sign = 0;
	if (len == 5)
	{
		offset = 1;
		if  (input[0] == '+')
		{
			// +hhmm
			sign = +1;
		}
		else if (input[0] == '-')
		{
			// -hhmm
			sign = -1;
		}
	}
	else if (len == 6 && input[0] == '2')
	{
		offset = 2;
		if (input[1] == 'B' || input[1] == 'b')
		{
			// 2Bhhmm or 2bhhmm
			sign = +1;
		}
		if (input[1] == 'D' || input[1] == 'd')
		{
			// 2Dhhmm or 2Dhhmm
			sign = -1;
		}
	}

	if (offset != 0 && sign != 0)
	{
		return (sign * (3600 * chars_to_int(input+offset,2) + 60 * chars_to_int(input+offset+2, 2)));
	}
	else
	{
		return -1;
	}
}

// Return the current century.
int current_century()
{
	int current_century = -1;

	if (current_century == -1)
	{
		time_t rawtime;
		time ( &rawtime );
		struct tm * timeinfo;
		timeinfo = localtime ( &rawtime );
		current_century = (1900+timeinfo->tm_year)/100;
	}

	return current_century;
}

// Return the current year.
int current_year()
{
	int current_year = -1;

	if (current_year == -1)
	{
		time_t rawtime;
		time ( &rawtime );
		struct tm * timeinfo;
		timeinfo = localtime ( &rawtime );
		current_year = 1900+timeinfo->tm_year;
	}

	return current_year;
}

/**
 * Add a century to a year, so that the year is max 20 years in the future and max 80 years in the past
 *
 * @param year The last two digits of the year
 * @return The four digit year as int.
 */
int add_century(int year)
{
	static const int yearsInFuture = 20;

	int currentYear = current_year();
	int proposedYear = year + 100*current_century();
	if (proposedYear - currentYear > yearsInFuture)
	{
		// Too far in future, e.g. current year = 2101, year = 99 (proposedYear = 2199)
		proposedYear = proposedYear - 100;
	}
	else if (currentYear - proposedYear > 100 - yearsInFuture)
	{
		// Too far in the past, e.g. current year = 2099, year = 00 (proposedYear = 2000)
		proposedYear = proposedYear + 100;
	}

	return proposedYear;
}

/**
 * Converts a string representing a local date/time to the native time_t type.
 * The timezone of the date/time string is indicated by the timezone string which
 * may either be in [+-]hhmm or 2[bBdD]hhmm format or may be any timezone recognized
 * by the underlying C-library (e.g. "GMT+2").
 *
 * @param time The string representing the date/time.
 * @param timezone The offset compared to UTC represented by the time or the timezone time refers to
 * @param format The format in which the date/time is stored in the string
 * @return The time in native time_t type
 */
time_t localtime_to_time_t(const char * time, const char * timezone, int format)
{
	//time_t rv;
    
    //////////////
    struct tm timeinfo;
    switch (format)
		{
		case YYYYMMDDhhmmss:
			if (strlen(time) < 14) return 0;
			timeinfo.tm_year = chars_to_int(time + 0, 4) - 1900;
			timeinfo.tm_mon  = chars_to_int(time + 4, 2) - 1;
			timeinfo.tm_mday = chars_to_int(time + 6, 2);
			timeinfo.tm_hour = chars_to_int(time + 8, 2);
			timeinfo.tm_min  = chars_to_int(time + 10, 2);
			timeinfo.tm_sec  = chars_to_int(time + 12, 2);
			break;
		case YYMMDDhhmmss:
			if (strlen(time) < 12) return 0;
			timeinfo.tm_year = add_century(chars_to_int(time + 0, 2)) - 1900;
			timeinfo.tm_mon  = chars_to_int(time + 2, 2) - 1;
			timeinfo.tm_mday = chars_to_int(time + 4, 2);
			timeinfo.tm_hour = chars_to_int(time + 6, 2);
			timeinfo.tm_min  = chars_to_int(time + 8, 2);
			timeinfo.tm_sec  = chars_to_int(time + 10, 2);
			puts("here");
			break;
		case ssmmhhDDMMYYYY:
			if (strlen(time) < 14) return 0;
			timeinfo.tm_sec  = chars_to_int(time, 2);
			timeinfo.tm_min  = chars_to_int(time + 2, 2);
			timeinfo.tm_hour = chars_to_int(time + 4, 2);
			timeinfo.tm_mday = chars_to_int(time + 6, 2);
			timeinfo.tm_mon  = chars_to_int(time + 8, 2) - 1;
			timeinfo.tm_year = chars_to_int(time + 10, 4) - 1900;
			break;
		case ssmmhhDDMMYY:
			if (strlen(time) < 12) return 0;
			timeinfo.tm_sec  = chars_to_int(time, 2);
			timeinfo.tm_min  = chars_to_int(time + 2, 2);
			timeinfo.tm_hour = chars_to_int(time + 4, 2);
			timeinfo.tm_mday = chars_to_int(time + 6, 2);
			timeinfo.tm_mon  = chars_to_int(time + 8, 2) - 1;
			timeinfo.tm_year = add_century(chars_to_int(time + 0, 2)) - 1900;
			break;
    }
    
    printf("%d\n", timeinfo.tm_mday);
    
    /////////////
	
	timeinfo.tm_isdst = -1;
	int timezone_offset = string_to_offset(timezone);
	if (timezone_offset) {
		printf("%d\n", timezone_offset);
	}
	
	
	if (timezone_offset > -1)
	{
		// timezone is an offset
		// TZEnv utc("UTC");
		
		//////////////////////////
		char   *tz = getenv("TZ");
		//char dup_tz[strlen(tz) + 1];
		//strcpy(dup_tz, tz);
		//puts(dup_tz);
	if (tz) {
		
	}

    //setenv("TZ", "", 1); // TZ empty refers to UTC
    //tzset();


		///////////////////////////
		
	//	errno = 0;
	 //   rv = mktime(&timeinfo) - timezone_offset;
	 //   int saved_errno = errno;
	    
     //   setenv("TZ", dup_tz, 1);


    //	errno = saved_errno;
    	
	} else {
		return 99999;
	}

	//if (rv == -1) return -1;
	return 0;
}

int main(void) {
	
	time_t epoch = localtime_to_time_t("181218213533", "2b0200", YYMMDDhhmmss);
	printf("%lld\n", (long long) epoch);
	
	return 0;
}
