tm struct time.h not normalizing

912 views Asked by At

I am adding values to the time (hours, minutes, seconds) members of my tm struct and they are not updating/normalizing even though I'm using mktime() Here is the code:

struct tm timeStruct;
char buffer[80];

timeStruct.tm_year = 2016 - 1900;
timeStruct.tm_mon = 3;
timeStruct.tm_mday = 32;
timeStruct.tm_hour = 23;
timeStruct.tm_min = 59;
timeStruct.tm_sec = 59;
timeStruct.tm_isdst = -1;

printf( "Date before adding interval: \n");
mktime(&timeStruct);
strftime(buffer, sizeof(buffer), "%c", &timeStruct);
printf(buffer);

printf( "\nthe year is %d\n", timeStruct.tm_year );
printf( "the month is %d\n", timeStruct.tm_mon );
printf( "the day is %d\n", timeStruct.tm_mday );
printf( "the hours are %d\n", timeStruct.tm_hour );
printf( "the minutes are %d\n", timeStruct.tm_min );
printf( "the seconds are %d\n", timeStruct.tm_sec );

/*
 * Add intervals to time
 */
timeStruct.tm_sec += 2;
timeStruct.tm_min += 2;
timeStruct.tm_hour += 5;

printf( "Date after adding interval: \n");
strftime(buffer, sizeof(buffer), "%c", &timeStruct);
printf(buffer);

printf( "\nthe year is %d\n", timeStruct.tm_year );
printf( "the month is %d\n", timeStruct.tm_mon );
printf( "the day is %d\n", timeStruct.tm_mday );
printf( "the hours are %d\n", timeStruct.tm_hour );
printf( "the minutes are %d\n", timeStruct.tm_min );
printf( "the seconds are %d\n", timeStruct.tm_sec );

Console Output:1

This is a print out of the console output:

Date before adding interval: 
Mon May  2 23:59:59 2016
the year is 116
the month is 4
the day is 2
the hours are 23
the minutes are 59
the seconds are 59
Date after adding interval: 
Mon May  2 28:61:61 2016
the year is 116
the month is 4
the day is 2
the hours are 28
the minutes are 61
the seconds are 61

I am using Eclipse, compiling with Cygwin, on a Windows 7 machine.

2

There are 2 answers

0
Yu Hao On BEST ANSWER

In your code, mktime() is called only before adding intervals. You need to call it after adding intervals (so that it can normalize the updated timeStruct):

printf( "Date after adding interval: \n");
mktime(&timeStruct);    // <--- here
strftime(buffer, sizeof(buffer), "%c", &timeStruct);

Output:

Tue May  3 05:02:01 2016
the year is 116
the month is 4
the day is 3
the hours are 5
the minutes are 2
the seconds are 1
0
user3629249 On

here is the corrected code:

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

struct tm timeStruct;
char buffer[80];

int main( void )
{
    timeStruct.tm_year = 2016 - 1900;
    timeStruct.tm_mon = 3;
    timeStruct.tm_mday = 32;
    timeStruct.tm_hour = 23;
    timeStruct.tm_min = 59;
    timeStruct.tm_sec = 59;
    timeStruct.tm_isdst = -1;

    printf( "Date before adding interval: \n");
    if( (time_t)-1 == mktime(&timeStruct) )
    {
        perror( "first call to mktime failed due to: ");
    }

    if( 0 == strftime(buffer, sizeof(buffer), "%c", &timeStruct) )
    {
        perror( "first call to strftime failed due to: ");
    }

    printf( "\n\n%s\n", buffer);

    printf( "\nthe year is %d\n", timeStruct.tm_year );
    printf( "the month is %d\n", timeStruct.tm_mon );
    printf( "the day is %d\n", timeStruct.tm_mday );
    printf( "the hours are %d\n", timeStruct.tm_hour );
    printf( "the minutes are %d\n", timeStruct.tm_min );
    printf( "the seconds are %d\n", timeStruct.tm_sec );

    /*
     * Add intervals to time
     */
    timeStruct.tm_sec += 2;
    timeStruct.tm_min += 2;
    timeStruct.tm_hour += 5;
    timeStruct.tm_year = 2016 - 1900;
    timeStruct.tm_mon = 3;
    timeStruct.tm_mday = 32;
    timeStruct.tm_hour = 23;
    timeStruct.tm_min = 59;
    timeStruct.tm_sec = 59;
    timeStruct.tm_isdst = -1;

    printf( "Date after adding first interval: \n");
    if( (time_t)-1 == mktime(&timeStruct) )
    {
        perror( "second call to mktime failed due to: ");
    }

    if( 0 == strftime(buffer, sizeof(buffer), "%c", &timeStruct) )
    {
        perror( "second call to strftime failed due to: ");
    }

    printf("\n\n%s\n", buffer);

    printf( "\nthe year is %d\n", timeStruct.tm_year );
    printf( "the month is %d\n", timeStruct.tm_mon );
    printf( "the day is %d\n", timeStruct.tm_mday );
    printf( "the hours are %d\n", timeStruct.tm_hour );
    printf( "the minutes are %d\n", timeStruct.tm_min );
    printf( "the seconds are %d\n", timeStruct.tm_sec );

    /*
     * Add intervals to time
     */
    timeStruct.tm_sec += 2;
    timeStruct.tm_min += 2;
    timeStruct.tm_hour += 5;

    printf( "Date after adding second interval: \n");
    if( (time_t)-1 == mktime(&timeStruct) )
    {
        perror( "third call to mktime failed due to: ");
    }

    if( 0 == strftime(buffer, sizeof(buffer), "%c", &timeStruct) )
    {
        perror( "third call to strftime failed due to: ");
    }

    printf("\n\n%s\n", buffer);

    printf( "\nthe year is %d\n", timeStruct.tm_year );
    printf( "the month is %d\n", timeStruct.tm_mon );
    printf( "the day is %d\n", timeStruct.tm_mday );
    printf( "the hours are %d\n", timeStruct.tm_hour );
    printf( "the minutes are %d\n", timeStruct.tm_min );
    printf( "the seconds are %d\n", timeStruct.tm_sec );
}

Here is the current/corrected code output:

Date before adding interval: 


Mon May  2 23:59:59 2016

the year is 116
the month is 4
the day is 2
the hours are 23
the minutes are 59
the seconds are 59
Date after adding first interval: 


Mon May  2 23:59:59 2016

the year is 116
the month is 4
the day is 2
the hours are 23
the minutes are 59
the seconds are 59
Date after adding second interval: 


Tue May  3 05:02:01 2016

the year is 116
the month is 4
the day is 3
the hours are 5
the minutes are 2
the seconds are 1