Groovy JDK

java.util
Class Calendar

Method Summary
Calendar clearTime()
Clears the time portion of this Calendar instance; useful utility where it makes sense to compare month/day/year only portions of a Calendar.
Calendar copyWith(Map updates)
Support creating a new Date having similar properties to an existing Date (which remains unaltered) but with some fields updated according to a Map of changes.
void downto(Calendar to, Closure closure)
Iterates from the date represented by this calendar up to the date represented by the given calendar, inclusive, incrementing by one day each time.
String format(String pattern)

Shortcut for SimpleDateFormat to output a String representation of this calendar instance.

int getAt(int field)
Support the subscript operator for a Calendar.
int minus(Calendar then)
Subtract another date from this one and return the number of days of the difference.
Calendar next()
Increment a Calendar by one day.
Calendar previous()
Decrement a Calendar by one day.
void putAt(int field, int value)
Support the subscript operator for mutating a Calendar.
void set(Map updates)
Support mutating a Calendar with a Map.
Calendar updated(Map updates)
Legacy alias for copyWith.
void upto(Calendar to, Closure closure)
Iterates from the date represented by this calendar up to the date represented by the given calendar, inclusive, incrementing by one day each time.
 
Method Detail

clearTime

public Calendar clearTime()
 
Clears the time portion of this Calendar instance; useful utility where it makes sense to compare month/day/year only portions of a Calendar.
Returns:
the Calendar but with the time portion cleared
Since:
1.6.7

copyWith

public Calendar copyWith(Map updates)
 
Support creating a new Date having similar properties to an existing Date (which remains unaltered) but with some fields updated according to a Map of changes.

Example usage:

import static java.util.Calendar.YEAR
def now = Calendar.instance
def nextYear = now[YEAR] + 1
def oneYearFromNow = now.copyWith(year: nextYear)
println now.time
println oneYearFromNow.time
Parameters:
updates - A Map of Calendar keys and values.
Returns:
The newly created Calendar
Since:
2.2.0
See:
Calendar#set.
Calendar#set.
Calendar#set.

downto

public void downto(Calendar to, Closure closure)
 
Iterates from the date represented by this calendar up to the date represented by the given calendar, inclusive, incrementing by one day each time.
Parameters:
to - another Calendar to go down to.
closure - the closure to call.
Since:
2.2

format

public String format(String pattern)
 

Shortcut for SimpleDateFormat to output a String representation of this calendar instance. This method respects the Calendar's assigned TimeZone, whereas calling cal.time.format('HH:mm:ss') would use the system timezone.

Note that Calendar equivalents of date.getDateString() and variants do not exist because those methods are Locale-dependent. Although a Calendar may be assigned a Locale, that information is lost and therefore cannot be used to control the default date/time formats provided by these methods. Instead, the system Locale would always be used. The alternative is to simply call DateFormat#getDateInstance and pass the same Locale that was used for the Calendar.

Parameters:
pattern - format pattern.
Returns:
String representation of this calendar with the given format.
Since:
1.6.0
See:
DateFormat#setTimeZone.
SimpleDateFormat#format.
Date#format.

getAt

public int getAt(int field)
 
Support the subscript operator for a Calendar.
Parameters:
field - a Calendar field, e.g. MONTH.
Returns:
the value for the given field, e.g. FEBRUARY
Since:
1.7.3
See:
Calendar.

minus

public int minus(Calendar then)
 
Subtract another date from this one and return the number of days of the difference.

Date self = Date then + (Date self - Date then)

IOW, if self is before then the result is a negative value.

Parameters:
then - another Calendar.
Returns:
number of days
Since:
1.6.0

next

public Calendar next()
 
Increment a Calendar by one day.
Returns:
a new Calendar set to the next day
Since:
1.8.7

previous

public Calendar previous()
 
Decrement a Calendar by one day.
Returns:
a new Calendar set to the previous day
Since:
1.8.7

putAt

public void putAt(int field, int value)
 
Support the subscript operator for mutating a Calendar. Example usage:
import static java.util.Calendar.*
def cal = Calendar.instance
cal[DAY_OF_WEEK] = MONDAY
cal[MONTH] = MARCH
println cal.time // A Monday in March
Parameters:
field - A Calendar field, e.g. MONTH.
value - The value for the given field, e.g. FEBRUARY.
Since:
1.7.3
See:
Calendar#set.

set

public void set(Map updates)
 
Support mutating a Calendar with a Map.

The map values are the normal values provided as the second parameter to java.util.Calendar#set(int, int). The keys can either be the normal fields values provided as the first parameter to that method or one of the following Strings:

Calendar index values
yearCalendar.YEAR
monthCalendar.MONTH
dateCalendar.DATE
dayOfMonthCalendar.DATE
hourOfDayCalendar.HOUR_OF_DAY
minuteCalendar.MINUTE
secondCalendar.SECOND
Example usage:
import static java.util.Calendar.*
def cal = Calendar.instance
def m = [:]
m[YEAR] = 2010
m[MONTH] = DECEMBER
m[DATE] = 25
cal.set(m)
println cal.time // Christmas 2010

cal.set(year:2011, month:DECEMBER, date:25)
println cal.time // Christmas 2010
Parameters:
updates - A Map of Calendar keys and values.
Since:
1.7.3
See:
Calendar#set.
Calendar#set.

updated

public Calendar updated(Map updates)
 
Legacy alias for copyWith. Will be deprecated and removed in future versions of Groovy.
Parameters:
Since:
1.7.3
See:
Calendar#copyWith.

upto

public void upto(Calendar to, Closure closure)
 
Iterates from the date represented by this calendar up to the date represented by the given calendar, inclusive, incrementing by one day each time.
Parameters:
to - another Calendar to go up to.
closure - the closure to call.
Since:
2.2

Groovy JDK