IntlCalendar::roll
(PHP 5 >= 5.5.0, PHP 7, PHP 8, PECL >= 3.0.0a1)
IntlCalendar::roll — Add value to field without carrying into more significant fields
Beschreibung
Objektorientierter Stil
$field
, int|bool $value
): boolProzeduraler Stil
Adds a (signed) amount to a field. The difference with respect to IntlCalendar::add() is that when the field value overflows, it does not carry into more significant fields.
Parameter-Liste
-
calendar
-
Eine IntlCalendar-Instanz.
-
field
-
One of the IntlCalendar date/time field constants. These are integer values between
0
andIntlCalendar::FIELD_COUNT
. -
value
-
The (signed) amount to add to the field,
true
for rolling up (adding1
), orfalse
for rolling down (subtracting1
).
Rückgabewerte
Returns true
on success or false
on failure.
Beispiele
Beispiel #1 IntlCalendar::roll()
<?php
ini_set('date.timezone', 'Europe/Lisbon');
ini_set('intl.default_locale', 'pt_PT');
$cal = new IntlGregorianCalendar(2013, 5 /* June */, 30);
$cal->add(IntlCalendar::FIELD_DAY_OF_MONTH, 1);
var_dump(IntlDateFormatter::formatObject($cal)); // "01/07/2013, 00:00:00"
$cal->set(2013, 5 /* June */, 30);
$cal->roll(IntlCalendar::FIELD_DAY_OF_MONTH, true); // roll up, same as rolling +1
var_dump(IntlDateFormatter::formatObject($cal)); // "01/06/2013, 00:00:00"
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
string(20) "01/07/2013, 00:00:00" string(20) "01/06/2013, 00:00:00"
Siehe auch
- IntlCalendar::add() - Add a (signed) amount of time to a field
- IntlCalendar::set() - Set a time field or several common fields at once