@@ -4276,13 +4276,13 @@ PHP_FUNCTION(timezone_transitions_get)
42764276 RETURN_FALSE ;
42774277 }
42784278
4279- #define add_nominal ( ) \
4279+ #define add_by_index ( i , ts ) \
42804280 array_init_size(&element, 5); \
4281- add_assoc_long(&element, "ts", timestamp_begin ); \
4282- add_assoc_str(&element, "time", php_format_date(DATE_FORMAT_ISO8601_LARGE_YEAR, 13, timestamp_begin , 0)); \
4283- add_assoc_long(&element, "offset", tzobj->tzi.tz->type[0 ].offset); \
4284- add_assoc_bool(&element, "isdst", tzobj->tzi.tz->type[0 ].isdst); \
4285- add_assoc_string(&element, "abbr", &tzobj->tzi.tz->timezone_abbr[tzobj->tzi.tz->type[0 ].abbr_idx]); \
4281+ add_assoc_long(&element, "ts", ts ); \
4282+ add_assoc_str(&element, "time", php_format_date(DATE_FORMAT_ISO8601_LARGE_YEAR, 13, ts , 0)); \
4283+ add_assoc_long(&element, "offset", tzobj->tzi.tz->type[i ].offset); \
4284+ add_assoc_bool(&element, "isdst", tzobj->tzi.tz->type[i ].isdst); \
4285+ add_assoc_string(&element, "abbr", &tzobj->tzi.tz->timezone_abbr[tzobj->tzi.tz->type[i ].abbr_idx]); \
42864286 add_next_index_zval(return_value, &element);
42874287
42884288#define add (i ,ts ) \
@@ -4294,14 +4294,13 @@ PHP_FUNCTION(timezone_transitions_get)
42944294 add_assoc_string(&element, "abbr", &tzobj->tzi.tz->timezone_abbr[tzobj->tzi.tz->type[tzobj->tzi.tz->trans_idx[i]].abbr_idx]); \
42954295 add_next_index_zval(return_value, &element);
42964296
4297- #define add_by_index (i ,ts ) \
4298- array_init_size(& element, 5 ); \
4297+ #define upd_prev (i ,ts ) \
4298+ element = *ZEND_HASH_ELEMENT(Z_ARRVAL_P(return_value), Z_ARRVAL_P(return_value)->nNumUsed-1 ); \
42994299 add_assoc_long(&element, "ts", ts); \
43004300 add_assoc_str(&element, "time", php_format_date(DATE_FORMAT_ISO8601_LARGE_YEAR, 13, ts, 0)); \
4301- add_assoc_long(&element, "offset", tzobj->tzi.tz->type[i].offset); \
4302- add_assoc_bool(&element, "isdst", tzobj->tzi.tz->type[i].isdst); \
4303- add_assoc_string(&element, "abbr", &tzobj->tzi.tz->timezone_abbr[tzobj->tzi.tz->type[i].abbr_idx]); \
4304- add_next_index_zval(return_value, &element);
4301+ add_assoc_long(&element, "offset", tzobj->tzi.tz->type[tzobj->tzi.tz->trans_idx[i]].offset); \
4302+ add_assoc_bool(&element, "isdst", tzobj->tzi.tz->type[tzobj->tzi.tz->trans_idx[i]].isdst); \
4303+ add_assoc_string(&element, "abbr", &tzobj->tzi.tz->timezone_abbr[tzobj->tzi.tz->type[tzobj->tzi.tz->trans_idx[i]].abbr_idx]);
43054304
43064305#define add_from_tto (to ,ts ) \
43074306 array_init_size(&element, 5); \
@@ -4312,6 +4311,7 @@ PHP_FUNCTION(timezone_transitions_get)
43124311 add_assoc_string(&element, "abbr", (to)->abbr); \
43134312 add_next_index_zval(return_value, &element);
43144313
4314+ #define add_nominal () add_by_index(0, timestamp_begin)
43154315#define add_last () add(tzobj->tzi.tz->bit64.timecnt - 1, timestamp_begin)
43164316
43174317 array_init (return_value );
@@ -4364,10 +4364,11 @@ PHP_FUNCTION(timezone_transitions_get)
43644364
43654365 if (tzobj -> tzi .tz -> trans [i ] > timestamp_begin ) {
43664366 add (i , tzobj -> tzi .tz -> trans [i ]);
4367+ last_transition_ts = tzobj -> tzi .tz -> trans [i ];
4368+ } else {
4369+ upd_prev (i , timestamp_begin );
43674370 }
43684371 }
4369-
4370- last_transition_ts = tzobj -> tzi .tz -> trans [tzobj -> tzi .tz -> bit64 .timecnt - 1 ];
43714372 }
43724373
43734374 if (tzobj -> tzi .tz -> posix_info && tzobj -> tzi .tz -> posix_info -> dst_end ) {
0 commit comments