SharedQueue.st
author Claus Gittinger <cg@exept.de>
Sat, 16 Dec 1995 13:47:44 +0100
changeset 156 109b1c9342b2
parent 141 2804943fc6f0
child 251 58fc29adb012
permissions -rw-r--r--
access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
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
30
f34b335ac2d7 *** empty log message ***
claus
parents: 14
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.
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    50
"
f34b335ac2d7 *** empty log message ***
claus
parents: 14
diff changeset
    51
! !
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    52
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    53
!SharedQueue methodsFor:'accessing'!
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    54
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    55
next
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    56
    "return the next value in the queue; if it its empty, wait 'til
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    57
     something is put into the receiver.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    58
     When the datum has been removed, signal space-availability to
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    59
     writers"
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    60
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    61
    |value ok|
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    62
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    63
    ok := false.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    64
    [ok] whileFalse:[
68
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    65
	[tally == 0] whileTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    66
	    dataAvailable wait
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    67
	].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    68
	accessProtect critical:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    69
	    "
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    70
	     this check is needed, since another process may
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    71
	     have read the value in the meantime ...
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    72
	    "
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    73
	    tally == 0 ifFalse:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    74
		value := super next.
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    75
		tally == (contentsArray size - 1) ifTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    76
		    spaceAvailable signal
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    77
		].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    78
		ok := true
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    79
	    ]
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    80
	]
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    81
    ].
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    82
    ^ value
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    83
!
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    84
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    85
nextPut:anObject
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    86
    "enter anObject into the queue; wait for available space, if
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    87
     the queue is full. After the put, signal availablity of a datum
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    88
     to readers."
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    89
1
claus
parents: 0
diff changeset
    90
    |ok|
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    91
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    92
    ok := false.
1cf8d1747859 Initial revision
claus
parents:
diff changeset
    93
    [ok] whileFalse:[
68
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    94
	[tally == contentsArray size] whileTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    95
	    spaceAvailable wait
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    96
	].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    97
	accessProtect critical:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    98
	    tally == contentsArray size ifFalse:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
    99
		super nextPut:anObject.
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   100
		tally == 1 ifTrue:[
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   101
		    dataAvailable signal
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   102
		].
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   103
		ok := true
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   104
	    ]
6650e0d50a1a *** empty log message ***
claus
parents: 34
diff changeset
   105
	]
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   106
    ].
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   107
    ^ 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
   108
!
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   109
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   110
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
   111
    "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
   112
     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
   113
109b1c9342b2 access methods for the internal semaphores added (maybe useful when waiting for multiple queues)
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   114
    ^ 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
   115
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
    "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
   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
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
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
   120
    "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
   121
     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
   122
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
    ^ 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
   124
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
    "Modified: 16.12.1995 / 13:47:07 / cg"
0
1cf8d1747859 Initial revision
claus
parents:
diff changeset
   126
! !
141
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   127
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   128
!SharedQueue methodsFor:'initialization'!
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   129
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   130
init:size
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   131
    "initialize the receiver for size entries"
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   132
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   133
    super init:size.
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   134
    accessProtect := Semaphore forMutualExclusion.
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   135
    dataAvailable := Semaphore new.
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   136
    spaceAvailable := Semaphore new
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   137
! !
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   138
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   139
!SharedQueue class methodsFor:'documentation'!
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   140
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   141
version
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
   142
    ^ '$Header: /cvs/stx/stx/libbasic2/SharedQueue.st,v 1.13 1995-12-16 12:47:44 cg Exp $'
141
2804943fc6f0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   143
! !