SharedQueue.st
author Claus Gittinger <cg@exept.de>
Sun, 05 Jan 1997 21:23:36 +0100
changeset 469 9b4318b56d9d
parent 396 88bd6136ee67
child 485 fe9c2ff10461
permissions -rw-r--r--
commentary
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     1
"
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
68
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
     3
	      All Rights Reserved
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     4
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
1cf8d1747859 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    11
"
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    12
6
claus
parents: 3
diff changeset
    13
Queue subclass:#SharedQueue
156
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
    14
	instanceVariableNames:'accessProtect dataAvailable spaceAvailable'
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
    15
	classVariableNames:''
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
    16
	poolDictionaries:''
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
    17
	category:'Kernel-Processes'
141
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
    18
!
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    19
469
9b4318b56d9d commentary
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
    20
!SharedQueue class methodsFor:'documentation'!
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    21
30
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    22
copyright
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    23
"
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    24
 COPYRIGHT (c) 1993 by Claus Gittinger
68
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    25
	      All Rights Reserved
30
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    26
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    27
 This software is furnished under a license and may be used
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    28
 only in accordance with the terms of that license and with the
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    30
 be provided or otherwise made available to, or used by, any
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    31
 other person.  No title to or ownership of the software is
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    32
 hereby transferred.
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    33
"
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    34
!
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    35
30
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    36
documentation
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    37
"
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    38
    SharedQueues provide a safe mechanism for processes to communicate.
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    39
    They are basically Queues, with added secure access to the internals,
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    40
    allowing use from multiple processes (i.e. the access methods use
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    41
    critical regions to protect against confusion due to a process
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    42
    switch within a modification).
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    43
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    44
    Also, sharedQueues can be used for synchronization, since a reading
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    45
    process will be blocked when attempting to read an empty queue, while
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    46
    a writer will be blocked when attempting to write into a full queue.
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    47
    For nonBlocking read, use #isEmpty; for nonBlocking write, use #isFull.
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    48
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    49
    See samples in doc/coding.
251
58fc29adb012 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 156
diff changeset
    50
257
759055770356 documentation
Claus Gittinger <cg@exept.de>
parents: 251
diff changeset
    51
    [author:]
759055770356 documentation
Claus Gittinger <cg@exept.de>
parents: 251
diff changeset
    52
        Claus Gittinger
759055770356 documentation
Claus Gittinger <cg@exept.de>
parents: 251
diff changeset
    53
251
58fc29adb012 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 156
diff changeset
    54
    [see also:]
58fc29adb012 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 156
diff changeset
    55
        Semaphore
58fc29adb012 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 156
diff changeset
    56
        Process
469
9b4318b56d9d commentary
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
    57
        CodingExamples::SharedQueueExamples
30
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    58
"
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    59
! !
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    60
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    61
!SharedQueue methodsFor:'accessing'!
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    62
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    63
next
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    64
    "return the next value in the queue; if it its empty, wait 'til
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    65
     something is put into the receiver.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    66
     When the datum has been removed, signal space-availability to
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    67
     writers"
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    68
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    69
    |value ok|
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    70
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    71
    ok := false.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    72
    [ok] whileFalse:[
68
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    73
	[tally == 0] whileTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    74
	    dataAvailable wait
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    75
	].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    76
	accessProtect critical:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    77
	    "
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    78
	     this check is needed, since another process may
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    79
	     have read the value in the meantime ...
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    80
	    "
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    81
	    tally == 0 ifFalse:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    82
		value := super next.
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    83
		tally == (contentsArray size - 1) ifTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    84
		    spaceAvailable signal
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    85
		].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    86
		ok := true
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    87
	    ]
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    88
	]
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    89
    ].
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    90
    ^ value
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    91
!
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    92
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    93
nextPut:anObject
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    94
    "enter anObject into the queue; wait for available space, if
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    95
     the queue is full. After the put, signal availablity of a datum
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    96
     to readers."
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    97
1
claus
parents: 0
diff changeset
    98
    |ok|
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    99
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   100
    ok := false.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   101
    [ok] whileFalse:[
68
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   102
	[tally == contentsArray size] whileTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   103
	    spaceAvailable wait
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   104
	].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   105
	accessProtect critical:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   106
	    tally == contentsArray size ifFalse:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   107
		super nextPut:anObject.
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   108
		tally == 1 ifTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   109
		    dataAvailable signal
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   110
		].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   111
		ok := true
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   112
	    ]
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   113
	]
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   114
    ].
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   115
    ^ anObject
156
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   116
!
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   117
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   118
readSemaphore
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   119
    "return the semaphore which is signalled when data is available
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   120
     for reading."
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   121
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   122
    ^ dataAvailable
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   123
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   124
    "Modified: 16.12.1995 / 13:47:11 / cg"
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   125
!
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   126
396
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   127
removeLast
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   128
    "return the last value in the queue; if it its empty, wait 'til
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   129
     something is put into the receiver.
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   130
     When the datum has been removed, signal space-availability to
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   131
     writers"
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   132
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   133
    |value ok|
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   134
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   135
    ok := false.
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   136
    [ok] whileFalse:[
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   137
        [tally == 0] whileTrue:[
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   138
            dataAvailable wait
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   139
        ].
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   140
        accessProtect critical:[
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   141
            "
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   142
             this check is needed, since another process may
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   143
             have read the value in the meantime ...
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   144
            "
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   145
            tally == 0 ifFalse:[
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   146
                value := super removeLast.
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   147
                tally == (contentsArray size - 1) ifTrue:[
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   148
                    spaceAvailable signal
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   149
                ].
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   150
                ok := true
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   151
            ]
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   152
        ]
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   153
    ].
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   154
    ^ value
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   155
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   156
    "Created: 22.6.1996 / 18:50:12 / cg"
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   157
!
88bd6136ee67 added #removeLast
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   158
156
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   159
writeSemaphore
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   160
    "return the semaphore which is signalled when the queue has space
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   161
     for writing."
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   162
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   163
    ^ spaceAvailable
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   164
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   165
    "Modified: 16.12.1995 / 13:47:07 / cg"
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   166
! !
141
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   167
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   168
!SharedQueue methodsFor:'initialization'!
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   169
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   170
init:size
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   171
    "initialize the receiver for size entries"
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   172
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   173
    super init:size.
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   174
    accessProtect := Semaphore forMutualExclusion.
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   175
    dataAvailable := Semaphore new.
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   176
    spaceAvailable := Semaphore new
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   177
! !
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   178
469
9b4318b56d9d commentary
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   179
!SharedQueue class methodsFor:'documentation'!
141
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   180
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   181
version
469
9b4318b56d9d commentary
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   182
    ^ '$Header: /cvs/stx/stx/libbasic2/SharedQueue.st,v 1.17 1997-01-05 20:23:36 cg Exp $'
141
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   183
! !