| /* |
| * 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) { |
| event_names_.clear(); |
| for (const auto& field : proto.event_names()) { |
| event_names_.emplace_back(); |
| static_assert(sizeof(event_names_.back()) == sizeof(proto.event_names(0)), |
| "size mismatch"); |
| event_names_.back() = |
| static_cast<decltype(event_names_)::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 : event_names_) { |
| auto* entry = proto->add_event_names(); |
| static_assert(sizeof(it) == sizeof(proto->event_names(0)), "size mismatch"); |
| *entry = static_cast<decltype(proto->event_names(0))>(it); |
| } |
| |
| for (const auto& it : atrace_categories_) { |
| auto* entry = proto->add_atrace_categories(); |
| static_assert(sizeof(it) == sizeof(proto->atrace_categories(0)), |
| "size mismatch"); |
| *entry = static_cast<decltype(proto->atrace_categories(0))>(it); |
| } |
| |
| for (const auto& it : atrace_apps_) { |
| auto* entry = proto->add_atrace_apps(); |
| static_assert(sizeof(it) == sizeof(proto->atrace_apps(0)), "size mismatch"); |
| *entry = static_cast<decltype(proto->atrace_apps(0))>(it); |
| } |
| |
| 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 |