Change jerry_port interface to allow for a correct implementation of timezones. (#2540)
The previous jerry_port interface did not allow timezones to be handled correctly, even if the host system was up to the task. This PR changes the jerry_port interface to allow a completely correct implementation to exist, and provides one (for Linux/BSD systems) in default-date.c. Fixes #1661 JerryScript-DCO-1.0-Signed-off-by: crazy2be crazy1be@gmail.com
This commit is contained in:
+36
-31
@@ -76,27 +76,37 @@ void jerry_port_log (jerry_log_level_t level, const char *fmt, ...);
|
|||||||
|
|
||||||
```c
|
```c
|
||||||
/**
|
/**
|
||||||
* Jerry time zone structure
|
* Get local time zone adjustment, in milliseconds, for the given timestamp.
|
||||||
*/
|
* The timestamp can be specified in either UTC or local time, depending on
|
||||||
typedef struct
|
* the value of is_utc. Adding the value returned from this function to
|
||||||
{
|
* a timestamp in UTC time should result in local time for the current time
|
||||||
int offset; /**< minutes from west */
|
* zone, and subtracting it from a timestamp in local time should result in
|
||||||
int daylight_saving_time; /**< daylight saving time (1 - DST applies, 0 - not on DST) */
|
* UTC time.
|
||||||
} jerry_time_zone_t;
|
*
|
||||||
|
* Ideally, this function should satisfy the stipulations applied to LocalTZA
|
||||||
/**
|
* in section 20.3.1.7 of the ECMAScript version 9.0 spec.
|
||||||
* Get timezone and daylight saving data
|
*
|
||||||
|
* See Also:
|
||||||
|
* ECMA-262 v9, 20.3.1.7
|
||||||
*
|
*
|
||||||
* Note:
|
* Note:
|
||||||
* This port function is called by jerry-core when
|
* This port function is called by jerry-core when
|
||||||
* CONFIG_DISABLE_DATE_BUILTIN is _not_ defined. Otherwise this function is
|
* CONFIG_DISABLE_DATE_BUILTIN is _not_ defined. Otherwise this function is
|
||||||
* not used.
|
* not used.
|
||||||
*
|
*
|
||||||
* @param[out] tz_p time zone structure to fill.
|
* @param unix_ms The unix timestamp we want an offset for, given in
|
||||||
* @return true - if success
|
* millisecond precision (could be now, in the future,
|
||||||
* false - otherwise
|
* or in the past). As with all unix timestamps, 0 refers to
|
||||||
|
* 1970-01-01, a day is exactly 86 400 000 milliseconds, and
|
||||||
|
* leap seconds cause the same second to occur twice.
|
||||||
|
* @param is_utc Is the given timestamp in UTC time? If false, it is in local
|
||||||
|
* time.
|
||||||
|
*
|
||||||
|
* @return milliseconds between local time and UTC for the given timestamp,
|
||||||
|
* if available
|
||||||
|
*. 0 if not available / we are in UTC.
|
||||||
*/
|
*/
|
||||||
bool jerry_port_get_time_zone (jerry_time_zone_t *tz_p);
|
double jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get system time
|
* Get system time
|
||||||
@@ -194,31 +204,26 @@ jerry_port_log (jerry_log_level_t level, /**< log level */
|
|||||||
## Date
|
## Date
|
||||||
|
|
||||||
```c
|
```c
|
||||||
|
#include <time.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include "jerryscript-port.h"
|
#include "jerryscript-port.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default implementation of jerry_port_get_time_zone.
|
* Default implementation of jerry_port_get_local_time_zone_adjustment.
|
||||||
*/
|
*/
|
||||||
bool jerry_port_get_time_zone (jerry_time_zone_t *tz_p)
|
double jerry_port_get_local_time_zone_adjustment (double unix_ms, /**< ms since unix epoch */
|
||||||
|
bool is_utc) /**< is the time above in UTC? */
|
||||||
{
|
{
|
||||||
struct timeval tv;
|
struct tm tm;
|
||||||
struct timezone tz;
|
time_t now = (time_t) (unix_ms / 1000);
|
||||||
|
localtime_r (&now, &tm);
|
||||||
/* gettimeofday may not fill tz, so zero-initializing */
|
if (!is_utc)
|
||||||
tz.tz_minuteswest = 0;
|
|
||||||
tz.tz_dsttime = 0;
|
|
||||||
|
|
||||||
if (gettimeofday (&tv, &tz) != 0)
|
|
||||||
{
|
{
|
||||||
return false;
|
now -= tm.tm_gmtoff;
|
||||||
|
localtime_r (&now, &tm);
|
||||||
}
|
}
|
||||||
|
return ((double) tm.tm_gmtoff) * 1000;
|
||||||
tz_p->offset = tz.tz_minuteswest;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
tz_p->daylight_saving_time = tz.tz_dsttime > 0 ? 1 : 0;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default implementation of jerry_port_get_current_time.
|
* Default implementation of jerry_port_get_current_time.
|
||||||
|
|||||||
@@ -600,7 +600,7 @@ ecma_builtin_date_prototype_dispatch_routine (uint16_t builtin_routine_id, /**<
|
|||||||
|
|
||||||
if (!BUILTIN_DATE_FUNCTION_IS_UTC (builtin_routine_id))
|
if (!BUILTIN_DATE_FUNCTION_IS_UTC (builtin_routine_id))
|
||||||
{
|
{
|
||||||
this_num += ecma_date_local_time_zone (this_num);
|
this_num += ecma_date_local_time_zone_adjustment (this_num);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (builtin_routine_id <= ECMA_DATE_PROTOTYPE_GET_UTC_TIMEZONE_OFFSET)
|
if (builtin_routine_id <= ECMA_DATE_PROTOTYPE_GET_UTC_TIMEZONE_OFFSET)
|
||||||
|
|||||||
@@ -302,83 +302,32 @@ ecma_date_week_day (ecma_number_t time) /**< time value */
|
|||||||
} /* ecma_date_week_day */
|
} /* ecma_date_week_day */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper function to get local time zone adjustment.
|
* Helper function to get the local time zone offset at a given UTC timestamp.
|
||||||
|
* You can add this number to the given UTC timestamp to get local time.
|
||||||
*
|
*
|
||||||
* See also:
|
* See also:
|
||||||
* ECMA-262 v5, 15.9.1.7
|
* ECMA-262 v5, 15.9.1.9
|
||||||
*
|
*
|
||||||
* @return local time zone adjustment
|
* @return local time zone adjustment
|
||||||
*/
|
*/
|
||||||
static inline ecma_number_t JERRY_ATTR_ALWAYS_INLINE
|
|
||||||
ecma_date_local_tza (jerry_time_zone_t *tz) /**< time zone information */
|
|
||||||
{
|
|
||||||
return tz->offset * -ECMA_DATE_MS_PER_MINUTE;
|
|
||||||
} /* ecma_date_local_tza */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Helper function to get the daylight saving time adjustment.
|
|
||||||
*
|
|
||||||
* See also:
|
|
||||||
* ECMA-262 v5, 15.9.1.8
|
|
||||||
*
|
|
||||||
* @return daylight saving time adjustment
|
|
||||||
*/
|
|
||||||
static inline ecma_number_t JERRY_ATTR_ALWAYS_INLINE
|
|
||||||
ecma_date_daylight_saving_ta (jerry_time_zone_t *tz, /**< time zone information */
|
|
||||||
ecma_number_t time) /**< time value */
|
|
||||||
{
|
|
||||||
JERRY_ASSERT (!ecma_number_is_nan (time));
|
|
||||||
|
|
||||||
/*
|
|
||||||
* TODO: Fix daylight saving calculation.
|
|
||||||
* https://github.com/jerryscript-project/jerryscript/issues/1661
|
|
||||||
*/
|
|
||||||
return tz->daylight_saving_time * ECMA_DATE_MS_PER_HOUR;
|
|
||||||
} /* ecma_date_daylight_saving_ta */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Helper function to get local time from UTC.
|
|
||||||
*
|
|
||||||
* See also:
|
|
||||||
* ECMA-262 v5, 15.9.1.9
|
|
||||||
*
|
|
||||||
* @return local time
|
|
||||||
*/
|
|
||||||
inline ecma_number_t JERRY_ATTR_ALWAYS_INLINE
|
inline ecma_number_t JERRY_ATTR_ALWAYS_INLINE
|
||||||
ecma_date_local_time_zone (ecma_number_t time) /**< time value */
|
ecma_date_local_time_zone_adjustment (ecma_number_t time) /**< time value */
|
||||||
{
|
{
|
||||||
jerry_time_zone_t tz;
|
return jerry_port_get_local_time_zone_adjustment (time, true);
|
||||||
|
} /* ecma_date_local_time_zone_adjustment */
|
||||||
if (ecma_number_is_nan (time)
|
|
||||||
|| !jerry_port_get_time_zone (&tz))
|
|
||||||
{
|
|
||||||
return ecma_number_make_nan ();
|
|
||||||
}
|
|
||||||
|
|
||||||
return ecma_date_local_tza (&tz) + ecma_date_daylight_saving_ta (&tz, time);
|
|
||||||
} /* ecma_date_local_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper function to get utc from local time.
|
* Helper function to get UTC time from local time.
|
||||||
*
|
*
|
||||||
* See also:
|
* See also:
|
||||||
* ECMA-262 v5, 15.9.1.9
|
* ECMA-262 v5, 15.9.1.9
|
||||||
*
|
*
|
||||||
* @return utc time
|
* @return UTC time
|
||||||
*/
|
*/
|
||||||
ecma_number_t
|
ecma_number_t
|
||||||
ecma_date_utc (ecma_number_t time) /**< time value */
|
ecma_date_utc (ecma_number_t time) /**< time value */
|
||||||
{
|
{
|
||||||
jerry_time_zone_t tz;
|
return time - jerry_port_get_local_time_zone_adjustment (time, false);
|
||||||
|
|
||||||
if (ecma_number_is_nan (time)
|
|
||||||
|| !jerry_port_get_time_zone (&tz))
|
|
||||||
{
|
|
||||||
return ecma_number_make_nan ();
|
|
||||||
}
|
|
||||||
|
|
||||||
ecma_number_t simple_utc_time = time - ecma_date_local_tza (&tz);
|
|
||||||
return simple_utc_time - ecma_date_daylight_saving_ta (&tz, simple_utc_time);
|
|
||||||
} /* ecma_date_utc */
|
} /* ecma_date_utc */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -615,7 +564,7 @@ ecma_date_timezone_offset (ecma_number_t time) /**< time value */
|
|||||||
{
|
{
|
||||||
JERRY_ASSERT (!ecma_number_is_nan (time));
|
JERRY_ASSERT (!ecma_number_is_nan (time));
|
||||||
|
|
||||||
return (-ecma_date_local_time_zone (time)) / ECMA_DATE_MS_PER_MINUTE;
|
return (-ecma_date_local_time_zone_adjustment (time)) / ECMA_DATE_MS_PER_MINUTE;
|
||||||
} /* ecma_date_timezone_offset */
|
} /* ecma_date_timezone_offset */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -724,7 +673,7 @@ ecma_date_to_string_format (ecma_number_t datetime_number, /**< datetime */
|
|||||||
}
|
}
|
||||||
case LIT_CHAR_LOWERCASE_Z: /* Time zone minutes part. */
|
case LIT_CHAR_LOWERCASE_Z: /* Time zone minutes part. */
|
||||||
{
|
{
|
||||||
int32_t time_zone = (int32_t) ecma_date_local_time_zone (datetime_number);
|
int32_t time_zone = (int32_t) ecma_date_local_time_zone_adjustment (datetime_number);
|
||||||
|
|
||||||
if (time_zone >= 0)
|
if (time_zone >= 0)
|
||||||
{
|
{
|
||||||
@@ -744,7 +693,7 @@ ecma_date_to_string_format (ecma_number_t datetime_number, /**< datetime */
|
|||||||
{
|
{
|
||||||
JERRY_ASSERT (*format_p == LIT_CHAR_UPPERCASE_Z); /* Time zone seconds part. */
|
JERRY_ASSERT (*format_p == LIT_CHAR_UPPERCASE_Z); /* Time zone seconds part. */
|
||||||
|
|
||||||
int32_t time_zone = (int32_t) ecma_date_local_time_zone (datetime_number);
|
int32_t time_zone = (int32_t) ecma_date_local_time_zone_adjustment (datetime_number);
|
||||||
|
|
||||||
if (time_zone < 0)
|
if (time_zone < 0)
|
||||||
{
|
{
|
||||||
@@ -805,7 +754,7 @@ ecma_date_to_string_format (ecma_number_t datetime_number, /**< datetime */
|
|||||||
ecma_value_t
|
ecma_value_t
|
||||||
ecma_date_value_to_string (ecma_number_t datetime_number) /**< datetime */
|
ecma_date_value_to_string (ecma_number_t datetime_number) /**< datetime */
|
||||||
{
|
{
|
||||||
datetime_number += ecma_date_local_time_zone (datetime_number);
|
datetime_number += ecma_date_local_time_zone_adjustment (datetime_number);
|
||||||
return ecma_date_to_string_format (datetime_number, "$W $M $D $Y $h:$m:$s GMT$z:$Z");
|
return ecma_date_to_string_format (datetime_number, "$W $M $D $Y $h:$m:$s GMT$z:$Z");
|
||||||
} /* ecma_date_value_to_string */
|
} /* ecma_date_value_to_string */
|
||||||
|
|
||||||
|
|||||||
@@ -100,7 +100,7 @@ ecma_number_t ecma_date_year_from_time (ecma_number_t time);
|
|||||||
ecma_number_t ecma_date_month_from_time (ecma_number_t time);
|
ecma_number_t ecma_date_month_from_time (ecma_number_t time);
|
||||||
ecma_number_t ecma_date_date_from_time (ecma_number_t time);
|
ecma_number_t ecma_date_date_from_time (ecma_number_t time);
|
||||||
ecma_number_t ecma_date_week_day (ecma_number_t time);
|
ecma_number_t ecma_date_week_day (ecma_number_t time);
|
||||||
ecma_number_t ecma_date_local_time_zone (ecma_number_t time);
|
ecma_number_t ecma_date_local_time_zone_adjustment (ecma_number_t time);
|
||||||
ecma_number_t ecma_date_utc (ecma_number_t time);
|
ecma_number_t ecma_date_utc (ecma_number_t time);
|
||||||
ecma_number_t ecma_date_hour_from_time (ecma_number_t time);
|
ecma_number_t ecma_date_hour_from_time (ecma_number_t time);
|
||||||
ecma_number_t ecma_date_min_from_time (ecma_number_t time);
|
ecma_number_t ecma_date_min_from_time (ecma_number_t time);
|
||||||
|
|||||||
@@ -111,27 +111,37 @@ void JERRY_ATTR_FORMAT (printf, 2, 3) jerry_port_log (jerry_log_level_t level, c
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Jerry time zone structure
|
* Get local time zone adjustment, in milliseconds, for the given timestamp.
|
||||||
*/
|
* The timestamp can be specified in either UTC or local time, depending on
|
||||||
typedef struct
|
* the value of is_utc. Adding the value returned from this function to
|
||||||
{
|
* a timestamp in UTC time should result in local time for the current time
|
||||||
int offset; /**< minutes from west */
|
* zone, and subtracting it from a timestamp in local time should result in
|
||||||
int daylight_saving_time; /**< daylight saving time (1 - DST applies, 0 - not on DST) */
|
* UTC time.
|
||||||
} jerry_time_zone_t;
|
*
|
||||||
|
* Ideally, this function should satisfy the stipulations applied to LocalTZA
|
||||||
/**
|
* in section 20.3.1.7 of the ECMAScript version 9.0 spec.
|
||||||
* Get timezone and daylight saving data
|
*
|
||||||
|
* See Also:
|
||||||
|
* ECMA-262 v9, 20.3.1.7
|
||||||
*
|
*
|
||||||
* Note:
|
* Note:
|
||||||
* This port function is called by jerry-core when
|
* This port function is called by jerry-core when
|
||||||
* CONFIG_DISABLE_DATE_BUILTIN is _not_ defined. Otherwise this function is
|
* CONFIG_DISABLE_DATE_BUILTIN is _not_ defined. Otherwise this function is
|
||||||
* not used.
|
* not used.
|
||||||
*
|
*
|
||||||
* @param[out] tz_p time zone structure to fill.
|
* @param unix_ms The unix timestamp we want an offset for, given in
|
||||||
* @return true - if success
|
* millisecond precision (could be now, in the future,
|
||||||
* false - otherwise
|
* or in the past). As with all unix timestamps, 0 refers to
|
||||||
|
* 1970-01-01, a day is exactly 86 400 000 milliseconds, and
|
||||||
|
* leap seconds cause the same second to occur twice.
|
||||||
|
* @param is_utc Is the given timestamp in UTC time? If false, it is in local
|
||||||
|
* time.
|
||||||
|
*
|
||||||
|
* @return milliseconds between local time and UTC for the given timestamp,
|
||||||
|
* if available
|
||||||
|
*. 0 if not available / we are in UTC.
|
||||||
*/
|
*/
|
||||||
bool jerry_port_get_time_zone (jerry_time_zone_t *tz_p);
|
double jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get system time
|
* Get system time
|
||||||
|
|||||||
@@ -26,6 +26,19 @@ file(GLOB SOURCE_PORT_DEFAULT *.c)
|
|||||||
# (should only be necessary if we used compiler default libc but not checking that)
|
# (should only be necessary if we used compiler default libc but not checking that)
|
||||||
set(DEFINES_PORT_DEFAULT _BSD_SOURCE _DEFAULT_SOURCE)
|
set(DEFINES_PORT_DEFAULT _BSD_SOURCE _DEFAULT_SOURCE)
|
||||||
|
|
||||||
|
INCLUDE (CheckStructHasMember)
|
||||||
|
# CHECK_STRUCT_HAS_MEMBER works by trying to compile some C code that accesses the
|
||||||
|
# given field of the given struct. However, our default compiler options break this
|
||||||
|
# C code, so turn a couple of them off for this.
|
||||||
|
set(CMAKE_REQUIRED_FLAGS "-Wno-error=strict-prototypes -Wno-error=old-style-definition")
|
||||||
|
# tm.tm_gmtoff is non-standard, so glibc doesn't expose it in c99 mode
|
||||||
|
# (our default). Define some macros to expose it anyway.
|
||||||
|
set(CMAKE_REQUIRED_DEFINITIONS "-D_BSD_SOURCE -D_DEFAULT_SOURCE")
|
||||||
|
CHECK_STRUCT_HAS_MEMBER ("struct tm" tm_gmtoff time.h HAVE_TM_GMTOFF)
|
||||||
|
if(HAVE_TM_GMTOFF)
|
||||||
|
set(DEFINES_PORT_DEFAULT ${DEFINES_PORT_DEFAULT} HAVE_TM_GMTOFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
# Sleep function availability check
|
# Sleep function availability check
|
||||||
INCLUDE (CheckIncludeFiles)
|
INCLUDE (CheckIncludeFiles)
|
||||||
CHECK_INCLUDE_FILES (time.h HAVE_TIME_H)
|
CHECK_INCLUDE_FILES (time.h HAVE_TIME_H)
|
||||||
|
|||||||
@@ -13,41 +13,43 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_TM_GMTOFF
|
||||||
|
#include <time.h>
|
||||||
|
#endif /* HAVE_TM_GMTOFF */
|
||||||
#ifdef __GNUC__
|
#ifdef __GNUC__
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#endif
|
#endif /* __GNUC__ */
|
||||||
|
|
||||||
#include "jerryscript-port.h"
|
#include "jerryscript-port.h"
|
||||||
#include "jerryscript-port-default.h"
|
#include "jerryscript-port-default.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default implementation of jerry_port_get_time_zone. Uses 'gettimeofday' if
|
* Default implementation of jerry_port_get_local_time_zone_adjustment. Uses the 'tm_gmtoff' field
|
||||||
* available on the system, does nothing otherwise.
|
* of 'struct tm' (a GNU extension) filled by 'localtime_r' if available on the
|
||||||
|
* system, does nothing otherwise.
|
||||||
*
|
*
|
||||||
* @return true - if 'gettimeofday' is available and executed successfully,
|
* @return offset between UTC and local time at the given unix timestamp, if
|
||||||
* false - otherwise.
|
* available. Otherwise, returns 0, assuming UTC time.
|
||||||
*/
|
*/
|
||||||
bool jerry_port_get_time_zone (jerry_time_zone_t *tz_p) /**< [out] time zone structure to fill */
|
double jerry_port_get_local_time_zone_adjustment (double unix_ms, /**< ms since unix epoch */
|
||||||
|
bool is_utc) /**< is the time above in UTC? */
|
||||||
{
|
{
|
||||||
#ifdef __GNUC__
|
#ifdef HAVE_TM_GMTOFF
|
||||||
struct timeval tv;
|
struct tm tm;
|
||||||
struct timezone tz;
|
time_t now = (time_t) (unix_ms / 1000);
|
||||||
|
localtime_r (&now, &tm);
|
||||||
/* gettimeofday may not fill tz, so zero-initializing */
|
if (!is_utc)
|
||||||
tz.tz_minuteswest = 0;
|
|
||||||
tz.tz_dsttime = 0;
|
|
||||||
|
|
||||||
if (gettimeofday (&tv, &tz) == 0)
|
|
||||||
{
|
{
|
||||||
tz_p->offset = tz.tz_minuteswest;
|
now -= tm.tm_gmtoff;
|
||||||
tz_p->daylight_saving_time = tz.tz_dsttime > 0 ? 1 : 0;
|
localtime_r (&now, &tm);
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
#endif /* __GNUC__ */
|
return ((double) tm.tm_gmtoff) * 1000;
|
||||||
|
#else /* !HAVE_TM_GMTOFF */
|
||||||
return false;
|
(void) unix_ms;
|
||||||
} /* jerry_port_get_time_zone */
|
(void) is_utc;
|
||||||
|
return 0.0;
|
||||||
|
#endif /* HAVE_TM_GMTOFF */
|
||||||
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default implementation of jerry_port_get_current_time. Uses 'gettimeofday' if
|
* Default implementation of jerry_port_get_current_time. Uses 'gettimeofday' if
|
||||||
|
|||||||
@@ -52,16 +52,13 @@ void jerry_port_fatal (jerry_fatal_code_t code)
|
|||||||
} /* jerry_port_fatal */
|
} /* jerry_port_fatal */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Curie BSP implementation of jerry_port_get_time_zone.
|
* Curie BSP implementation of jerry_port_get_local_time_zone_adjustment.
|
||||||
*/
|
*/
|
||||||
bool jerry_port_get_time_zone (jerry_time_zone_t *tz_p)
|
double jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||||
{
|
{
|
||||||
//EMPTY implementation
|
//EMPTY implementation
|
||||||
tz_p->offset = 0;
|
return 0;
|
||||||
tz_p->daylight_saving_time = 0;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
|
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Curie BSP implementation of jerry_port_get_current_time.
|
* Curie BSP implementation of jerry_port_get_current_time.
|
||||||
|
|||||||
@@ -61,16 +61,13 @@ jerry_port_get_current_time (void)
|
|||||||
} /* jerry_port_get_current_time */
|
} /* jerry_port_get_current_time */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dummy function to get the time zone.
|
* Dummy function to get the time zone adjustment.
|
||||||
*
|
*
|
||||||
* @return true
|
* @return 0
|
||||||
*/
|
*/
|
||||||
bool
|
double
|
||||||
jerry_port_get_time_zone (jerry_time_zone_t *tz_p)
|
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||||
{
|
{
|
||||||
/* We live in UTC. */
|
/* We live in UTC. */
|
||||||
tz_p->offset = 0;
|
return 0;
|
||||||
tz_p->daylight_saving_time = 0;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
|
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|||||||
@@ -46,17 +46,15 @@ jerry_port_log (jerry_log_level_t level, /**< log level */
|
|||||||
#endif /* JSMBED_OVERRIDE_JERRY_PORT_LOG */
|
#endif /* JSMBED_OVERRIDE_JERRY_PORT_LOG */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of jerry_port_get_time_zone.
|
* Implementation of jerry_port_get_local_time_zone_adjustment.
|
||||||
*
|
*
|
||||||
* @return true - if success
|
* @return 0, as we live in UTC.
|
||||||
*/
|
*/
|
||||||
bool
|
double
|
||||||
jerry_port_get_time_zone (jerry_time_zone_t *tz_p) /**< timezone pointer */
|
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||||
{
|
{
|
||||||
tz_p->offset = 0;
|
return 0;
|
||||||
tz_p->daylight_saving_time = 0;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of jerry_port_get_current_time.
|
* Implementation of jerry_port_get_current_time.
|
||||||
|
|||||||
@@ -492,19 +492,16 @@ jerry_port_log (jerry_log_level_t level, /**< log level */
|
|||||||
} /* jerry_port_log */
|
} /* jerry_port_log */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dummy function to get the time zone.
|
* Dummy function to get the time zone adjustment.
|
||||||
*
|
*
|
||||||
* @return true
|
* @return 0
|
||||||
*/
|
*/
|
||||||
bool
|
double
|
||||||
jerry_port_get_time_zone (jerry_time_zone_t *tz_p)
|
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||||
{
|
{
|
||||||
/* We live in UTC. */
|
/* We live in UTC. */
|
||||||
tz_p->offset = 0;
|
return 0;
|
||||||
tz_p->daylight_saving_time = 0;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
|
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dummy function to get the current time.
|
* Dummy function to get the current time.
|
||||||
|
|||||||
@@ -474,19 +474,16 @@ jerry_port_log (jerry_log_level_t level, /**< log level */
|
|||||||
} /* jerry_port_log */
|
} /* jerry_port_log */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dummy function to get the time zone.
|
* Dummy function to get the time zone adjustment.
|
||||||
*
|
*
|
||||||
* @return true
|
* @return 0
|
||||||
*/
|
*/
|
||||||
bool
|
double
|
||||||
jerry_port_get_time_zone (jerry_time_zone_t *tz_p)
|
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||||
{
|
{
|
||||||
/* We live in UTC. */
|
/* We live in UTC. */
|
||||||
tz_p->offset = 0;
|
return 0;
|
||||||
tz_p->daylight_saving_time = 0;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
|
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dummy function to get the current time.
|
* Dummy function to get the current time.
|
||||||
|
|||||||
@@ -59,19 +59,16 @@ jerry_port_get_current_time (void)
|
|||||||
} /* jerry_port_get_current_time */
|
} /* jerry_port_get_current_time */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dummy function to get the time zone.
|
* Dummy function to get the time zone adjustment.
|
||||||
*
|
*
|
||||||
* @return true
|
* @return 0
|
||||||
*/
|
*/
|
||||||
bool
|
double
|
||||||
jerry_port_get_time_zone (jerry_time_zone_t *tz_p)
|
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||||
{
|
{
|
||||||
/* We live in UTC. */
|
/* We live in UTC. */
|
||||||
tz_p->offset = 0;
|
return 0;
|
||||||
tz_p->daylight_saving_time = 0;
|
} /* jerry_port_get_local_time_zone_adjustment */
|
||||||
|
|
||||||
return true;
|
|
||||||
} /* jerry_port_get_time_zone */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provide the implementation of jerryx_port_handler_print_char.
|
* Provide the implementation of jerryx_port_handler_print_char.
|
||||||
|
|||||||
@@ -24,8 +24,7 @@ assert (d.getUTCDate() == 9);
|
|||||||
assert (d.getDay() == 4);
|
assert (d.getDay() == 4);
|
||||||
assert (d.getUTCDay() == 4);
|
assert (d.getUTCDay() == 4);
|
||||||
assert (d.getHours() == 12);
|
assert (d.getHours() == 12);
|
||||||
// FIXME: Missing timezone adjustment.
|
assert (d.getUTCHours() == (12 + d.getTimezoneOffset() / 60));
|
||||||
//assert (d.getUTCHours() == (12 + d.getTimezoneOffset() / 60));
|
|
||||||
assert (d.getMinutes() == 13);
|
assert (d.getMinutes() == 13);
|
||||||
assert (d.getUTCMinutes() == 13);
|
assert (d.getUTCMinutes() == 13);
|
||||||
assert (d.getSeconds() == 14);
|
assert (d.getSeconds() == 14);
|
||||||
@@ -44,9 +43,8 @@ assert (d.getDate() == 9);
|
|||||||
assert (d.getUTCDate() == 9);
|
assert (d.getUTCDate() == 9);
|
||||||
assert (d.getDay() == 4);
|
assert (d.getDay() == 4);
|
||||||
assert (d.getUTCDay() == 4);
|
assert (d.getUTCDay() == 4);
|
||||||
// FIXME: Missing timezone adjustment.
|
assert (d.getHours() == Math.floor(12 - 1.5 + d.getTimezoneOffset() / 60));
|
||||||
//assert (d.getHours() == 12);
|
assert (d.getUTCHours() == Math.floor(12 - 1.5));
|
||||||
//assert (d.getUTCHours() == (12 + d.getTimezoneOffset() / 60));
|
|
||||||
assert (d.getMinutes() == 43);
|
assert (d.getMinutes() == 43);
|
||||||
assert (d.getUTCMinutes() == 43);
|
assert (d.getUTCMinutes() == 43);
|
||||||
assert (d.getSeconds() == 14);
|
assert (d.getSeconds() == 14);
|
||||||
@@ -65,8 +63,7 @@ assert (d.getDate() == 1);
|
|||||||
assert (d.getUTCDate() == 1);
|
assert (d.getUTCDate() == 1);
|
||||||
assert (d.getDay() == 4);
|
assert (d.getDay() == 4);
|
||||||
assert (d.getUTCDay() == 4);
|
assert (d.getUTCDay() == 4);
|
||||||
// FIXME: Missing timezone adjustment.
|
assert (d.getHours() == 0 - (d.getTimezoneOffset() / 60));
|
||||||
// assert (d.getHours() == 0 - (d.getTimezoneOffset() / 60));
|
|
||||||
assert (d.getUTCHours() == 0);
|
assert (d.getUTCHours() == 0);
|
||||||
assert (d.getMinutes() == 0);
|
assert (d.getMinutes() == 0);
|
||||||
assert (d.getUTCMinutes() == 0);
|
assert (d.getUTCMinutes() == 0);
|
||||||
|
|||||||
+18
-19
@@ -82,25 +82,24 @@ assert (d.getUTCSeconds() == 1);
|
|||||||
assert (d.getUTCMilliseconds() == 1);
|
assert (d.getUTCMilliseconds() == 1);
|
||||||
|
|
||||||
/* 15.9.5.34 Date.prototype.setHours (hour [, min [, sec [, ms ] ] ] ) */
|
/* 15.9.5.34 Date.prototype.setHours (hour [, min [, sec [, ms ] ] ] ) */
|
||||||
// FIXME: Missing timezone adjustment.
|
d.setTime(0);
|
||||||
//d.setTime(0);
|
assert (d.setHours(1) == hour + d.getTimezoneOffset() * 60000);
|
||||||
//assert (d.setHours(1) == hour + d.getTimezoneOffset() * 60000);
|
assert (d.getHours() == 1);
|
||||||
//assert (d.getHours() == 1);
|
d.setTime(0);
|
||||||
//d.setTime(0);
|
assert (d.setHours(1, 1) == hour + min + d.getTimezoneOffset() * 60000);
|
||||||
//assert (d.setHours(1, 1) == hour + min + d.getTimezoneOffset() * 60000);
|
assert (d.getHours() == 1);
|
||||||
//assert (d.getHours() == 1);
|
assert (d.getMinutes() == 1);
|
||||||
//assert (d.getMinutes() == 1);
|
d.setTime(0);
|
||||||
//d.setTime(0);
|
assert (d.setHours(1, 1, 1) == hour + min + sec + d.getTimezoneOffset() * 60000);
|
||||||
//assert (d.setHours(1, 1, 1) == hour + min + sec + d.getTimezoneOffset() * 60000);
|
assert (d.getHours() == 1);
|
||||||
//assert (d.getHours() == 1);
|
assert (d.getMinutes() == 1);
|
||||||
//assert (d.getMinutes() == 1);
|
assert (d.getSeconds() == 1);
|
||||||
//assert (d.getSeconds() == 1);
|
d.setTime(0);
|
||||||
//d.setTime(0);
|
assert (d.setHours(1, 1, 1, 1) == hour + min + sec + ms + d.getTimezoneOffset() * 60000);
|
||||||
//assert (d.setHours(1, 1, 1, 1) == hour + min + sec + ms + d.getTimezoneOffset() * 60000);
|
assert (d.getHours() == 1);
|
||||||
//assert (d.getHours() == 1);
|
assert (d.getMinutes() == 1);
|
||||||
//assert (d.getMinutes() == 1);
|
assert (d.getSeconds() == 1);
|
||||||
//assert (d.getSeconds() == 1);
|
assert (d.getMilliseconds() == 1);
|
||||||
//assert (d.getMilliseconds() == 1);
|
|
||||||
|
|
||||||
/* 15.9.5.35 Date.prototype.setUTCHours (hour [, min [, sec [, ms ] ] ] ) */
|
/* 15.9.5.35 Date.prototype.setUTCHours (hour [, min [, sec [, ms ] ] ] ) */
|
||||||
d.setTime(0);
|
d.setTime(0);
|
||||||
|
|||||||
@@ -52,15 +52,8 @@ fi
|
|||||||
rm -rf "${PATH_TO_TEST262}/test/suite/bestPractice"
|
rm -rf "${PATH_TO_TEST262}/test/suite/bestPractice"
|
||||||
rm -rf "${PATH_TO_TEST262}/test/suite/intl402"
|
rm -rf "${PATH_TO_TEST262}/test/suite/intl402"
|
||||||
|
|
||||||
# TODO: Enable these tests after daylight saving calculation is fixed.
|
echo "Starting test262 testing for ${ENGINE}. Running test262 may take several minutes."
|
||||||
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T1.js"
|
|
||||||
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T2.js"
|
|
||||||
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T3.js"
|
|
||||||
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T4.js"
|
|
||||||
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T5.js"
|
|
||||||
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T6.js"
|
|
||||||
|
|
||||||
echo "Starting test262 testing for ${ENGINE}. Running test262 may take a several minutes."
|
|
||||||
|
|
||||||
function progress_monitor() {
|
function progress_monitor() {
|
||||||
NUM_LINES_GOTTEN=0
|
NUM_LINES_GOTTEN=0
|
||||||
@@ -85,7 +78,7 @@ python2 "${PATH_TO_TEST262}"/tools/packaging/test262.py --command "${COMMAND}" \
|
|||||||
TEST262_EXIT_CODE=$?
|
TEST262_EXIT_CODE=$?
|
||||||
if [ $TEST262_EXIT_CODE -ne 0 ]
|
if [ $TEST262_EXIT_CODE -ne 0 ]
|
||||||
then
|
then
|
||||||
echo -e "\nFailed to run test2626\n"
|
echo -e "\nFailed to run test262\n"
|
||||||
echo "$0: see ${REPORT_PATH} for details about failures"
|
echo "$0: see ${REPORT_PATH} for details about failures"
|
||||||
exit $TEST262_EXIT_CODE
|
exit $TEST262_EXIT_CODE
|
||||||
fi
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user