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