| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- /// {{ method.name }} (Server Streaming)
- public class {{ .|call:file,service,method }} {
- private var call : Call
- /// Create a call.
- fileprivate init(_ channel: Channel) {
- self.call = channel.makeCall("{{ .|path:file,service,method }}")
- }
- /// Call this once with the message to send. Nonblocking.
- fileprivate func start(request: {{ method|input }},
- metadata: Metadata,
- completion: @escaping (CallResult) -> ())
- throws -> {{ .|call:file,service,method }} {
- let requestData = try request.serializedData()
- try call.start(.serverStreaming,
- metadata:metadata,
- message:requestData,
- completion:completion)
- return self
- }
- /// Call this to wait for a result. Blocking.
- public func receive() throws -> {{ method|output }} {
- var returnError : {{ .|clienterror:file,service }}?
- var returnResponse : {{ method|output }}!
- let sem = DispatchSemaphore(value: 0)
- do {
- try receive() {response, error in
- returnResponse = response
- returnError = error
- sem.signal()
- }
- _ = sem.wait(timeout: DispatchTime.distantFuture)
- }
- if let returnError = returnError {
- throw returnError
- }
- return returnResponse
- }
- /// Call this to wait for a result. Nonblocking.
- public func receive(completion:@escaping ({{ method|output }}?, {{ .|clienterror:file,service }}?)->()) throws {
- do {
- try call.receiveMessage() {(responseData) in
- if let responseData = responseData {
- if let response = try? {{ method|output }}(serializedData:responseData) {
- completion(response, nil)
- } else {
- completion(nil, {{ .|clienterror:file,service }}.invalidMessageReceived)
- }
- } else {
- completion(nil, {{ .|clienterror:file,service }}.endOfStream)
- }
- }
- }
- }
- }
|