#include "datetime.h"
#include <ctype.h>
+#define PHP_TIME_FREE(m) \
+ if (m) { \
+ free(m); \
+ m = NULL; \
+ } \
+
timelib_time* timelib_time_ctor()
{
timelib_time *t;
void timelib_time_tz_abbr_update(timelib_time* tm, char* tz_abbr)
{
int i;
-
- if (tm->tz_abbr) {
- free(tm->tz_abbr);
- }
+
+ PHP_TIME_FREE(tm->tz_abbr);
tm->tz_abbr = strdup(tz_abbr);
for (i = 0; i < strlen(tz_abbr); i++) {
tm->tz_abbr[i] = toupper(tz_abbr[i]);
void timelib_time_dtor(timelib_time* t)
{
- if (t->tz_abbr) {
- free(t->tz_abbr);
+ PHP_TIME_FREE(t->tz_abbr);
+ if (t->tz_info) {
+ timelib_tzinfo_dtor(t->tz_info);
+ t->tz_info = NULL;
}
- free(t);
+ PHP_TIME_FREE(t);
}
timelib_time_offset* timelib_time_offset_ctor()
void timelib_time_offset_dtor(timelib_time_offset* t)
{
- if (t->abbr) {
- free(t->abbr);
- }
- free(t);
+ PHP_TIME_FREE(t->abbr);
+ PHP_TIME_FREE(t);
}
timelib_tzinfo* timelib_tzinfo_ctor(char *name)
void timelib_tzinfo_dtor(timelib_tzinfo *tz)
{
- free(tz->name);
- free(tz->trans);
- free(tz->trans_idx);
- free(tz->type);
- free(tz->timezone_abbr);
- free(tz->leap_times);
- free(tz);
+ PHP_TIME_FREE(tz->name);
+ PHP_TIME_FREE(tz->trans);
+ PHP_TIME_FREE(tz->trans_idx);
+ PHP_TIME_FREE(tz->type);
+ PHP_TIME_FREE(tz->timezone_abbr);
+ PHP_TIME_FREE(tz->leap_times);
+ PHP_TIME_FREE(tz);
}
char *timelib_get_tz_abbr_ptr(timelib_time *t)
now = timelib_time_ctor();
timelib_unixtime2local(now, (signed long long) time(NULL), tzi);
} else {
+ timelib_tzinfo_ctor(tzi);
RETURN_FALSE;
}
timelib_fill_holes(t, now, 0);
timelib_update_ts(t, tzi);
ts = timelib_date_to_int(t, &error);
+
+ /* if tz_info is not a copy, avoid double free */
+ if (now->tz_info == tzi) {
+ now->tz_info = NULL;
+ }
+
+ timelib_time_dtor(now);
+ timelib_time_dtor(t);
+ timelib_tzinfo_dtor(tzi);
+
if (error) {
RETURN_FALSE;
} else {