IntlCalendar::getRepeatedWallTimeOption

繰り返される実時間を扱う際の振る舞いを取得する

説明

オブジェクト指向型

public int IntlCalendar::getRepeatedWallTimeOption()

手続き型

int intlcal_get_repeated_wall_time_option(IntlCalendar $calendar)

夏時間が終わり、 「時計が巻き戻される時に繰り返される実時間」をどう扱うかの戦略を取得します。 デフォルト値は IntlCalendar::WALLTIME_LAST です。

この関数を使うには、ICU 4.9 以降が必要です。

パラメータ

calendar

IntlCalendar クラスのインスタンス。

戻り値

IntlCalendar::WALLTIME_FIRST または IntlCalendar::WALLTIME_LAST のどちらかを返します。

例1 IntlCalendar::getRepeatedWallTimeOption

<?php
ini_set('date.timezone', 'Europe/Lisbon');
ini_set('intl.default_locale', 'en_US');
ini_set('intl.error_level', E_WARNING);

//On October 27th at 0200, the clock goes back 1 hour and from GMT+01 to GMT+00
$cal = new IntlGregorianCalendar(2013, 9 /* October */, 27, 1, 30);

var_dump($cal->getRepeatedWalltimeOption()); // 0 WALLTIME_LAST

$formatter = IntlDateFormatter::create(
    NULL,
    IntlDateFormatter::FULL,
    IntlDateFormatter::FULL,
    'UTC'
);
var_dump($formatter->format($cal->getTime() / 1000.));

$cal->setRepeatedWalltimeOption(IntlCalendar::WALLTIME_FIRST);
var_dump($cal->getRepeatedWalltimeOption()); // 1 WALLTIME_FIRST
$cal->set(IntlCalendar::FIELD_HOUR_OF_DAY, 1);

var_dump($formatter->format($cal->getTime() / 1000.));

上の例の出力は以下となります。

int(0)
string(42) "Sunday, October 27, 2013 at 1:30:00 AM GMT"
int(1)
string(43) "Sunday, October 27, 2013 at 12:30:00 AM GMT"

参考

  • IntlCalendar::getSkippedWallTimeOption
  • IntlCalendar::setSkippedWallTimeOption
  • IntlCalendar::setRepeatedWallTimeOption