2001-03-08 14:48:27 +00:00
|
|
|
/* Interface for NSCalendarDate for GNUStep
|
|
|
|
Copyright (C) 1994, 1996, 1999 Free Software Foundation, Inc.
|
|
|
|
|
|
|
|
This file is part of the GNUstep Base Library.
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
2007-09-14 11:36:11 +00:00
|
|
|
modify it under the terms of the GNU Lesser General Public
|
2001-03-08 14:48:27 +00:00
|
|
|
License as published by the Free Software Foundation; either
|
2008-06-08 10:38:33 +00:00
|
|
|
version 2 of the License, or (at your option) any later version.
|
2001-03-08 14:48:27 +00:00
|
|
|
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
2007-09-14 11:36:11 +00:00
|
|
|
You should have received a copy of the GNU Lesser General Public
|
2001-03-08 14:48:27 +00:00
|
|
|
License along with this library; if not, write to the Free
|
2006-09-13 10:20:49 +00:00
|
|
|
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
Boston, MA 02111 USA.
|
2001-03-08 14:48:27 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __NSCalendarDate_h_GNUSTEP_BASE_INCLUDE
|
|
|
|
#define __NSCalendarDate_h_GNUSTEP_BASE_INCLUDE
|
2006-10-31 07:05:46 +00:00
|
|
|
#import <GNUstepBase/GSVersionMacros.h>
|
2001-03-08 14:48:27 +00:00
|
|
|
|
2006-10-31 07:05:46 +00:00
|
|
|
#import <Foundation/NSDate.h>
|
2001-03-08 14:48:27 +00:00
|
|
|
|
2006-09-13 10:20:49 +00:00
|
|
|
#if defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2001-03-08 14:48:27 +00:00
|
|
|
@class NSTimeZone;
|
|
|
|
@class NSTimeZoneDetail;
|
|
|
|
|
|
|
|
@interface NSCalendarDate : NSDate
|
|
|
|
{
|
|
|
|
NSTimeInterval _seconds_since_ref;
|
|
|
|
NSString *_calendar_format;
|
|
|
|
NSTimeZone *_time_zone;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Getting an NSCalendar Date
|
|
|
|
+ (id) calendarDate;
|
|
|
|
+ (id) dateWithString: (NSString*)description
|
|
|
|
calendarFormat: (NSString*)format;
|
|
|
|
+ (id) dateWithString: (NSString*)description
|
|
|
|
calendarFormat: (NSString*)format
|
|
|
|
locale: (NSDictionary*)dictionary;
|
2009-02-23 20:42:32 +00:00
|
|
|
+ (id) dateWithYear: (NSInteger)year
|
|
|
|
month: (NSUInteger)month
|
|
|
|
day: (NSUInteger)day
|
|
|
|
hour: (NSUInteger)hour
|
|
|
|
minute: (NSUInteger)minute
|
|
|
|
second: (NSUInteger)second
|
2001-03-08 14:48:27 +00:00
|
|
|
timeZone: (NSTimeZone*)aTimeZone;
|
|
|
|
|
|
|
|
// Initializing an NSCalendar Date
|
|
|
|
- (id) initWithString: (NSString*)description;
|
|
|
|
- (id) initWithString: (NSString*)description
|
|
|
|
calendarFormat: (NSString*)format;
|
|
|
|
- (id) initWithString: (NSString*)description
|
2001-12-17 14:31:42 +00:00
|
|
|
calendarFormat: (NSString*)fmt
|
|
|
|
locale: (NSDictionary*)locale;
|
2009-02-23 20:42:32 +00:00
|
|
|
- (id) initWithYear: (NSInteger)year
|
|
|
|
month: (NSUInteger)month
|
|
|
|
day: (NSUInteger)day
|
|
|
|
hour: (NSUInteger)hour
|
|
|
|
minute: (NSUInteger)minute
|
|
|
|
second: (NSUInteger)second
|
2001-03-08 14:48:27 +00:00
|
|
|
timeZone: (NSTimeZone*)aTimeZone;
|
|
|
|
|
2006-10-23 12:24:52 +00:00
|
|
|
// Retrieving Date Elements
|
2009-02-23 20:42:32 +00:00
|
|
|
- (NSInteger) dayOfCommonEra;
|
|
|
|
- (NSInteger) dayOfMonth;
|
|
|
|
- (NSInteger) dayOfWeek;
|
|
|
|
- (NSInteger) dayOfYear;
|
|
|
|
- (NSInteger) hourOfDay;
|
|
|
|
- (NSInteger) minuteOfHour;
|
|
|
|
- (NSInteger) monthOfYear;
|
|
|
|
- (NSInteger) secondOfMinute;
|
|
|
|
- (NSInteger) yearOfCommonEra;
|
2001-03-08 14:48:27 +00:00
|
|
|
|
|
|
|
// Providing Adjusted Dates
|
2009-02-23 20:42:32 +00:00
|
|
|
- (NSCalendarDate*) addYear: (NSInteger)year
|
|
|
|
month: (NSInteger)month
|
|
|
|
day: (NSInteger)day
|
|
|
|
hour: (NSInteger)hour
|
|
|
|
minute: (NSInteger)minute
|
|
|
|
second: (NSInteger)second;
|
2001-03-08 14:48:27 +00:00
|
|
|
|
|
|
|
// Getting String Descriptions of Dates
|
|
|
|
- (NSString*) description;
|
|
|
|
- (NSString*) descriptionWithCalendarFormat: (NSString*)format;
|
|
|
|
- (NSString*) descriptionWithCalendarFormat: (NSString*)format
|
|
|
|
locale: (NSDictionary*)locale;
|
|
|
|
- (NSString*) descriptionWithLocale: (NSDictionary*)locale;
|
|
|
|
|
|
|
|
// Getting and Setting Calendar Formats
|
|
|
|
- (NSString*) calendarFormat;
|
|
|
|
- (void) setCalendarFormat: (NSString*)format;
|
|
|
|
|
|
|
|
// Getting and Setting Time Zones
|
|
|
|
- (void) setTimeZone: (NSTimeZone*)aTimeZone;
|
2006-10-31 07:05:46 +00:00
|
|
|
#if OS_API_VERSION(GS_API_MACOSX, GS_API_LATEST)
|
2001-03-08 14:48:27 +00:00
|
|
|
- (NSTimeZone*) timeZone;
|
|
|
|
#endif
|
2006-10-31 07:05:46 +00:00
|
|
|
#if OS_API_VERSION(GS_API_OPENSTEP, GS_API_MACOSX)
|
2001-03-08 14:48:27 +00:00
|
|
|
- (NSTimeZoneDetail*) timeZoneDetail;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
2006-10-31 07:05:46 +00:00
|
|
|
#if OS_API_VERSION(GS_API_NONE, GS_API_NONE)
|
2003-04-17 06:20:17 +00:00
|
|
|
|
2004-06-22 22:27:39 +00:00
|
|
|
/**
|
|
|
|
* Adds <code>-weekOfYear</code> method.
|
|
|
|
*/
|
2003-04-17 06:20:17 +00:00
|
|
|
@interface NSCalendarDate (GSCategories)
|
2004-06-22 22:27:39 +00:00
|
|
|
/**
|
|
|
|
* The ISO standard week of the year is based on the first week of the
|
|
|
|
* year being that week (starting on monday) for which the thursday
|
|
|
|
* is on or after the first of january.<br />
|
|
|
|
* This has the effect that, if january first is a friday, saturday or
|
|
|
|
* sunday, the days of that week (up to and including the sunday) are
|
2005-11-06 13:53:40 +00:00
|
|
|
* considered to be in week 53 of the preceding year. Similarly if the
|
2004-06-22 22:27:39 +00:00
|
|
|
* last day of the year is a monday tuesday or wednesday, these days are
|
|
|
|
* part of week 1 of the next year.
|
|
|
|
*/
|
2009-02-23 20:42:32 +00:00
|
|
|
- (NSInteger) weekOfYear;
|
2003-04-17 06:20:17 +00:00
|
|
|
@end
|
|
|
|
|
2001-03-08 14:48:27 +00:00
|
|
|
@interface NSCalendarDate (GregorianDate)
|
|
|
|
|
2009-02-23 20:42:32 +00:00
|
|
|
- (NSInteger) lastDayOfGregorianMonth: (NSInteger)month year: (NSInteger)year;
|
|
|
|
- (NSInteger) absoluteGregorianDay: (NSInteger)day month: (NSInteger)month year: (NSInteger)year;
|
|
|
|
- (void) gregorianDateFromAbsolute: (NSInteger)d
|
|
|
|
day: (NSInteger*)day
|
|
|
|
month: (NSInteger*)month
|
|
|
|
year: (NSInteger*)year;
|
2001-03-08 14:48:27 +00:00
|
|
|
|
|
|
|
@end
|
|
|
|
|
2003-01-07 15:26:42 +00:00
|
|
|
#endif
|
|
|
|
|
2006-10-31 07:05:46 +00:00
|
|
|
#if OS_API_VERSION(GS_API_OPENSTEP, GS_API_MACOSX)
|
2001-03-08 14:48:27 +00:00
|
|
|
@interface NSCalendarDate (OPENSTEP)
|
|
|
|
|
2009-02-23 20:42:32 +00:00
|
|
|
- (NSCalendarDate*) dateByAddingYears: (NSInteger)years
|
|
|
|
months: (NSInteger)months
|
|
|
|
days: (NSInteger)days
|
|
|
|
hours: (NSInteger)hours
|
|
|
|
minutes: (NSInteger)minutes
|
|
|
|
seconds: (NSInteger)seconds;
|
|
|
|
|
|
|
|
- (void) years: (NSInteger*)years
|
|
|
|
months: (NSInteger*)months
|
|
|
|
days: (NSInteger*)days
|
|
|
|
hours: (NSInteger*)hours
|
|
|
|
minutes: (NSInteger*)minutes
|
|
|
|
seconds: (NSInteger*)seconds
|
2001-03-08 14:48:27 +00:00
|
|
|
sinceDate: (NSDate*)date;
|
|
|
|
@end
|
2002-08-08 19:25:17 +00:00
|
|
|
#endif
|
|
|
|
|
2006-09-13 10:20:49 +00:00
|
|
|
#if defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2001-03-08 14:48:27 +00:00
|
|
|
#endif /* __NSCalendarDate_h_GNUSTEP_BASE_INCLUDE*/
|