@@ -4276,13 +4276,13 @@ PHP_FUNCTION(timezone_transitions_get)
4276
4276
RETURN_FALSE ;
4277
4277
}
4278
4278
4279
- #define add_nominal ( ) \
4279
+ #define add_by_index ( i , ts ) \
4280
4280
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]); \
4286
4286
add_next_index_zval(return_value, &element);
4287
4287
4288
4288
#define add (i ,ts ) \
@@ -4294,14 +4294,13 @@ PHP_FUNCTION(timezone_transitions_get)
4294
4294
add_assoc_string(&element, "abbr", &tzobj->tzi.tz->timezone_abbr[tzobj->tzi.tz->type[tzobj->tzi.tz->trans_idx[i]].abbr_idx]); \
4295
4295
add_next_index_zval(return_value, &element);
4296
4296
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 ); \
4299
4299
add_assoc_long(&element, "ts", ts); \
4300
4300
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]);
4305
4304
4306
4305
#define add_from_tto (to ,ts ) \
4307
4306
array_init_size(&element, 5); \
@@ -4312,6 +4311,7 @@ PHP_FUNCTION(timezone_transitions_get)
4312
4311
add_assoc_string(&element, "abbr", (to)->abbr); \
4313
4312
add_next_index_zval(return_value, &element);
4314
4313
4314
+ #define add_nominal () add_by_index(0, timestamp_begin)
4315
4315
#define add_last () add(tzobj->tzi.tz->bit64.timecnt - 1, timestamp_begin)
4316
4316
4317
4317
array_init (return_value );
@@ -4364,10 +4364,11 @@ PHP_FUNCTION(timezone_transitions_get)
4364
4364
4365
4365
if (tzobj -> tzi .tz -> trans [i ] > timestamp_begin ) {
4366
4366
add (i , tzobj -> tzi .tz -> trans [i ]);
4367
+ last_transition_ts = tzobj -> tzi .tz -> trans [i ];
4368
+ } else {
4369
+ upd_prev (i , timestamp_begin );
4367
4370
}
4368
4371
}
4369
-
4370
- last_transition_ts = tzobj -> tzi .tz -> trans [tzobj -> tzi .tz -> bit64 .timecnt - 1 ];
4371
4372
}
4372
4373
4373
4374
if (tzobj -> tzi .tz -> posix_info && tzobj -> tzi .tz -> posix_info -> dst_end ) {
0 commit comments