|  | // Copyright 2020 The Fuchsia Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | // [START includes] | 
|  | #include <fuchsia/examples/llcpp/fidl.h> | 
|  | #include <lib/async-loop/cpp/loop.h> | 
|  | #include <lib/async-loop/default.h> | 
|  | #include <lib/fdio/directory.h> | 
|  | #include <lib/fidl/llcpp/client.h> | 
|  | #include <lib/zx/channel.h> | 
|  | #include <zircon/status.h> | 
|  |  | 
|  | #include <iostream> | 
|  | // [END includes] | 
|  |  | 
|  | // [START connect] | 
|  | // Returns a channel connected to the /svc directory. The | 
|  | // remote end of the channel implements the io.Directory protocol and contains | 
|  | // the capabilities provided to this component. | 
|  | zx::channel get_svc_directory() { | 
|  | zx::channel server_end, client_end; | 
|  | ZX_ASSERT(zx::channel::create(0, &client_end, &server_end) == ZX_OK); | 
|  | ZX_ASSERT(fdio_service_connect("/svc/.", server_end.release()) == ZX_OK); | 
|  | return client_end; | 
|  | } | 
|  | // [END connect] | 
|  |  | 
|  | // [START main] | 
|  | int main(int argc, const char** argv) { | 
|  | async::Loop loop(&kAsyncLoopConfigAttachToCurrentThread); | 
|  | async_dispatcher_t* dispatcher = loop.dispatcher(); | 
|  |  | 
|  | auto svc = get_svc_directory(); | 
|  | zx::channel server_end, client_end; | 
|  | ZX_ASSERT(zx::channel::create(0, &client_end, &server_end) == ZX_OK); | 
|  | // Connect to the fuchsia.examples.Echo protocol. | 
|  | ZX_ASSERT(fdio_service_connect_at(svc.get(), "fuchsia.examples.Echo", server_end.release()) == | 
|  | ZX_OK); | 
|  |  | 
|  | // Define the event handlers for the client. The OnString event handler prints the event | 
|  | llcpp::fuchsia::examples::Echo::AsyncEventHandlers handlers = { | 
|  | .on_string = [&](llcpp::fuchsia::examples::Echo::OnStringResponse* message) { | 
|  | std::string event(message->response.data(), message->response.size()); | 
|  | std::cout << "Got event: " << event << std::endl; | 
|  | loop.Quit(); | 
|  | }}; | 
|  | // Create a client to the Echo protocol | 
|  | fidl::Client<llcpp::fuchsia::examples::Echo> client(std::move(client_end), dispatcher, | 
|  | std::move(handlers)); | 
|  |  | 
|  | // Make an EchoString call, passing it a lambda to handle the response asynchronously. | 
|  | client->EchoString("hello", [&](fidl::StringView resp) { | 
|  | std::string reply(resp.data(), resp.size()); | 
|  | std::cout << "Got response: " << reply << std::endl; | 
|  | loop.Quit(); | 
|  | }); | 
|  | loop.Run(); | 
|  | loop.ResetQuit(); | 
|  |  | 
|  | // Make a synchronous EchoString call, which blocks until it receives the response, | 
|  | // then returns a ResultOf object for the response. | 
|  | auto result = client->EchoString_Sync("hello"); | 
|  | ZX_ASSERT(result.ok()); | 
|  | std::string reply_string(result->response.data(), result->response.size()); | 
|  | std::cout << "Got synchronous response: " << reply_string << std::endl; | 
|  |  | 
|  | // Make a SendString request. The resulting OnString event will be handled by | 
|  | // the event handler defined above. | 
|  | client->SendString("hi"); | 
|  | loop.Run(); | 
|  |  | 
|  | return 0; | 
|  | } | 
|  | // [END main] |