-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathNSDate+Components.h
112 lines (92 loc) · 2.94 KB
/
NSDate+Components.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#import <Cocoa/Cocoa.h>
/*!
@brief A class for creating NSDate objects with arbitrary components,
and for getting the components of NSDate objects. Here, by
"components", we mean the year, month, hours, etc., in the sense of
NSDateComponents.
@details It seems to me that you really need these for dealing with
recurring dates, for example scheduling events to occur every day at
a given time. I'm surprised that Apple doesn't provide this.
I'm sure there's a reason, but I've never been able to stay awake
long enough to read documents like Date and Time Programming Guide.
I understand that one could get probably get a PhD degree in dates,
but I just want something that works for 99% of the world.
*/
@interface NSDate (Components)
/*!
@brief Returns an NSDate equal to the current date
and user's time zone, except certain component(s) which are
replaced with values given in the parameter(s).
@details Pass NSNotFound as the parameter value for
any component which you wish to assume its default value of
the current date and user's time zone. Do not pass 0
unless you really mean it, because when you later display
the result, it will be offset to the user's time zone and
daylight-savings-ness, which is probably not what you want.
*/
+ (NSDate*)dateWithYear:(NSInteger)year
month:(NSInteger)month
day:(NSInteger)day
hour:(NSInteger)hour
minute:(NSInteger)minute
second:(NSInteger)second
timeZoneOffset:(NSInteger)timeZoneOffset ;
/*!
@brief Returns the year of the receiver as a string.
*/
- (NSString*)yearString ;
/*!
@brief Returns the month of the receiver as a string, padded with a leading
zero if necessary to make two characters
*/
- (NSString*)monthString ;
/*!
@brief Returns the month of the receiver as a string, as one or two characters
*/
- (NSString*)monthStringWithoutLeadingZero ;
/*!
@brief Returns the day of the receiver as a string, padded with a leading
zero if necessary to make two characters
*/
- (NSString*)dayString ;
/*!
@brief Returns the day of the receiver as a string, as one or two characters
*/
- (NSString*)dayStringWithoutLeadingZero ;
/*!
@brief Returns the hour of the receiver as a string.
*/
- (NSString*)hourString ;
/*!
@brief Returns the minute of the receiver as a string.
*/
- (NSString*)minuteString ;
/*!
@brief Returns the second of the receiver as a string.
*/
- (NSString*)secondString ;
/*!
@brief Returns the year of the receiver as an integer.
*/
- (NSInteger)year ;
/*!
@brief Returns the month of the receiver as an integer.
*/
- (NSInteger)month ;
/*!
@brief Returns the day of the receiver as an integer.
*/
- (NSInteger)day ;
/*!
@brief Returns the hour of the receiver as an integer.
*/
- (NSInteger)hour ;
/*!
@brief Returns the minute of the receiver as an integer.
*/
- (NSInteger)minute ;
/*!
@brief Returns the second of the receiver as an integer.
*/
- (NSInteger)second ;
@end