|
|
@@ -135,38 +135,23 @@ Group {
|
|
|
sem.signal()
|
|
|
}
|
|
|
|
|
|
- let sendCountMutex = Mutex()
|
|
|
- var sendCount = 0
|
|
|
-
|
|
|
let parts = message.components(separatedBy: " ")
|
|
|
for part in parts {
|
|
|
var requestMessage = Echo_EchoRequest()
|
|
|
requestMessage.text = part
|
|
|
print("collect sending: " + part)
|
|
|
- try collectCall.send(requestMessage) {
|
|
|
- error in
|
|
|
- sendCountMutex.synchronize {
|
|
|
- sendCount = sendCount + 1
|
|
|
- }
|
|
|
- if let error = error {
|
|
|
+ try collectCall.send(requestMessage) { error in
|
|
|
+ if let error = error {
|
|
|
print("collect send error \(error)")
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- // don't close until all sends have completed
|
|
|
- var waiting = true
|
|
|
- while (waiting) {
|
|
|
- sendCountMutex.synchronize {
|
|
|
- if sendCount == parts.count {
|
|
|
- waiting = false
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
+ collectCall.waitForSendOperationsToFinish()
|
|
|
let responseMessage = try collectCall.closeAndReceive()
|
|
|
print("collect received: \(responseMessage.text)")
|
|
|
_ = sem.wait(timeout: DispatchTime.distantFuture)
|
|
|
if let statusCode = callResult?.statusCode {
|
|
|
- print("collect completed with status \(statusCode)")
|
|
|
+ print("collect completed with code \(statusCode)")
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -181,58 +166,37 @@ Group {
|
|
|
sem.signal()
|
|
|
}
|
|
|
|
|
|
- let responsesMutex = Mutex()
|
|
|
- var responses : [String] = []
|
|
|
-
|
|
|
- DispatchQueue.global().async {
|
|
|
- var running = true
|
|
|
- while running {
|
|
|
- do {
|
|
|
- let responseMessage = try updateCall.receive()
|
|
|
- responsesMutex.synchronize {
|
|
|
- responses.append("update received: \(responseMessage.text)")
|
|
|
- }
|
|
|
- } catch ClientError.endOfStream {
|
|
|
- running = false
|
|
|
- } catch (let error) {
|
|
|
- responsesMutex.synchronize {
|
|
|
- responses.append("update receive error: \(error)")
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
let parts = message.components(separatedBy: " ")
|
|
|
for part in parts {
|
|
|
var requestMessage = Echo_EchoRequest()
|
|
|
requestMessage.text = part
|
|
|
print("update sending: " + requestMessage.text)
|
|
|
- try updateCall.send(requestMessage) {
|
|
|
- error in
|
|
|
- if let error = error {
|
|
|
- print("update send error: \(error)")
|
|
|
+ try updateCall.send(requestMessage) { error in
|
|
|
+ if let error = error {
|
|
|
+ print("update send error \(error)")
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
- // don't close until last update is received
|
|
|
- var waiting = true
|
|
|
- while (waiting) {
|
|
|
- responsesMutex.synchronize {
|
|
|
- if responses.count == parts.count {
|
|
|
- waiting = false
|
|
|
- }
|
|
|
+ updateCall.waitForSendOperationsToFinish()
|
|
|
+
|
|
|
+ try updateCall.closeSend()
|
|
|
+
|
|
|
+ while true {
|
|
|
+ do {
|
|
|
+ let responseMessage = try updateCall.receive()
|
|
|
+ print("update received: \(responseMessage.text)")
|
|
|
+ } catch ClientError.endOfStream {
|
|
|
+ break
|
|
|
+ } catch (let error) {
|
|
|
+ print("update receive error: \(error)")
|
|
|
+ break
|
|
|
}
|
|
|
}
|
|
|
- try updateCall.closeSend()
|
|
|
|
|
|
_ = sem.wait(timeout: DispatchTime.distantFuture)
|
|
|
|
|
|
- for response in responses {
|
|
|
- print(response)
|
|
|
- }
|
|
|
if let statusCode = callResult?.statusCode {
|
|
|
- print("update completed with status \(statusCode)")
|
|
|
+ print("update completed with code \(statusCode)")
|
|
|
}
|
|
|
}
|
|
|
|