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