| // Copyright 2021 The Crashpad 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 |
| // |
| // 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 CRASHPAD_UTIL_IOS_IOS_INTERMEDIATE_DUMP_READER_H_ |
| #define CRASHPAD_UTIL_IOS_IOS_INTERMEDIATE_DUMP_READER_H_ |
| |
| #include "util/ios/ios_intermediate_dump_interface.h" |
| #include "util/ios/ios_intermediate_dump_map.h" |
| #include "util/misc/initialization_state_dcheck.h" |
| |
| namespace crashpad { |
| namespace internal { |
| |
| //! \brief The return value for IOSIntermediateDumpReader::Initialize. |
| enum class IOSIntermediateDumpReaderInitializeResult : int { |
| //! \brief The intermediate dump was read successfully, initialization |
| //! succeeded. |
| kSuccess, |
| |
| //! \brief The intermediate dump could be loaded, but parsing was incomplete. |
| //! An attempt to parse the RootMap should still be made, as there may |
| //! still be valuable information to put into a minidump. |
| kIncomplete, |
| |
| //! \brief The intermediate dump could not be loaded, initialization failed. |
| kFailure, |
| }; |
| |
| //! \brief Open and parse iOS intermediate dumps. |
| class IOSIntermediateDumpReader { |
| public: |
| IOSIntermediateDumpReader() {} |
| |
| IOSIntermediateDumpReader(const IOSIntermediateDumpReader&) = delete; |
| IOSIntermediateDumpReader& operator=(const IOSIntermediateDumpReader&) = |
| delete; |
| |
| //! \brief Open and parses \a dump_interface. |
| //! |
| //! Will attempt to parse the binary file, similar to a JSON file, using the |
| //! same format used by IOSIntermediateDumpWriter, resulting in an |
| //! IOSIntermediateDumpMap |
| //! |
| //! \param[in] dump_interface An interface corresponding to an intermediate |
| //! dump file. |
| //! |
| //! \return On success, returns `true`, otherwise returns `false`. Clients may |
| //! still attempt to parse RootMap, as partial minidumps may still be |
| //! usable. |
| IOSIntermediateDumpReaderInitializeResult Initialize( |
| const IOSIntermediateDumpInterface& dump_interface); |
| |
| //! \brief Returns an IOSIntermediateDumpMap corresponding to the root of the |
| //! intermediate dump. |
| const IOSIntermediateDumpMap* RootMap(); |
| |
| private: |
| bool Parse(FileReaderInterface* reader, FileOffset file_size); |
| IOSIntermediateDumpMap intermediate_dump_; |
| InitializationStateDcheck initialized_; |
| }; |
| |
| } // namespace internal |
| } // namespace crashpad |
| |
| #endif // CRASHPAD_UTIL_IOS_IOS_INTERMEDIATE_DUMP_READER_H_ |