Promise.st
author Claus Gittinger <cg@exept.de>
Sat, 02 May 2020 21:40:13 +0200
changeset 5476 7355a4b11cb6
parent 5204 2aed622d96ee
permissions -rw-r--r--
#FEATURE by cg class: Socket class added: #newTCPclientToHost:port:domain:domainOrder:withTimeout: changed: #newTCPclientToHost:port:domain:withTimeout:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5202
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
     1
"{ Encoding: utf8 }"
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
     2
75
claus
parents: 71
diff changeset
     3
"
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
     4
 COPYRIGHT (c) 1993 by Claus Gittinger
75
claus
parents: 71
diff changeset
     5
	      All Rights Reserved
claus
parents: 71
diff changeset
     6
claus
parents: 71
diff changeset
     7
 This software is furnished under a license and may be used
claus
parents: 71
diff changeset
     8
 only in accordance with the terms of that license and with the
claus
parents: 71
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
claus
parents: 71
diff changeset
    10
 be provided or otherwise made available to, or used by, any
claus
parents: 71
diff changeset
    11
 other person.  No title to or ownership of the software is
claus
parents: 71
diff changeset
    12
 hereby transferred.
claus
parents: 71
diff changeset
    13
"
4031
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    14
"{ Package: 'stx:libbasic2' }"
75
claus
parents: 71
diff changeset
    15
4031
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    16
"{ NameSpace: Smalltalk }"
71
claus
parents:
diff changeset
    17
claus
parents:
diff changeset
    18
Object subclass:#Promise
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    19
	instanceVariableNames:'value valueAvailable exception'
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    20
	classVariableNames:''
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    21
	poolDictionaries:''
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    22
	category:'Kernel-Processes'
71
claus
parents:
diff changeset
    23
!
claus
parents:
diff changeset
    24
75
claus
parents: 71
diff changeset
    25
!Promise class methodsFor:'documentation'!
claus
parents: 71
diff changeset
    26
claus
parents: 71
diff changeset
    27
copyright
claus
parents: 71
diff changeset
    28
"
claus
parents: 71
diff changeset
    29
 COPYRIGHT (c) 1993 by Claus Gittinger
claus
parents: 71
diff changeset
    30
	      All Rights Reserved
claus
parents: 71
diff changeset
    31
claus
parents: 71
diff changeset
    32
 This software is furnished under a license and may be used
claus
parents: 71
diff changeset
    33
 only in accordance with the terms of that license and with the
claus
parents: 71
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
claus
parents: 71
diff changeset
    35
 be provided or otherwise made available to, or used by, any
claus
parents: 71
diff changeset
    36
 other person.  No title to or ownership of the software is
claus
parents: 71
diff changeset
    37
 hereby transferred.
claus
parents: 71
diff changeset
    38
"
claus
parents: 71
diff changeset
    39
!
claus
parents: 71
diff changeset
    40
claus
parents: 71
diff changeset
    41
documentation
claus
parents: 71
diff changeset
    42
"
claus
parents: 71
diff changeset
    43
    When created, a promise will start to evaluate its block in the background,
claus
parents: 71
diff changeset
    44
    and promise to deliver the value of this computation, when asked
5204
2aed622d96ee #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5202
diff changeset
    45
    for it via #value. 
2aed622d96ee #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5202
diff changeset
    46
    If an exception happens druing the block evaluate,
2aed622d96ee #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5202
diff changeset
    47
    it will be delivered  to the value-consumer.
2aed622d96ee #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5202
diff changeset
    48
2aed622d96ee #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5202
diff changeset
    49
    Promises can be used for background computations,
75
claus
parents: 71
diff changeset
    50
    which automatically block the user of the result when that result is needed,
claus
parents: 71
diff changeset
    51
    unless the computation finished in the meanwhile.
claus
parents: 71
diff changeset
    52
4230
5009e3cfe732 #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4031
diff changeset
    53
    See also Block>>promise and Lazy/Future in libbasic2.
75
claus
parents: 71
diff changeset
    54
"
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    55
!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    56
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    57
examples
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    58
"
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    59
     |p|
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    60
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    61
     p := [10000 factorial] promise.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    62
     Transcript showCR:'doing something else'.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    63
     p value   
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    64
"
75
claus
parents: 71
diff changeset
    65
! !
claus
parents: 71
diff changeset
    66
71
claus
parents:
diff changeset
    67
!Promise class methodsFor:'instance creation'!
claus
parents:
diff changeset
    68
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    69
new
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    70
    ^ self basicNew initialize 
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    71
!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
    72
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    73
value:aBlock
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    74
    "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
    75
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    76
    ^ self new value:aBlock priority:Processor activePriority 
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    77
!
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
    78
71
claus
parents:
diff changeset
    79
value:aBlock priority:aPrio
claus
parents:
diff changeset
    80
    "create and return a Promise to evaluate aBlock at some priority"
claus
parents:
diff changeset
    81
claus
parents:
diff changeset
    82
    ^ self new value:aBlock priority:aPrio
claus
parents:
diff changeset
    83
! !
claus
parents:
diff changeset
    84
claus
parents:
diff changeset
    85
!Promise methodsFor:'accessing'!
claus
parents:
diff changeset
    86
claus
parents:
diff changeset
    87
value
claus
parents:
diff changeset
    88
    "return the value of the promise. 
claus
parents:
diff changeset
    89
     If the evaluation process has not yet finished, wait for it.
claus
parents:
diff changeset
    90
     Otherwise return the value immediately.
4031
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    91
     Any exception which occurred during the evaluation is forwarded to the
71
claus
parents:
diff changeset
    92
     requestor of the value here."
claus
parents:
diff changeset
    93
claus
parents:
diff changeset
    94
    valueAvailable waitUncounted.
claus
parents:
diff changeset
    95
    exception notNil ifTrue:[
4031
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    96
        "/
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    97
        "/ an exception occurred while evaluating the promise.
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    98
        "/ This exception is remembered and raised here, when the
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
    99
        "/ value is asked for.
5202
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   100
        "/ reRaise leaves the suspendedContext untouched.
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   101
        exception reRaise
71
claus
parents:
diff changeset
   102
    ].
claus
parents:
diff changeset
   103
    ^ value
claus
parents:
diff changeset
   104
!
claus
parents:
diff changeset
   105
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   106
value:anObject
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   107
    "fake value arrived"
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   108
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   109
    value := anObject.
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   110
    valueAvailable signal.
4337
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   111
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   112
    "Modified: / 20-02-2017 / 10:28:23 / stefan"
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   113
! !
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   114
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   115
!Promise methodsFor:'initialization'!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   116
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   117
initialize
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   118
    "setup"
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   119
4503
752f99d23094 #TUNING by stefan
Stefan Vogel <sv@exept.de>
parents: 4366
diff changeset
   120
    valueAvailable := EventSemaphore name:'Promise.valueAvailable'.
4337
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   121
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   122
    "Modified: / 20-02-2017 / 10:37:40 / stefan"
1488
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   123
!
6b394aed47f7 *** empty log message ***
penk
parents: 1307
diff changeset
   124
71
claus
parents:
diff changeset
   125
value:aBlock priority:aPrio
claus
parents:
diff changeset
   126
    "setup and start the evaluation process."
claus
parents:
diff changeset
   127
claus
parents:
diff changeset
   128
    [
5202
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   129
        |top|
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   130
4337
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   131
        [
5202
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   132
            top := thisContext.
4337
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   133
            value := aBlock value.
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   134
        ] on:Error do:[:ex|
5202
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   135
            "/ in order to be able to reRaise the exception 
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   136
            "/ AND provide the original walkback,
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   137
            "/ we make a special copy here.
5e7ec026714d #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5200
diff changeset
   138
            exception := ex copyWithWalkbackUpTo:top.
4337
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   139
        ].
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   140
        valueAvailable signal.
71
claus
parents:
diff changeset
   141
    ] forkAt:aPrio
claus
parents:
diff changeset
   142
claus
parents:
diff changeset
   143
    "
claus
parents:
diff changeset
   144
     Promise value:[100 timesRepeat:[1000 factorial]] priority:7
claus
parents:
diff changeset
   145
    "
claus
parents:
diff changeset
   146
    "
claus
parents:
diff changeset
   147
     Promise value:[10 timesRepeat:[1000 factorial]. [self halt] value.] priority:7
claus
parents:
diff changeset
   148
    "
4337
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   149
167d0c973942 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4230
diff changeset
   150
    "Modified: / 20-02-2017 / 10:31:36 / stefan"
71
claus
parents:
diff changeset
   151
! !
claus
parents:
diff changeset
   152
claus
parents:
diff changeset
   153
!Promise methodsFor:'queries'!
claus
parents:
diff changeset
   154
claus
parents:
diff changeset
   155
hasValue
4366
b52f62b48580 #OTHER by mawalch
mawalch
parents: 4337
diff changeset
   156
    "return true, if the promise has a value available.
71
claus
parents:
diff changeset
   157
     (i.e. if sending #value to it would NOT block)"
claus
parents:
diff changeset
   158
claus
parents:
diff changeset
   159
    ^ valueAvailable wouldBlock not
4366
b52f62b48580 #OTHER by mawalch
mawalch
parents: 4337
diff changeset
   160
b52f62b48580 #OTHER by mawalch
mawalch
parents: 4337
diff changeset
   161
    "Modified (comment): / 17-05-2017 / 16:57:53 / mawalch"
71
claus
parents:
diff changeset
   162
! !
claus
parents:
diff changeset
   163
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   164
!Promise class methodsFor:'documentation'!
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   165
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   166
version
4031
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
   167
    ^ '$Header$'
5200
06e90979b15b #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 5199
diff changeset
   168
!
06e90979b15b #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 5199
diff changeset
   169
06e90979b15b #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 5199
diff changeset
   170
version_CVS
06e90979b15b #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 5199
diff changeset
   171
    ^ '$Header$'
1307
18bf29731638 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 485
diff changeset
   172
! !
4031
3077e1dbb704 #OTHER by mawalch
mawalch
parents: 1488
diff changeset
   173