// 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
//
//     https://www.apache.org/licenses/LICENSE-2.0
//
// 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.

#define PW_LOG_MODULE_NAME "PW_RPC"

#include <cstddef>

#include "pw_log/log.h"
#include "pw_status/status.h"

namespace pw::rpc::internal {

void LogNoRpcServiceRegistryError() {
  PW_LOG_ERROR("LocalRpcEgress: service registry not configured");
}

void LogPacketSizeTooLarge(size_t packet_size, size_t max_packet_size) {
  PW_LOG_ERROR("LocalRpcEgress: packet too large (%d > %d)",
               static_cast<int>(packet_size),
               static_cast<int>(max_packet_size));
}

void LogEgressThreadNotRunningError() {
  PW_LOG_ERROR("LocalRpcEgress: egress thread is not running");
}

void LogFailedToProcessPacket(Status status) {
  PW_LOG_ERROR("LocalRpcEgress: failed to process packet. Status %d",
               static_cast<int>(status.code()));
}

void LogFailedToAccessPacket(Status status) {
  PW_LOG_ERROR("LocalRpcEgress: failed to access packet buffer. Status %d",
               static_cast<int>(status.code()));
}

void LogNoPacketAvailable(Status status) {
  PW_LOG_ERROR("LocalRpcEgress: no packet available. Status %d",
               static_cast<int>(status.code()));
}

}  // namespace pw::rpc::internal
