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