// Copyright 2014 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_MINIDUMP_MINIDUMP_CRASHPAD_INFO_WRITER_H_ #define CRASHPAD_MINIDUMP_MINIDUMP_CRASHPAD_INFO_WRITER_H_ #include #include #include #include "minidump/minidump_extensions.h" #include "minidump/minidump_stream_writer.h" #include "util/misc/uuid.h" namespace crashpad { class MinidumpModuleCrashpadInfoListWriter; class MinidumpSimpleStringDictionaryWriter; class ProcessSnapshot; //! \brief The writer for a MinidumpCrashpadInfo stream in a minidump file. class MinidumpCrashpadInfoWriter final : public internal::MinidumpStreamWriter { public: MinidumpCrashpadInfoWriter(); MinidumpCrashpadInfoWriter(const MinidumpCrashpadInfoWriter&) = delete; MinidumpCrashpadInfoWriter& operator=(const MinidumpCrashpadInfoWriter&) = delete; ~MinidumpCrashpadInfoWriter() override; //! \brief Initializes MinidumpCrashpadInfo based on \a process_snapshot. //! //! This method may add additional structures to the minidump file as children //! of the MinidumpCrashpadInfo stream. To do so, it may obtain other //! snapshot information from \a process_snapshot, such as a list of //! ModuleSnapshot objects used to initialize //! MinidumpCrashpadInfo::module_list. Only data that is considered useful //! will be included. For module information, usefulness is determined by //! MinidumpModuleCrashpadInfoListWriter::IsUseful(). //! //! \param[in] process_snapshot The process snapshot to use as source data. //! //! \note Valid in #kStateMutable. No mutator methods may be called before //! this method, and it is not normally necessary to call any mutator //! methods after this method. void InitializeFromSnapshot(const ProcessSnapshot* process_snapshot); //! \brief Sets MinidumpCrashpadInfo::report_id. void SetReportID(const UUID& report_id); //! \brief Sets MinidumpCrashpadInfo::client_id. void SetClientID(const UUID& client_id); //! \brief Arranges for MinidumpCrashpadInfo::simple_annotations to point to //! the MinidumpSimpleStringDictionaryWriter object to be written by \a //! simple_annotations. //! //! This object takes ownership of \a simple_annotations and becomes its //! parent in the overall tree of internal::MinidumpWritable objects. //! //! \note Valid in #kStateMutable. void SetSimpleAnnotations( std::unique_ptr simple_annotations); //! \brief Arranges for MinidumpCrashpadInfo::module_list to point to the //! MinidumpModuleCrashpadInfoList object to be written by \a //! module_list. //! //! This object takes ownership of \a module_list and becomes its parent in //! the overall tree of internal::MinidumpWritable objects. //! //! \note Valid in #kStateMutable. void SetModuleList( std::unique_ptr module_list); //! \brief Sets MinidumpCrashpadInfo::address_mask. void SetAddressMask(uint64_t mask); //! \brief Determines whether the object is useful. //! //! A useful object is one that carries data that makes a meaningful //! contribution to a minidump file. An object carrying children would be //! considered useful. //! //! \return `true` if the object is useful, `false` otherwise. bool IsUseful() const; protected: // MinidumpWritable: bool Freeze() override; size_t SizeOfObject() override; std::vector Children() override; bool WriteObject(FileWriterInterface* file_writer) override; // MinidumpStreamWriter: MinidumpStreamType StreamType() const override; private: MinidumpCrashpadInfo crashpad_info_; std::unique_ptr simple_annotations_; std::unique_ptr module_list_; }; } // namespace crashpad #endif // CRASHPAD_MINIDUMP_MINIDUMP_CRASHPAD_INFO_WRITER_H_