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