blob: d17dad863e0948f218891f54d5cecb0d7faf7c62 [file] [log] [blame]
// Copyright 2023 The Pigweed Authors
// Licensed under the Apache License, Version 2.0 (the "License"); you may not
// use this file except in compliance with the License. You may obtain a copy of
// the License at
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
// License for the specific language governing permissions and limitations under
// the License.
#include <memory>
#include <optional>
#include "pw_async/function_dispatcher.h"
#include "pw_async/heap_dispatcher.h"
#include "pw_async_basic/dispatcher.h"
#include "pw_async_bench/callback_impl.h"
#include "pw_thread/thread.h"
#include "pw_thread_stl/options.h"
int main() {
pw::async::BasicDispatcher basic_dispatcher;
pw::thread::Thread work_thread(pw::thread::stl::Options(), basic_dispatcher);
// `HeapDispatcher` is needed so that we can post callbacks without managing
// `Task` object lifetimes within the class that makes an asynchronous call.
pw::async::HeapDispatcher heap_dispatcher(basic_dispatcher);
pw::async_bench::RpcSystem rpc_system(heap_dispatcher);
const char* ECHO_VALUE = "some value";
pw::async_bench::EchoRequest request{ECHO_VALUE};
std::optional<pw::Result<pw::async_bench::EchoResponse>> result_storage(
pw::async_bench::RemoteEcho remote(rpc_system);
pw::async_bench::ProxyEchoImpl impl(remote);
rpc_system, impl, std::move(request), result_storage);
PW_ASSERT(result_storage->value().value == ECHO_VALUE);
return 0;