AbstractTime.st
author Claus Gittinger <cg@exept.de>
Sat, 11 Nov 1995 15:28:26 +0100
changeset 528 a083413dfbe8
parent 418 d49a94b08368
child 699 12f456343eea
permissions -rw-r--r--
converted version methods from comment-only to returning-a-string
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     1
"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     3
	      All Rights Reserved
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     4
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    11
"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    12
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    13
'From Smalltalk/X, Version:2.10.4 on 7-feb-1995 at 11:53:03 pm'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    14
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    15
Magnitude subclass:#AbstractTime
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    16
	 instanceVariableNames:''
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    17
	 classVariableNames:''
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    18
	 poolDictionaries:''
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    19
	 category:'Magnitude-General'
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    20
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    21
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    22
!AbstractTime class methodsFor:'documentation'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    23
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    24
copyright
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    25
"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    26
 COPYRIGHT (c) 1995 by Claus Gittinger
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    27
	      All Rights Reserved
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    28
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    29
 This software is furnished under a license and may be used
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    30
 only in accordance with the terms of that license and with the
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    32
 be provided or otherwise made available to, or used by, any
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    33
 other person.  No title to or ownership of the software is
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    34
 hereby transferred.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    35
"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    36
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    37
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    38
documentation
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    39
"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    40
    This is an abstract class; there are no instances in the system.
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    41
    It is meant as a home for methods common to time handling classes.
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    42
"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    43
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    44
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    45
version
528
a083413dfbe8 converted version methods from comment-only to returning-a-string
Claus Gittinger <cg@exept.de>
parents: 418
diff changeset
    46
    ^ '$Header: /cvs/stx/stx/libbasic/AbstractTime.st,v 1.7 1995-11-11 14:26:24 cg Exp $'
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    47
! !
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    48
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    49
!AbstractTime class methodsFor:'instance creation'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    50
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    51
now
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    52
    "return an instance of myself representing this moment"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    53
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    54
    ^ self basicNew fromOSTime:(OperatingSystem getTimeParts)
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    55
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    56
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    57
     AbsoluteTime now   
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    58
     Time now   
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    59
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    60
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    61
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    62
fromSeconds:seconds
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    63
    "return an instance that is constructed from seconds.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    64
     This method is only allowed for second values as returned by
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    65
     getSeconds, possibly adding/subtracting to that. Never
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    66
     depend on any specific interpretation of the seconds."
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    67
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    68
   ^ self basicNew setSeconds:seconds
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    69
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    70
    "
360
claus
parents: 275
diff changeset
    71
     Time fromSeconds:0             should return midnight
claus
parents: 275
diff changeset
    72
     AbsoluteTime fromSeconds:0     on UNIX: returns 1st. Jan 1970
claus
parents: 275
diff changeset
    73
				    on others: dont know
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    74
    "
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    75
!
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    76
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    77
fromOSTime:osTime
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    78
    "return a time, representing the time given by the operatingSystem time.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    79
     Not meant for public use."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
    80
418
claus
parents: 384
diff changeset
    81
    |low hi|
claus
parents: 384
diff changeset
    82
claus
parents: 384
diff changeset
    83
    "now migrating to support LargeInteger OS-time handles ...
claus
parents: 384
diff changeset
    84
     ... in the meantime, support both formats."
claus
parents: 384
diff changeset
    85
claus
parents: 384
diff changeset
    86
    (osTime isMemberOf:Array) ifTrue:[
claus
parents: 384
diff changeset
    87
	low := osTime at:1.
claus
parents: 384
diff changeset
    88
	hi :=  osTime at:2.
claus
parents: 384
diff changeset
    89
    ] ifFalse:[
claus
parents: 384
diff changeset
    90
	low := osTime bitAnd:16rFFFF.
claus
parents: 384
diff changeset
    91
	hi := (osTime bitShift:-16) bitAnd:16rFFFF.
claus
parents: 384
diff changeset
    92
    ].
claus
parents: 384
diff changeset
    93
    ^ self basicNew fromOSTimeLow:low and:hi
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    94
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    95
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    96
fromOSTimeLow:osTimeLow and:osTimeHigh
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    97
    "return a time, representing the time given by the operatingSystem time.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    98
     Not meant for public use."
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
    99
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   100
    ^ self basicNew fromOSTimeLow:osTimeLow and:osTimeHigh
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   101
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   102
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   103
dateAndTimeNow
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   104
    "return an array filled with date and time"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   105
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   106
    ^ Array with:(Date today) with:(Time now)
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   107
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   108
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   109
     Time dateAndTimeNow
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   110
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   111
! !
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   112
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   113
!AbstractTime class methodsFor:'obsolete'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   114
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   115
fromUnixTimeLow:low and:hi
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   116
    "return an instance of myself, given the unix time.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   117
     Internal interface - not for public use."
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   118
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   119
    ^ self fromOSTimeLow:low and:hi
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   120
! !
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   121
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   122
!AbstractTime methodsFor:'private'!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   123
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   124
fromOSTime:timeParts
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   125
    "set my time, from operatingSystems time parts"
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   126
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   127
    ^ self fromOSTimeLow:(timeParts at:1) and:(timeParts at:2)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   128
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   129
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   130
fromOSTimeTimeLow:lowTime and:hiTime
360
claus
parents: 275
diff changeset
   131
    "set my time, from operatingSystems time parts.
claus
parents: 275
diff changeset
   132
     Since I am abstract (not knowing how the time is actually
claus
parents: 275
diff changeset
   133
     represented), this must be done by a concrete class."
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   134
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   135
    ^ self subclassResponsibility
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   136
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   137
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   138
setSeconds:secs
360
claus
parents: 275
diff changeset
   139
    "set the seconds.
claus
parents: 275
diff changeset
   140
     Since I am abstract (not knowing how the time is actually
claus
parents: 275
diff changeset
   141
     represented), this must be done by a concrete class."
claus
parents: 275
diff changeset
   142
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   143
    ^ self subclassResponsibility
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   144
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   145
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   146
getSeconds
360
claus
parents: 275
diff changeset
   147
    "get the seconds.
claus
parents: 275
diff changeset
   148
     Since I am abstract (not knowing how the time is actually
claus
parents: 275
diff changeset
   149
     represented), this must be done by a concrete class."
claus
parents: 275
diff changeset
   150
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   151
    ^ self subclassResponsibility
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   152
! !
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   153
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   154
!AbstractTime methodsFor:'accessing'!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   155
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   156
hourInDay
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   157
    "return the hours (0..23)"
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   158
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   159
    ^ self hours
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   160
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   161
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   162
     AbsoluteTime now hourInDay 
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   163
     Time now hourInDay 
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   164
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   165
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   166
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   167
minuteInDay
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   168
    "return the minutes (0..59)"
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   169
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   170
    ^ self minutes.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   171
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   172
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   173
     AbsoluteTime now minuteInDay 
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   174
     Time now minuteInDay 
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   175
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   176
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   177
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   178
secondDay
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   179
    "return the seconds (0..59)"
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   180
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   181
    ^ self seconds
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   182
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   183
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   184
     AbsoluteTime now secondInDay 
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   185
     Time now seconds 
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   186
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   187
! !
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   188
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   189
!AbstractTime methodsFor:'arithmetic'!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   190
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   191
- aTime
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   192
    "return the delta in seconds between 2 times."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   193
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   194
    ^ self getSeconds - (aTime getSeconds)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   195
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   196
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   197
     |t1 t2|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   198
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   199
     t1 := AbsoluteTime now.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   200
     (Delay forSeconds:5) wait.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   201
     t2 := AbsoluteTime now.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   202
     'seconds passed: ' print. (t2 - t1) printNL.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   203
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   204
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   205
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   206
addSeconds:numberOfSeconds
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   207
    "return a new instance of myself, numberOfSeconds afterwards."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   208
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   209
    ^ self species basicNew setSeconds:(self getSeconds + numberOfSeconds)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   210
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   211
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   212
     |t|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   213
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   214
     t := AbsoluteTime now. t printNL. (t addSeconds:50) printNL.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   215
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   216
     t := Time now. t printNL. (t addSeconds:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   217
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   218
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   219
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   220
addMinutes:numberOfMinutes
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   221
    "return a new instance of myself, numberOfMinutes afterwards."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   222
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   223
    ^ self addSeconds:(numberOfMinutes * 60)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   224
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   225
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   226
     |t|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   227
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   228
     t := AbsoluteTime now. t printNL. (t addMinutes:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   229
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   230
     t := Time now. t printNL. (t addMinutes:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   231
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   232
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   233
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   234
addHours:numberOfHours
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   235
    "return a new instance of myself, numberOfHours afterwards."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   236
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   237
    ^ self addSeconds:(numberOfHours * (60 * 60))
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   238
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   239
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   240
     |t|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   241
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   242
     t := AbsoluteTime now.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   243
     t printNL.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   244
     (t addHours:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   245
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   246
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   247
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   248
subtractSeconds:numberOfSeconds
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   249
    "return a new instance of myself, numberOfSeconds before."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   250
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   251
    ^ self species basicNew setSeconds:(self getSeconds - numberOfSeconds)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   252
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   253
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   254
     |t|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   255
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   256
     t := AbsoluteTime now.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   257
     t printNL.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   258
     (t subtractSeconds:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   259
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   260
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   261
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   262
subtractMinutes:numberOfMinutes
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   263
    "return a new instance of myself, numberOfMinutes before."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   264
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   265
    ^ self subtractSeconds:(numberOfMinutes * 60)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   266
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   267
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   268
     |t|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   269
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   270
     t := AbsoluteTime now.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   271
     t printNL.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   272
     (t subtractMinutes:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   273
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   274
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   276
subtractHours:numberOfHours
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   277
    "return a new instance of myself, numberOfHours before."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   278
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   279
    ^ self subtractSeconds:(numberOfHours * (60 * 60))
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   280
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   281
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   282
     |t|
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   283
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   284
     t := AbsoluteTime now.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   285
     t printNL.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   286
     (t subtractHours:50) printNL
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   287
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   288
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   289
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   290
addTime:timeAmount
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   291
    "return a new instance of myself, timeAmount seconds afterwards.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   292
     AddTime is a bad name - it does not add a time, but expects
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   293
     a number. Use any of addSeconds/addHours etc."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   294
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   295
    ^ self species basicNew setSeconds:(self getSeconds + timeAmount)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   296
!
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   297
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   298
subtractTime:timeAmount
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   299
    "return a new instance opf myself, timeAmount seconds before myself.
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   300
     SubtractTime is a bad name - it does not subtract a time, but expects
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   301
     a number. Use any of subtractSeconds/subtractHours etc."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   302
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   303
    ^ self species basicNew setSeconds:(self getSeconds - timeAmount)
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   304
! !
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   305
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   306
!AbstractTime class methodsFor:'queries'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   307
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   308
secondClock
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   309
    "return seconds of now - for GNU-ST compatibility"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   310
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   311
    ^ OperatingSystem getTime
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   312
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   313
    "
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   314
     AbstractTime secondClock    
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   315
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   316
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   317
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   318
millisecondClockValue
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   319
    "return the millisecond clock - since this one overruns
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   320
     regularly, use the value only for short timing deltas.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   321
     Also remember that it wraps when compares these values."
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   322
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   323
    ^ OperatingSystem getMillisecondTime.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   324
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   325
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   326
     Time millisecondClockValue 
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   327
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   328
! !
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   329
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   330
!AbstractTime class methodsFor:'timing evaluations'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   331
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   332
secondsToRun:aBlock
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   333
    "evaluate the argument, aBlock; return the number of seconds it took"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   334
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   335
    |startTime endTime|
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   336
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   337
    startTime := self secondClock.
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   338
    aBlock value.
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   339
    endTime := self secondClock.
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   340
    ^ endTime - startTime
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   341
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   342
    "
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   343
     Time secondsToRun:[1000 factorial]  
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   344
    "
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   345
!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   346
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   347
millisecondsToRun:aBlock
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   348
    "evaluate the argument, aBlock; return the number of milliseconds it took"
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   349
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   350
    |startTime endTime|
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   351
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   352
    startTime := self millisecondClockValue.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   353
    aBlock value.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   354
    endTime := self millisecondClockValue.
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   355
    ^ endTime - startTime
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   356
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   357
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   358
     Time millisecondsToRun:[100 factorial]  
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   359
    "
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   360
! !
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   361
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   362
!AbstractTime class methodsFor:'ST-80 compatibility'!
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   363
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   364
totalSeconds
275
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   365
    "returns an internal second clock. Dont interpret the returned
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   366
     value - if at all, use it to compute time deltas, by subtracting
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   367
     returned values."
a76029ddaa98 *** empty log message ***
claus
parents: 240
diff changeset
   368
240
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   369
    ^ self secondClock
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   370
! !
f5ff68fffb92 Initial revision
claus
parents:
diff changeset
   371