/*
* Copyright (C) 2017 The Android Open Source Project
*
* 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
*
* http://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.
*/
/*******************************************************************************
* AUTOGENERATED - DO NOT EDIT
*******************************************************************************
* This file has been generated from the protobuf message
* perfetto/config/ftrace/ftrace_config.proto
* by
* ../../tools/proto_to_cpp/proto_to_cpp.cc.
* If you need to make changes here, change the .proto file and then run
* ./tools/gen_tracing_cpp_headers_from_protos.py
*/
#include "perfetto/tracing/core/ftrace_config.h"
#include "perfetto/config/ftrace/ftrace_config.pb.h"
namespace perfetto {
FtraceConfig::FtraceConfig() = default;
FtraceConfig::~FtraceConfig() = default;
FtraceConfig::FtraceConfig(const FtraceConfig&) = default;
FtraceConfig& FtraceConfig::operator=(const FtraceConfig&) = default;
FtraceConfig::FtraceConfig(FtraceConfig&&) noexcept = default;
FtraceConfig& FtraceConfig::operator=(FtraceConfig&&) = default;
void FtraceConfig::FromProto(const perfetto::protos::FtraceConfig& proto) {
ftrace_events_.clear();
for (const auto& field : proto.ftrace_events()) {
ftrace_events_.emplace_back();
static_assert(
sizeof(ftrace_events_.back()) == sizeof(proto.ftrace_events(0)),
"size mismatch");
ftrace_events_.back() =
static_cast<decltype(ftrace_events_)::value_type>(field);
}
atrace_categories_.clear();
for (const auto& field : proto.atrace_categories()) {
atrace_categories_.emplace_back();
static_assert(
sizeof(atrace_categories_.back()) == sizeof(proto.atrace_categories(0)),
"size mismatch");
atrace_categories_.back() =
static_cast<decltype(atrace_categories_)::value_type>(field);
}
atrace_apps_.clear();
for (const auto& field : proto.atrace_apps()) {
atrace_apps_.emplace_back();
static_assert(sizeof(atrace_apps_.back()) == sizeof(proto.atrace_apps(0)),
"size mismatch");
atrace_apps_.back() =
static_cast<decltype(atrace_apps_)::value_type>(field);
}
static_assert(sizeof(buffer_size_kb_) == sizeof(proto.buffer_size_kb()),
"size mismatch");
buffer_size_kb_ =
static_cast<decltype(buffer_size_kb_)>(proto.buffer_size_kb());
static_assert(sizeof(drain_period_ms_) == sizeof(proto.drain_period_ms()),
"size mismatch");
drain_period_ms_ =
static_cast<decltype(drain_period_ms_)>(proto.drain_period_ms());
unknown_fields_ = proto.unknown_fields();
}
void FtraceConfig::ToProto(perfetto::protos::FtraceConfig* proto) const {
proto->Clear();
for (const auto& it : ftrace_events_) {
proto->add_ftrace_events(
static_cast<decltype(proto->ftrace_events(0))>(it));
static_assert(sizeof(it) == sizeof(proto->ftrace_events(0)),
"size mismatch");
}
for (const auto& it : atrace_categories_) {
proto->add_atrace_categories(
static_cast<decltype(proto->atrace_categories(0))>(it));
static_assert(sizeof(it) == sizeof(proto->atrace_categories(0)),
"size mismatch");
}
for (const auto& it : atrace_apps_) {
proto->add_atrace_apps(static_cast<decltype(proto->atrace_apps(0))>(it));
static_assert(sizeof(it) == sizeof(proto->atrace_apps(0)), "size mismatch");
}
static_assert(sizeof(buffer_size_kb_) == sizeof(proto->buffer_size_kb()),
"size mismatch");
proto->set_buffer_size_kb(
static_cast<decltype(proto->buffer_size_kb())>(buffer_size_kb_));
static_assert(sizeof(drain_period_ms_) == sizeof(proto->drain_period_ms()),
"size mismatch");
proto->set_drain_period_ms(
static_cast<decltype(proto->drain_period_ms())>(drain_period_ms_));
*(proto->mutable_unknown_fields()) = unknown_fields_;
}
} // namespace perfetto