Promise.st
author Claus Gittinger <cg@exept.de>
Thu, 09 Jun 2016 18:09:58 +0200
changeset 3934 3fc6968232c1
parent 1488 6b394aed47f7
child 4031 3077e1dbb704
permissions -rw-r--r--
class: exept_expecco_plugin class definition
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
75
claus
parents: 71
diff changeset
     1
"
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
75
claus
parents: 71
diff changeset
     3
	      All Rights Reserved
claus
parents: 71
diff changeset
     4
claus
parents: 71
diff changeset
     5
 This software is furnished under a license and may be used
claus
parents: 71
diff changeset
     6
 only in accordance with the terms of that license and with the
claus
parents: 71
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
claus
parents: 71
diff changeset
     8
 be provided or otherwise made available to, or used by, any
claus
parents: 71
diff changeset
     9
 other person.  No title to or ownership of the software is
claus
parents: 71
diff changeset
    10
 hereby transferred.
claus
parents: 71
diff changeset
    11
"
claus
parents: 71
diff changeset
    12
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    13
"{ Package: 'stx:libbasic2' }"
71
claus
parents:
diff changeset
    14
claus
parents:
diff changeset
    15
Object subclass:#Promise
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    16
	instanceVariableNames:'value valueAvailable exception'
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    17
	classVariableNames:''
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    18
	poolDictionaries:''
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    19
	category:'Kernel-Processes'
71
claus
parents:
diff changeset
    20
!
claus
parents:
diff changeset
    21
75
claus
parents: 71
diff changeset
    22
!Promise class methodsFor:'documentation'!
claus
parents: 71
diff changeset
    23
claus
parents: 71
diff changeset
    24
copyright
claus
parents: 71
diff changeset
    25
"
claus
parents: 71
diff changeset
    26
 COPYRIGHT (c) 1993 by Claus Gittinger
claus
parents: 71
diff changeset
    27
	      All Rights Reserved
claus
parents: 71
diff changeset
    28
claus
parents: 71
diff changeset
    29
 This software is furnished under a license and may be used
claus
parents: 71
diff changeset
    30
 only in accordance with the terms of that license and with the
claus
parents: 71
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
claus
parents: 71
diff changeset
    32
 be provided or otherwise made available to, or used by, any
claus
parents: 71
diff changeset
    33
 other person.  No title to or ownership of the software is
claus
parents: 71
diff changeset
    34
 hereby transferred.
claus
parents: 71
diff changeset
    35
"
claus
parents: 71
diff changeset
    36
!
claus
parents: 71
diff changeset
    37
claus
parents: 71
diff changeset
    38
documentation
claus
parents: 71
diff changeset
    39
"
claus
parents: 71
diff changeset
    40
    When created, a promise will start to evaluate its block in the background,
claus
parents: 71
diff changeset
    41
    and promise to deliver the value of this computation, when asked
claus
parents: 71
diff changeset
    42
    for it via #value. Promises can be used for background computations,
claus
parents: 71
diff changeset
    43
    which automatically block the user of the result when that result is needed,
claus
parents: 71
diff changeset
    44
    unless the computation finished in the meanwhile.
claus
parents: 71
diff changeset
    45
claus
parents: 71
diff changeset
    46
    See also Block>>promise and Lazy/Future in the goodies directory.
claus
parents: 71
diff changeset
    47
"
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    48
!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    49
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    50
examples
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    51
"
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    52
     |p|
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    53
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    54
     p := [10000 factorial] promise.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    55
     Transcript showCR:'doing something else'.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    56
     p value   
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    57
"
75
claus
parents: 71
diff changeset
    58
! !
claus
parents: 71
diff changeset
    59
71
claus
parents:
diff changeset
    60
!Promise class methodsFor:'instance creation'!
claus
parents:
diff changeset
    61
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    62
new
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    63
    ^ self basicNew initialize 
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    64
!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    65
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    66
value:aBlock
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    67
    "create and return a Promise to evaluate aBlock at the current priority"
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    68
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    69
    ^ self new value:aBlock priority:Processor activePriority 
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    70
!
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    71
71
claus
parents:
diff changeset
    72
value:aBlock priority:aPrio
claus
parents:
diff changeset
    73
    "create and return a Promise to evaluate aBlock at some priority"
claus
parents:
diff changeset
    74
claus
parents:
diff changeset
    75
    ^ self new value:aBlock priority:aPrio
claus
parents:
diff changeset
    76
! !
claus
parents:
diff changeset
    77
claus
parents:
diff changeset
    78
!Promise methodsFor:'accessing'!
claus
parents:
diff changeset
    79
claus
parents:
diff changeset
    80
value
claus
parents:
diff changeset
    81
    "return the value of the promise. 
claus
parents:
diff changeset
    82
     If the evaluation process has not yet finished, wait for it.
claus
parents:
diff changeset
    83
     Otherwise return the value immediately.
claus
parents:
diff changeset
    84
     Any exception which occured during the evaluation is forwarded to the
claus
parents:
diff changeset
    85
     requestor of the value here."
claus
parents:
diff changeset
    86
claus
parents:
diff changeset
    87
    valueAvailable waitUncounted.
claus
parents:
diff changeset
    88
    exception notNil ifTrue:[
claus
parents:
diff changeset
    89
	"/
claus
parents:
diff changeset
    90
	"/ an exception occured while evaluating the promise.
claus
parents:
diff changeset
    91
	"/ This exception is remembered and raised here, when the
claus
parents:
diff changeset
    92
	"/ value is asked for.
claus
parents:
diff changeset
    93
	"/
claus
parents:
diff changeset
    94
	exception raise
claus
parents:
diff changeset
    95
    ].
claus
parents:
diff changeset
    96
    ^ value
claus
parents:
diff changeset
    97
!
claus
parents:
diff changeset
    98
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    99
value:anObject
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   100
    "fake value arrived"
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   101
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   102
    value := anObject.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   103
    valueAvailable signal.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   104
    valueAvailable signalForAll.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   105
! !
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   106
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   107
!Promise methodsFor:'initialization'!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   108
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   109
initialize
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   110
    "setup"
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   111
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   112
    valueAvailable := (Semaphore new:0) name:'valueAvailable'.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   113
!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   114
71
claus
parents:
diff changeset
   115
value:aBlock priority:aPrio
claus
parents:
diff changeset
   116
    "setup and start the evaluation process."
claus
parents:
diff changeset
   117
485
fe9c2ff10461 added friendly semaphore names
Claus Gittinger <cg@exept.de>
parents: 189
diff changeset
   118
    valueAvailable := (Semaphore new:0) name:'valueAvailable'.
71
claus
parents:
diff changeset
   119
claus
parents:
diff changeset
   120
    [
189
c2e0b4299f9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   121
	ErrorSignal handle:[:ex |
71
claus
parents:
diff changeset
   122
	    exception := ex.
claus
parents:
diff changeset
   123
	    ex return.
claus
parents:
diff changeset
   124
	] do:[
claus
parents:
diff changeset
   125
	    value := aBlock value.
claus
parents:
diff changeset
   126
	].
claus
parents:
diff changeset
   127
	valueAvailable signal.
claus
parents:
diff changeset
   128
	valueAvailable signalForAll.
claus
parents:
diff changeset
   129
    ] forkAt:aPrio
claus
parents:
diff changeset
   130
claus
parents:
diff changeset
   131
    "
claus
parents:
diff changeset
   132
     Promise value:[100 timesRepeat:[1000 factorial]] priority:7
claus
parents:
diff changeset
   133
    "
claus
parents:
diff changeset
   134
    "
claus
parents:
diff changeset
   135
     Promise value:[10 timesRepeat:[1000 factorial]. [self halt] value.] priority:7
claus
parents:
diff changeset
   136
    "
claus
parents:
diff changeset
   137
! !
claus
parents:
diff changeset
   138
claus
parents:
diff changeset
   139
!Promise methodsFor:'queries'!
claus
parents:
diff changeset
   140
claus
parents:
diff changeset
   141
hasValue
claus
parents:
diff changeset
   142
    "return true, if the promise has a value avaliable.
claus
parents:
diff changeset
   143
     (i.e. if sending #value to it would NOT block)"
claus
parents:
diff changeset
   144
claus
parents:
diff changeset
   145
    ^ valueAvailable wouldBlock not
claus
parents:
diff changeset
   146
! !
claus
parents:
diff changeset
   147
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   148
!Promise class methodsFor:'documentation'!
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   149
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   150
version
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   151
    ^ '$Header: /cvs/stx/stx/libbasic2/Promise.st,v 1.9 2004-11-10 10:43:23 penk Exp $'
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   152
! !