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