Date.st
author claus
Tue, 16 May 1995 19:09:45 +0200
changeset 345 cf2301210c47
parent 339 e8658d38abfb
child 362 4131e87e79ec
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    13
Magnitude subclass:#Date
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    14
       instanceVariableNames:'dateEncoding'
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
    15
       classVariableNames:'DayNames MonthNames DayAbbrevs MonthAbbrevs
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    16
			   EnvironmentChange'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
       category:'Magnitude-General'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
Date comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1989 by Claus Gittinger
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    23
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    24
339
claus
parents: 333
diff changeset
    25
$Header: /cvs/stx/stx/libbasic/Date.st,v 1.21 1995-05-08 03:29:07 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    27
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    28
!Date class methodsFor:'documentation'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    29
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    30
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    31
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    32
 COPYRIGHT (c) 1989 by Claus Gittinger
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    33
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    34
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    35
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    36
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    37
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    38
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    39
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    40
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    41
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    42
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    43
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    44
version
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    45
"
339
claus
parents: 333
diff changeset
    46
$Header: /cvs/stx/stx/libbasic/Date.st,v 1.21 1995-05-08 03:29:07 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    47
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    48
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    49
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    50
documentation
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    51
"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    52
    Instances of Date represent dates as year, month and day encoded in the 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    53
    (private & hidden) instance dateEncoding. The value found there is 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    54
    year*100*100 + month*100 + day (which makes magnitude-like comparison of 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    55
    dates easy, but is not guaranteed for future versions).
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    56
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    57
    The old representation used days since 1st Jan. 1901 internally - 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    58
    with the new implementation, it is possible to reasonably represent almost 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    59
    any Date.  (which insurance companies will like, since they can now 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    60
    represent even very old peoples birthday :-)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    61
    Notice: no correction for pre-Julian dates is done.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    62
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    63
    The printed representation of dates is controlled by resource definitions -
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    64
    thus national variants are already supported (see file 'resources/Date.rs').
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    65
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    66
    Compatibility notice:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    67
	due to some historic reasons, there are some methods found twice
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    68
	with different names in this class. The old ST/X methods will vanish in
241
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
    69
	one of the next releases, and kept for a while to support existing
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    70
	applications (the info on how these methods should be named came 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    71
	somewhat late from the testers ..).
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    72
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    73
	Please do not use methods marked as obsolete in their comment.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    74
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    75
    Most useful methods:
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    76
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    77
	Date today
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    78
	(Date today) addDays:
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    79
	(Date today) subtractDays:
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    80
"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    81
! !
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    82
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
!Date class methodsFor:'private'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
initNames
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
    "read the language specific names"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
10
claus
parents: 5
diff changeset
    88
    |resources|
claus
parents: 5
diff changeset
    89
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    90
    DayNames := #('monday'
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    91
		  'tuesday'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    92
		  'wednesday'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    93
		  'thursday'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    94
		  'friday'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    95
		  'saturday'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    96
		  'sunday').
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
    98
    DayAbbrevs := #('mon' 
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    99
		    'tue' 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   100
		    'wed'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   101
		    'thu' 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   102
		    'fri' 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   103
		    'sat' 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   104
		    'sun').
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   106
    MonthNames := #('january'
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   107
		    'february'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   108
		    'march'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   109
		    'april'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   110
		    'may'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   111
		    'june'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   112
		    'july'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   113
		    'august'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   114
		    'september'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   115
		    'october'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   116
		    'november'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   117
		    'december').
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   119
    MonthAbbrevs := #('jan'
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   120
		      'feb'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   121
		      'mar'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   122
		      'apr'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   123
		      'may'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   124
		      'jun'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   125
		      'jul'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   126
		      'aug'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   127
		      'sep'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   128
		      'oct'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   129
		      'nov'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   130
		      'dec').
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   131
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   132
    "check for case where Resource-classes are absent"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   133
    ResourcePack notNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   134
	resources := ResourcePack for:self.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   135
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   136
	DayNames := resources array:DayNames.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   137
	DayAbbrevs := resources array:DayAbbrevs.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   138
	MonthNames := resources array:MonthNames.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   139
	MonthAbbrevs := resources array:MonthAbbrevs.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   140
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   142
    EnvironmentChange := false
10
claus
parents: 5
diff changeset
   143
claus
parents: 5
diff changeset
   144
    "Date initNames"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   145
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   146
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   147
daysInMonthIndex: monthIndex forYear: yearInteger
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   148
    "return the number of days in month monthIndex of
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   149
     year yearInteger (modified GNU).
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   150
     Return 0 for invalid month index.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   151
     This is the internal version of daysInMonth:forYear:"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   152
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   153
    |days|
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   154
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   155
    (monthIndex between:1 and:12) ifFalse:[^ 0].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   156
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   157
    days := #(31 28 31           "Jan Feb Mar"
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   158
	      30 31 30           "Apr May Jun"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   159
	      31 31 30           "Jul Aug Sep"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   160
	      31 30 31           "Oct Nov Dec"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   161
	     ) at: monthIndex.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   162
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   163
    (monthIndex == 2) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   164
	(self leapYear:yearInteger) ifTrue:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   165
	    ^ days + 1
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   166
	]
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   167
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   168
    ^ days
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   169
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   170
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   171
     Date daysInMonthIndex:2 forYear:1994
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   172
     Date daysInMonthIndex:2 forYear:1980
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   173
     Date daysInMonthIndex:2 forYear:1981
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   174
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
a27a279701f8 Initial revision
claus
parents:
diff changeset
   177
!Date class methodsFor:'handling language changes'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
initialize
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   180
    "check for case where Resource-classes are absent"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   181
    ResourcePack isNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   182
	self initNames
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   183
    ] ifFalse:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   184
	Smalltalk addDependent:self.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   185
	EnvironmentChange := true
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   186
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
update:something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
    ((something == #Language) or:[something == #LanguageTerritory]) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   191
	"just remember change for next access"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   192
	EnvironmentChange := true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
!Date class methodsFor:'general queries'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   198
dateAndTimeNow
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   199
    "return an array containing the date and time of now"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   200
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   201
    ^ Time dateAndTimeNow
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   202
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   203
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   204
     Date dateAndTimeNow
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   205
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   206
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   207
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
dayOfWeek:dayName
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
    "given the name of a day (either string or symbol),
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
     return the day-index (1 for monday; 7 for sunday).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
     Return 0 for invalid day name"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   212
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   213
    EnvironmentChange ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   214
	self initNames
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
    ].
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   216
    ^ DayNames indexOf:dayName
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   218
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   219
     Date dayOfWeek:'wednesday'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   220
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   223
nameOfDay:dayIndex
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   224
    "given a day index (1..7), return the name of the day" 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   225
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   226
    EnvironmentChange ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   227
	self initNames
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   228
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   229
    ^ DayNames at:dayIndex
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   230
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   231
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   232
     Date nameOfDay:4
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   233
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   234
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   235
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   236
abbreviatedNameOfDay:dayIndex
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   237
    "given a day index (1..7), return the abbreviated name
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   238
     of the day"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   239
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   240
    EnvironmentChange ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   241
	self initNames
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   242
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   243
    ^ DayAbbrevs at:dayIndex
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   244
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   245
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   246
     Date abbreviatedNameOfDay:4
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   247
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   248
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   249
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
indexOfMonth:aMonthString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
    "given the name of a month (either string or symbol),
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
     return the month-index (1 for jan; 12 for december).
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   253
     The given string may be a full or abbreviated name,
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   254
     case is ignored.
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   255
     Return 0 for invalid month name."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
    |idx name|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   259
    EnvironmentChange ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   260
	self initNames
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
    name := aMonthString asLowercase.
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   263
    idx := MonthAbbrevs indexOf:name.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
    idx ~~ 0 ifTrue:[^ idx].
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   265
    idx := MonthNames indexOf:name.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
    idx ~~ 0 ifTrue:[^ idx].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
    name at:1 put:(name at:1) asUppercase.
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   269
    idx := MonthAbbrevs indexOf:name.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
    idx ~~ 0 ifTrue:[^ idx].
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   271
    idx := MonthNames indexOf:name.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
    idx ~~ 0 ifTrue:[^ idx].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
    ^ idx
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   276
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   277
     Date indexOfMonth:'jan'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   278
     Date indexOfMonth:'Jan'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   279
     Date indexOfMonth:'December'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   280
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   283
nameOfMonth:monthIndex
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   284
    "given a month index (1..12), return the name of the month"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   286
    EnvironmentChange ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   287
	self initNames
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   289
    ^ MonthNames at:monthIndex
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   291
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   292
     Date nameOfMonth:11
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   293
     Date nameOfMonth:12
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   294
     Date nameOfMonth:4
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   295
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
abbreviatedNameOfMonth:monthIndex
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
    "given a month index (1..12), return the abbreviated name
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   300
     of the month"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   302
    EnvironmentChange ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   303
	self initNames
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   305
    ^ MonthAbbrevs at:monthIndex
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   306
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   307
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   308
     Date abbreviatedNameOfMonth:11
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   309
     Date abbreviatedNameOfMonth:12
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   310
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   313
daysInMonth:month forYear:yearInteger
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   314
    "given the name of a month and a year, return the number 
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   315
     of days this month has (modified GNU).
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   316
     return 0 if the month name was invalid.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   317
     For your convenience, month maybe an integer or name-string."
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   318
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   319
    |monthIndex "{ Class: SmallInteger }"|
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   320
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   321
    month isInteger ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   322
	monthIndex := month
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   323
    ] ifFalse:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   324
	monthIndex := self indexOfMonth:month
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
    ].
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   326
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
    ^ self daysInMonthIndex:monthIndex forYear:yearInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   329
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   330
     Date daysInMonth:2 forYear:1980
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   331
     Date daysInMonth:2 forYear:1981
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   332
     Date daysInMonth:'feb' forYear:1981
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   333
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   336
daysUntilMonth:month forYear:yearInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
    "given the name of a month and a year, return the number 
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   338
     of days from 1st january to last of prev month of that year.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   339
     Return 0 if the month name/index is invalid or is january.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   340
     For your convenience, month maybe an integer or name-string."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   342
    |monthIndex "{ Class: SmallInteger }"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   343
     sumDays    "{ Class: SmallInteger }" |
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   345
    month isInteger ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   346
	monthIndex := month
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   347
    ] ifFalse:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   348
	monthIndex := self indexOfMonth:month
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
    ].
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   350
    (monthIndex between:1 and:12) ifFalse:[^ 0].
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   351
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
    sumDays := 0.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
    1 to:monthIndex-1 do:[:m |
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   354
	sumDays := sumDays + (self daysInMonthIndex:m forYear:yearInteger)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
    ^ sumDays
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   358
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   359
     Date daysUntilMonth:'feb' forYear:1993
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   360
     Date daysUntilMonth:'jan' forYear:1993
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   361
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   362
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   363
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   364
monthAndDayFromDayInYear:aDayInYear forYear:yearInteger
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   365
    "given a day-in-year (1..365) return an Array containing the
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   366
     month index and the day-in-month. Return nil if the argument is invalid."
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   367
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   368
    |restDays daysInMonth|
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   369
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   370
    restDays := aDayInYear.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   371
    restDays < 1 ifTrue:[^ nil].
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   372
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   373
    1 to:12 do:[:m |
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   374
	daysInMonth := self daysInMonthIndex:m forYear:yearInteger.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   375
	restDays <= daysInMonth ifTrue:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   376
	    ^ Array with:m with:restDays
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   377
	].
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   378
	restDays := restDays - daysInMonth 
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   379
    ].
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   380
    restDays > daysInMonth ifTrue:[^ nil].
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   381
    ^ Array with:12 with:restDays
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   382
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   383
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   384
     Date monthAndDayFromDayInYear:66 forYear:1980
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   385
     Date monthAndDayFromDayInYear:66 forYear:1981
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   386
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   387
! 
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   388
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   389
daysInYear:yearInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
    "return the number of days in a year"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   392
    (self leapYear:yearInteger) ifTrue:[^ 366].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
    ^ 365
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   395
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   396
     Date daysInYear:1900  
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   397
     Date daysInYear:1901 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   398
     Date daysInYear:1904 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   399
     Date daysInYear:1980 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   400
     Date daysInYear:1981
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   401
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
yearAsDays: yearInteger
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   405
    "Returns the number of days since Jan 1, 1901. (GNU)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   406
     to the first Jan of the year, yearInteger.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   407
     For 1901 this is zero, for 1902 its 365.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   408
     Defined for years >= 1901"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   410
    |y "{ Class: SmallInteger }"|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
    y := yearInteger - 1900.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   413
    y := y - 1.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   414
    ^ (y * 365)
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   415
	+ (y // 4)
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   416
	- (y // 100)
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   417
	+ ((y + 300) // 400)
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   418
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   419
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   420
     Date yearAsDays:1901 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   421
     Date yearAsDays:1902   
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   422
     Date yearAsDays:1903   
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   423
     Date yearAsDays:1904    
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   424
     Date yearAsDays:1905     
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   425
     Date yearAsDays:1994   
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   426
     (Date yearAsDays:2001) - (Date yearAsDays:2000)   
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   427
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   430
leapYear:yearInteger
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   431
    "return true, if yearInteger is a leap year."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   432
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   433
    |y "{ Class: SmallInteger }"|
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   434
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   435
    y := yearInteger.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   436
    (y \\ 4 == 0) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   437
	(y \\ 100 ~~ 0) ifTrue:[^ true].
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   438
	(y \\ 400 == 0) ifTrue:[^ true]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
    ^ false
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   441
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   442
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   443
     Date leapYear:1992
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   444
     Date leapYear:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   445
     Date leapYear:1900
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   446
     Date leapYear:2000
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   447
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   448
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   449
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   450
isLeapYear:yearInteger
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   451
    "Return true, if a year is a leap year.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   452
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   453
	 Please use the ST-80 compatible #leapYear for new programs, 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   454
	 since this method will vanish."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   455
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   456
    ^ self leapYear:yearInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
!Date class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   461
fromOSTime:osTime
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   462
    "return a date, representing the date given by the operatingSystem time.
241
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   463
     This somewhat clumsy implementation hides the OS's date representation
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   464
     (i.e. makes this class independent of what the OS starts its time values with).
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   465
     Dont use this method, the osTime representation is totally unportable."
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   466
241
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   467
    ^ self basicNew fromOSTime:osTime
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   468
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   469
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   470
     Date fromOSTime:#(0 0)      -> on UNIX: this should return 1st Jan 1970
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   471
				    thats where Unix time starts
241
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   472
				    On other systems, it may be something different.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   473
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   474
     Date fromOSTime:#(86400 0)  -> on UNIX: the day after
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   475
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   476
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   477
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
today
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
    "return a date, representing today"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   481
    ^ self fromOSTime:OperatingSystem getTimeParts
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   482
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   483
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   484
     Date today
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   485
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
fromDays:dayCount
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   489
    "return a new Date, given the day-number starting with 0 at 1.Jan 1901;
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   490
     (i.e. 'Date fromDays:0' returns 1st Jan. 1901).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   491
     Date asDays is the reverse operation.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   492
     for GNU/ST-80 compatibility"
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   493
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   494
    |yr rest d|
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   495
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   496
    "approx. year"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   497
    yr := (dayCount // 366) + 1901.
85
claus
parents: 77
diff changeset
   498
    rest := dayCount - (self yearAsDays:yr) + 1. "+1 for ST-80 compatibility"
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   499
    d := self daysInYear:yr.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   500
    (rest > d) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   501
	"adjust"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   502
	yr := yr + 1.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   503
	rest := rest - d.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   504
    ].
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   505
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   506
    ^ self day:rest year:yr
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   507
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   508
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   509
     Date fromDays:0     -> 1 jan 1901
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   510
     Date fromDays:365   -> 1 jan 1902
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   511
     Date fromDays:730   -> 1 jan 1903
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   512
     Date fromDays:1095  -> 1 jan 1903
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   513
     Date fromDays:1460  ->31 dec 1904 since 1904 was a leap year
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   514
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   515
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   516
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   517
day:dayInYear year:year
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   518
    "return a new Date, given the year and the day-in-year (starting at 1).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   519
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   520
	use newDay:year: for ST-80 compatibility"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   521
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   522
    ^ self newDay:dayInYear year:year
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   523
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   524
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   525
newDay:dayInYear year:year
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   526
    "return a new Date, given the year and the day-in-year (starting at 1).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   527
     ST-80 compatibility"
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   528
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   529
    |monthAndDay|
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   530
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   531
    (dayInYear between:1 and:365) ifFalse:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   532
	((dayInYear == 366) and:[self leapYear:year]) ifFalse:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   533
	    "
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   534
	     this error is triggered, when you try to create a
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   535
	     day from an invalid day-in-year; 
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   536
	     for example, 366 in a non-leap year.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   537
	     I dont know, if ST-80 wraps to the next year(s) in this case.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   538
	    "
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   539
	    ^ self error:'invalid date'
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   540
	]
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   541
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   542
    monthAndDay := self monthAndDayFromDayInYear:dayInYear forYear:year.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   543
    ^ self day:(monthAndDay at:2) month:(monthAndDay at:1) year:year
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   544
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   545
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   546
     Date newDay:150 year:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   547
     Date newDay:1 year:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   548
     Date newDay:1 year:1901
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   549
     Date newDay:1 year:1902
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   550
     Date newDay:365 year:1992
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   551
     Date newDay:366 year:1992
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   552
     Date newDay:365 year:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   553
     Date newDay:366 year:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   554
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   557
day:day month:month year:year
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   558
    "return a new Date, given the day, month and year.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   559
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   560
	use newDay:month:year: for ST-80 compatibility"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   561
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   562
    ^ self newDay:day month:month year:year
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   563
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   564
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   565
newDay:day month:month year:year
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   566
    "return a new Date, given the day, month and year.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   567
     For your convenience, month may be either an integer 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   568
     or the months name as a string. 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   569
     Year may be the actual year (such as 1890, 2001) or the number 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   570
     of years since 1900 (which is rubbish ST-80 compatibility: 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   571
     it will be totally useless in a few years ...).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   572
     You better not use this short-year feature in your programs."
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   573
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   574
    |monthIndex ok yr|
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   575
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   576
    yr := year.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   577
    yr < 100 ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   578
	yr := yr + 1900.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   579
    ].
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   580
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   581
    month isInteger ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   582
	monthIndex := month
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   583
    ] ifFalse:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   584
	monthIndex := self indexOfMonth:month
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   585
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   586
    (monthIndex == 2 and:[day == 29]) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   587
	ok := self leapYear:yr
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   588
    ] ifFalse:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   589
	ok := day <= (self daysInMonth:month forYear:yr)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   590
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   591
    ((day > 0) and:[ok]) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   592
	^ self basicNew dateEncoding:(((yr * 100) + monthIndex) * 100) + day
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   593
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   594
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   595
    "this error is triggered if you try to create a date from an
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   596
     invalid year/month/day combination;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   597
     Such as 29-feb-year, where year is no leap year
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   598
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   599
    self error:'invalid date'
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   600
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   601
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   602
     Date newDay:8  month:'may' year:1993
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   603
     Date newDay:8  month:5     year:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   604
     Date newDay:29 month:'feb' year:1994
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   605
     Date newDay:29 month:'feb' year:1993
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   606
     Date newDay:28 month:'feb' year:5
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   607
     Date newDay:28 month:'feb' year:95
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   608
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   609
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   610
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
   611
readFromString:aString onError:exceptionBlock
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   612
    "return a new Date, reading a printed representation from aStream.
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
   613
     Notice, that this is not the storeString format and 
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
   614
     is different from the format expected by readFrom:.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 155
diff changeset
   615
     BUG:
40ca7cc6fb9c *** empty log message ***
claus
parents: 155
diff changeset
   616
       This method assumes american format (i.e. month-day-year) instead
40ca7cc6fb9c *** empty log message ***
claus
parents: 155
diff changeset
   617
       of the german/french and other day-month-year.
40ca7cc6fb9c *** empty log message ***
claus
parents: 155
diff changeset
   618
       There ought to be a nationalized variant of this."
339
claus
parents: 333
diff changeset
   619
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
   620
    |month day year aStream|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   621
339
claus
parents: 333
diff changeset
   622
    Object errorSignal handle:[:ex |
claus
parents: 333
diff changeset
   623
	^ exceptionBlock value
claus
parents: 333
diff changeset
   624
    ] do:[
claus
parents: 333
diff changeset
   625
	aStream := ReadStream on:aString.
claus
parents: 333
diff changeset
   626
	[aStream peek isLetterOrDigit] whileFalse:[aStream next].
claus
parents: 333
diff changeset
   627
	(aStream peek isDigit) ifTrue:[
claus
parents: 333
diff changeset
   628
	    day := Integer readFrom:aStream onError:[^ exceptionBlock value]
claus
parents: 333
diff changeset
   629
	].
claus
parents: 333
diff changeset
   630
	[aStream peek isLetterOrDigit] whileFalse:[aStream next].
claus
parents: 333
diff changeset
   631
	(aStream peek isLetter) ifTrue:[
claus
parents: 333
diff changeset
   632
	    month := aStream nextAlphaNumericWord.
claus
parents: 333
diff changeset
   633
	    day isNil ifTrue:[
claus
parents: 333
diff changeset
   634
		[aStream peek isLetterOrDigit] whileFalse:[aStream next].
claus
parents: 333
diff changeset
   635
		day := Integer readFrom:aStream onError:[^ exceptionBlock value].
claus
parents: 333
diff changeset
   636
	    ]
claus
parents: 333
diff changeset
   637
	] ifFalse:[
claus
parents: 333
diff changeset
   638
	    month := self nameOfMonth:day.
claus
parents: 333
diff changeset
   639
	    day := Integer readFrom:aStream onError:[^ exceptionBlock value]
claus
parents: 333
diff changeset
   640
	].
claus
parents: 333
diff changeset
   641
	[aStream peek isLetterOrDigit] whileFalse:[aStream next].
claus
parents: 333
diff changeset
   642
	year := Integer readFrom:aStream onError:[^ exceptionBlock value].
claus
parents: 333
diff changeset
   643
	^ self newDay:day month:month year:year
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 155
diff changeset
   644
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   645
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   646
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   647
     Date readFromString:'31 December 1992'  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   648
     Date readFromString:'December, 5, 1992'  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   649
     Date readFromString:'December, 5 1992'  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   650
     Date readFromString:'3-jan-95'           
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   651
     Date readFromString:'12/31/1992'        
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   652
     Date readFromString:'15.4.1992'         -> german; leads to an error
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   653
     Date readFromString:'10.4.1992'         -> german; leads to a wrong date
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 155
diff changeset
   654
     Date readFromString:'10.4.1992' onError:['wrong date']
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   655
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   656
! !
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   657
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   658
!Date class methodsFor:'private encoding'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   659
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   660
encodeYear:y month:m day:d
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   661
    "the internal encoding is stricktly private, 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   662
     and should not be used outside."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   663
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   664
    ^ (((y * 100) + m) * 100) + d
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   665
! !
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   666
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   667
!Date methodsFor:'private accessing'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   668
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   669
dateEncoding
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   670
    "the internal encoding is stricktly private, 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   671
     and should not be used outside."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   672
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   673
    ^ dateEncoding
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   674
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   675
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   676
dateEncoding:anInteger
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   677
    "the internal encoding is stricktly private, 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   678
     and should not be used outside."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   679
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   680
    dateEncoding := anInteger
241
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   681
!
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   682
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   683
fromOSTime:osTime
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   684
    "set my dateEncoding from an OS time.
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   685
     This somewhat clumsy implementation hides the OS's date representation
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   686
     (i.e. makes this class independent of what the OS starts its time values with).
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   687
     Dont use this method, the osTime representation is totally unportable."
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   688
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   689
    OperatingSystem computeDatePartsOf:osTime 
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   690
				   for:[:year :month :day |
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   691
	dateEncoding := (((year * 100) + month) * 100) + day
6f30be88e314 *** empty log message ***
claus
parents: 202
diff changeset
   692
    ]
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   693
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   694
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   695
!Date methodsFor:'arithmetic'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   696
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   697
plusDays:days
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   698
    "return a new date representing 'days' after the receiver.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   699
     The argument should be some kind of integer.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   700
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   701
	 Please dont use this method since it will vanish.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   702
	 Use #addDays: instead for ST-80 compatibility."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   703
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   704
    ^ self addDays:days
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   705
!
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   706
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   707
addDays:days
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   708
    "return a new date representing 'days' after the receiver.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   709
     The argument should be some kind of integer.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   710
     For ST-80 compatibility."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   711
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   712
    ^ self class fromDays:(self asDays + days)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   713
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   714
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   715
     Date today addDays:7
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   716
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   717
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   718
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   719
minusDays:days
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   720
    "return a new date representing 'days' before the receiver.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   721
     The argument should be some kind of integer.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   722
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   723
	 Please dont use this method since it will vanish.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   724
	 Use #subtractDays: instead for ST-80 compatibility."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   725
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   726
    ^ self subtractDays:days
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   727
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   728
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   729
subtractDays:days
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   730
    "return a new date representing 'days' before the receiver.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   731
     The argument should be some kind of integer.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   732
     For ST-80 compatibility"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   733
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   734
    ^ self class fromDays:(self asDays - days)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   735
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   736
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   737
     Date today subtractDays:7
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   738
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   739
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   740
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   741
subtractDate:aDate
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   742
    "return the number of days between the receiver and aDate"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   743
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   744
    ^ self asDays - aDate asDays
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   745
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   746
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   747
    (Date day:1 month:1 year:1995) subtractDate:(Date day:24 month:12 year:1994)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   748
    (Date day:1 month:3 year:1992) subtractDate:(Date day:1 month:2 year:1992)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   749
    (Date day:1 month:3 year:1994) subtractDate:(Date day:1 month:2 year:1994)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   750
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   751
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   752
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   753
daysUntil:aDate
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   754
    "return the number of days between the receiver and the argument,
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   755
     aDate, whuch should be some kind of date"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   756
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   757
    ^ aDate asDays - self asDays
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   758
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   759
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   760
     (Date day:24 month:12 year:1994) daysUntil:(Date day:1 month:1 year:1995)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   761
     (Date day:1 month:2 year:1992) daysUntil:(Date day:1 month:3 year:1992)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   762
     (Date day:1 month:2 year:1994) daysUntil:(Date day:1 month:3 year:1994)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   763
    
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   764
     |delta|
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   765
     delta := Date today
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   766
		daysUntil:(Date day:25 month:12 year:Date today year).
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   767
     Transcript show:'still ';
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   768
		show:delta ;
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   769
		showCr:' days till xmas'
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   770
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   771
! !
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   772
    
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   773
!Date methodsFor:'accessing'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   774
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   775
day
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   776
    "return the day (1..31) of the receiver"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   777
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   778
    ^ dateEncoding \\ 100
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   779
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   780
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   781
     Date today day
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   782
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   783
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   784
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   785
month
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   786
    "return the month (1..12) of the receiver"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   787
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   788
    ^ (dateEncoding // 100) \\ 100
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   789
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   790
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   791
     Date today month
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   792
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   793
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   794
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   795
year
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   796
    "return the year (1..12) of the receiver"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   797
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   798
    ^ dateEncoding // (100*100)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   799
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   800
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   801
     Date today year
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   802
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   803
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   804
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   805
leap
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   806
    "return true, if the receivers year is a leap year"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   807
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   808
    ^ Date leapYear:(self year)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   809
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   810
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   811
     Date today leap
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   812
     (Date day:1 month:1 year:1992) leap
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   813
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   814
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   815
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   816
dayCount
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   817
    "return the number of days since 1st. Jan. 1901;
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   818
     starting with 0 for this date.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   819
     Date>>fromDays: is the reverse operation.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   820
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   821
	 please use asDays for ST-80 compatibility"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   822
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   823
    ^ self asDays.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   824
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   825
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   826
     (Date day:1 month:1 year:1901) dayCount
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   827
     Date fromDays:(Date day:1 month:1 year:1994) dayCount
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   828
     Date today dayCount
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   829
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   830
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   831
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   832
asDays
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   833
    "return the number of days elapsed since 01-Jan-1901
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   834
     and the receiver's day; starts with 0 for 1-1-1901.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   835
     Date>>fromDays: is the reverse operation.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   836
     For ST-80 compatibility."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   837
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   838
    |yr|
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   839
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   840
    yr := self year.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   841
    ^ (self class yearAsDays:yr)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   842
      + (self class daysUntilMonth:self month forYear:yr)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   843
      + self day
85
claus
parents: 77
diff changeset
   844
      - 1
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   845
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   846
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   847
     (Date day: 5 month: 8 year: 1962) asDays  -> should be 22496
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   848
     (Date day: 1 month: 1 year: 1901) asDays  -> 0
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   849
     Date today asDays
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   850
     Date fromDays:(Date today asDays + 7)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   851
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   852
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   853
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   854
asSeconds
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   855
    "return the seconds between 1.jan.1901 and the same time in the receivers 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   856
     day. (i.e. midnight to midnight).
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   857
     ST-80 compatibility."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   858
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   859
    ^ 60*60*24 * self asDays
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   860
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   861
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   862
     (Date day: 5 month: 8 year: 1962) asSeconds
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   863
     (Date day: 1 month: 1 year: 1901) asSeconds
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   864
     (Date today addDays:7) asSeconds - Date today asSeconds
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   865
    "  
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   866
! 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   867
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   868
dayOfMonth
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   869
    "Answer the day of the month represented by me.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   870
     Same as day; for ST-80 compatibility."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   871
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   872
    ^ self day
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   873
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   874
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   875
     Date today dayOfMonth
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   876
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   877
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   878
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   879
daysInMonth
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   880
    "return the number of days in the month of the receiver"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   881
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   882
    ^ Date daysInMonth:(self month) forYear:(self year)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   883
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   884
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   885
     Date today daysInMonth
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   886
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   887
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   888
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   889
daysInYear
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   890
    "return the number of days in the year of the receiver"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   891
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   892
    ^ Date daysInYear:(self year)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   893
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   894
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   895
     Date today daysInYear
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   896
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   897
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   898
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   899
daysLeftInYear
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   900
    "return the number of days left in the year of the receiver"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   901
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   902
    ^ Date daysInYear:(self year) - self day
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   903
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   904
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   905
     Date today daysLeftInYear
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   906
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   907
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   908
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   909
dayInWeek
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   910
    "return the week-day of the receiver - 1 for monday, 7 for sunday"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   911
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   912
    ^ (1 "know, that 1st Jan 1901 was a tuesday"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   913
      + self asDays) \\ 7 + 1
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   914
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   915
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   916
     Date today dayInWeek
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   917
     (Date day:15 month:4 year:1959) dayInWeek
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   918
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   919
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   920
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   921
dayName
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   922
    "return the week-day of the receiver as a string.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   923
     The returned string depends on the language setting.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   924
     Expect things like 'monday', 'tuesday' ...
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   925
     Obsolete:
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   926
	use #weekday for ST-80 compatibility"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   927
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   928
    ^ self weekday
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   929
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   930
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   931
weekday
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   932
    "return the week-day of the receiver as a string.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   933
     The returned string depends on the language setting.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   934
     Expect things like 'monday', 'tuesday' ...
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   935
     For ST-80 compatibility"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   936
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   937
    ^ self class nameOfDay:(self dayInWeek)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   938
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   939
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   940
     Date today weekday
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   941
     (Date day:15 month:4 year:1959) weekday
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   942
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   943
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   944
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   945
abbreviatedDayName
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   946
    "return the short week-day of the receiver as a string.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   947
     The returned string depends on the language setting.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   948
     Expect things like 'mon', 'tue' ..."
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   949
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   950
    ^ self class abbreviatedNameOfDay:(self dayInWeek)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   951
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   952
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   953
     Date today abbreviatedDayName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   954
     (Date day:15 month:4 year:1959) abbreviatedDayName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   955
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   956
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   957
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   958
monthIndex
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   959
    "return the index of the month (e.g. Feb.=2).
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   960
     Same as month; for ST-80 compatibility."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   961
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   962
    ^ self month  
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   963
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   964
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   965
monthName
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   966
    "return the month of the receiver as a string.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   967
     The returned string depends on the language setting.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   968
     Expect things like 'january', 'february' ..."
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   969
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   970
    ^ self class nameOfMonth:(self month)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   971
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   972
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   973
     Date today monthName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   974
     (Date day:15 month:4 year:1959) monthName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   975
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   976
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   977
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   978
abbreviatedMonthName
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   979
    "return the month of the receiver as a string.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   980
     The returned string depends on the language setting.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   981
     Expect things like 'jan', 'feb' ..."
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   982
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   983
    ^ self class abbreviatedNameOfMonth:(self month)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   984
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   985
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   986
     Date today abbreviatedMonthName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   987
     (Date day:15 month:4 year:1959) abbreviatedMonthName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   988
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   989
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   990
a27a279701f8 Initial revision
claus
parents:
diff changeset
   991
!Date methodsFor:'comparing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   992
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   993
< aDate
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   994
    "return true, if the date represented by the receiver
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   995
     is before the argument, aDate"
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
   996
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   997
    (aDate isMemberOf:Date) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   998
	^ dateEncoding < aDate dateEncoding
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
   999
    ].
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
  1000
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1001
    "the argument must understand year, month and day to be
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1002
     comparable, whatever it is"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1003
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1004
    ^ dateEncoding < (Date encodeYear:aDate year
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1005
				month:aDate month
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1006
				  day:aDate day)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1007
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1008
    "Date today < (Date day:24 month:12 year:2000)"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1009
    "Date today < (Date day:24 month:12 year:1900)"
29
b6577a9f8cee *** empty log message ***
claus
parents: 10
diff changeset
  1010
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1011
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1012
> aDate
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1013
    "return true, if the date represented by the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1014
     is after the argument, aDate"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1015
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1016
    (aDate isMemberOf:Date) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1017
	^ dateEncoding > aDate dateEncoding
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1018
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1019
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1020
    "the argument must understand year, month and day to be
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1021
     comparable, whatever it is"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1022
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1023
    ^ dateEncoding > (Date encodeYear:aDate year
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1024
				month:aDate month
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1025
				  day:aDate day)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1026
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1027
    "Date today > (Date day:24 month:12 year:2000)"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1028
    "Date today > (Date day:24 month:12 year:1900)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1029
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1030
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1031
= aDate
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1032
    "return true, if the date represented by the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1033
     is the same as the one represented by argument, aDate"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1034
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1035
    (aDate isMemberOf:Date) ifFalse:[^ false].
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1036
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1037
    ^ dateEncoding = aDate dateEncoding
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1038
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1039
    "the argument must understand year, month and day to be
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1040
     comparable, whatever it is"
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1041
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1042
"
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1043
    ^ dateEncoding = (Date encodeYear:aDate year
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1044
				month:aDate month
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1045
				  day:aDate day)
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
  1046
"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1047
    "Date today = ((Date today plusDays:7) minusDays:7)"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1048
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1049
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1050
hash
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1051
    "return an integer useful for hashing on dates"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1052
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1053
    ^ dateEncoding
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1054
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1055
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1056
!Date methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1057
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1058
storeOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1059
    "append a representation to aStream, from which the receiver
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1060
     can be reconstructed"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1061
333
claus
parents: 328
diff changeset
  1062
    aStream nextPutAll:'('; nextPutAll:'Date day:'.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1063
    self day printOn:aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1064
    aStream nextPutAll:' month:'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1065
    self month printOn:aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1066
    aStream nextPutAll:' year:'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1067
    self year printOn:aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1068
    aStream nextPutAll:')'
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1069
333
claus
parents: 328
diff changeset
  1070
    "
claus
parents: 328
diff changeset
  1071
     Date today storeOn:Transcript
claus
parents: 328
diff changeset
  1072
    "
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1073
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1074
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1075
printOn:aStream
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1076
    "append a printed representation of the receiver to aStream"
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1077
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1078
    self day printOn:aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1079
    aStream nextPutAll:'-'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1080
    (Date abbreviatedNameOfMonth:self month) printOn:aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1081
    aStream nextPutAll:'-'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 29
diff changeset
  1082
    self year printOn:aStream
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1083
333
claus
parents: 328
diff changeset
  1084
    "
claus
parents: 328
diff changeset
  1085
     Date today printOn:Transcript
claus
parents: 328
diff changeset
  1086
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1087
    "Date today printNL"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1088
! !