|  | /* | 
|  | * Copyright (C) 2019 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. | 
|  | */ | 
|  |  | 
|  | #ifndef SRC_TRACE_PROCESSOR_UTIL_PROTOZERO_TO_TEXT_H_ | 
|  | #define SRC_TRACE_PROCESSOR_UTIL_PROTOZERO_TO_TEXT_H_ | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include "perfetto/protozero/field.h" | 
|  |  | 
|  | namespace perfetto { | 
|  | namespace trace_processor { | 
|  |  | 
|  | class DescriptorPool; | 
|  |  | 
|  | namespace protozero_to_text { | 
|  |  | 
|  | // If |new_lines_modes| == kIncludeNewLines, new lines will be used between | 
|  | // fields, otherwise only a space will be used. | 
|  | enum NewLinesMode { | 
|  | kIncludeNewLines = 0, | 
|  | kSkipNewLines, | 
|  | }; | 
|  |  | 
|  | // Given a protozero message |protobytes| which is of fully qualified name | 
|  | // |type| within TrackEvent proto messages, we will convert this into a text | 
|  | // proto format string. | 
|  | // | 
|  | // DebugTrackEventProtozeroToText will use new lines between fields, and | 
|  | // ShortDebugTrackEventProtozeroToText will use only a single space. | 
|  | std::string DebugTrackEventProtozeroToText(const std::string& type, | 
|  | protozero::ConstBytes protobytes); | 
|  | std::string ShortDebugTrackEventProtozeroToText( | 
|  | const std::string& type, | 
|  | protozero::ConstBytes protobytes); | 
|  |  | 
|  | // Given a protozero message |protobytes| which is of fully qualified name | 
|  | // |type|, convert this into a text proto format string. All types used in | 
|  | // message definition of |type| must be available in |pool|. | 
|  | std::string ProtozeroToText( | 
|  | const DescriptorPool& pool, | 
|  | const std::string& type, | 
|  | protozero::ConstBytes protobytes, | 
|  | NewLinesMode new_lines_mode = NewLinesMode::kIncludeNewLines, | 
|  | uint32_t initial_indent_depth = 0); | 
|  |  | 
|  | std::string ProtozeroToText(const DescriptorPool& pool, | 
|  | const std::string& type, | 
|  | const std::vector<uint8_t>& protobytes, | 
|  | NewLinesMode new_lines_mode); | 
|  |  | 
|  | // Allow the conversion from a protozero enum to a string. The template is just | 
|  | // to allow easy enum passing since we will do the explicit cast to a int32_t | 
|  | // for the user. | 
|  | std::string ProtozeroEnumToText(const std::string& type, int32_t enum_value); | 
|  | template <typename Enum> | 
|  | std::string ProtozeroEnumToText(const std::string& type, Enum enum_value) { | 
|  | return ProtozeroEnumToText(type, static_cast<int32_t>(enum_value)); | 
|  | } | 
|  |  | 
|  | }  // namespace protozero_to_text | 
|  | }  // namespace trace_processor | 
|  | }  // namespace perfetto | 
|  |  | 
|  | #endif  // SRC_TRACE_PROCESSOR_UTIL_PROTOZERO_TO_TEXT_H_ |