// Copyright 2014 The Crashpad Authors. All rights reserved. // // 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_SIMPLE_STRING_DICTIONARY_WRITER_H_ #define CRASHPAD_MINIDUMP_MINIDUMP_SIMPLE_STRING_DICTIONARY_WRITER_H_ #include <sys/types.h> #include <map> #include <memory> #include <string> #include <vector> #include "minidump/minidump_extensions.h" #include "minidump/minidump_string_writer.h" #include "minidump/minidump_writable.h" namespace crashpad { //! \brief The writer for a MinidumpSimpleStringDictionaryEntry object in a //! minidump file. //! //! Because MinidumpSimpleStringDictionaryEntry objects only appear as elements //! of MinidumpSimpleStringDictionary objects, this class does not write any //! data on its own. It makes its MinidumpSimpleStringDictionaryEntry data //! available to its MinidumpSimpleStringDictionaryWriter parent, which writes //! it as part of a MinidumpSimpleStringDictionary. class MinidumpSimpleStringDictionaryEntryWriter final : public internal::MinidumpWritable { public: MinidumpSimpleStringDictionaryEntryWriter(); MinidumpSimpleStringDictionaryEntryWriter( const MinidumpSimpleStringDictionaryEntryWriter&) = delete; MinidumpSimpleStringDictionaryEntryWriter& operator=( const MinidumpSimpleStringDictionaryEntryWriter&) = delete; ~MinidumpSimpleStringDictionaryEntryWriter() override; //! \brief Returns a MinidumpSimpleStringDictionaryEntry referencing this //! object’s data. //! //! This method is expected to be called by a //! MinidumpSimpleStringDictionaryWriter in order to obtain a //! MinidumpSimpleStringDictionaryEntry to include in its list. //! //! \note Valid in #kStateWritable. const MinidumpSimpleStringDictionaryEntry* GetMinidumpSimpleStringDictionaryEntry() const; //! \brief Sets the strings to be written as the entry object’s key and value. //! //! \note Valid in #kStateMutable. void SetKeyValue(const std::string& key, const std::string& value); //! \brief Retrieves the key to be written. //! //! \note Valid in any state. const std::string& Key() const { return key_.UTF8(); } protected: // MinidumpWritable: bool Freeze() override; size_t SizeOfObject() override; std::vector<MinidumpWritable*> Children() override; bool WriteObject(FileWriterInterface* file_writer) override; private: struct MinidumpSimpleStringDictionaryEntry entry_; internal::MinidumpUTF8StringWriter key_; internal::MinidumpUTF8StringWriter value_; }; //! \brief The writer for a MinidumpSimpleStringDictionary object in a minidump //! file, containing a list of MinidumpSimpleStringDictionaryEntry objects. //! //! Because this class writes a representatin of a dictionary, the order of //! entries is insignificant. Entries may be written in any order. class MinidumpSimpleStringDictionaryWriter final : public internal::MinidumpWritable { public: MinidumpSimpleStringDictionaryWriter(); MinidumpSimpleStringDictionaryWriter( const MinidumpSimpleStringDictionaryWriter&) = delete; MinidumpSimpleStringDictionaryWriter& operator=( const MinidumpSimpleStringDictionaryWriter&) = delete; ~MinidumpSimpleStringDictionaryWriter() override; //! \brief Adds an initialized MinidumpSimpleStringDictionaryEntryWriter for //! each key-value pair in \a map to the MinidumpSimpleStringDictionary. //! //! \param[in] map The map 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 InitializeFromMap(const std::map<std::string, std::string>& map); //! \brief Adds a MinidumpSimpleStringDictionaryEntryWriter to the //! MinidumpSimpleStringDictionary. //! //! This object takes ownership of \a entry and becomes its parent in the //! overall tree of internal::MinidumpWritable objects. //! //! If the key contained in \a entry duplicates the key of an entry already //! present in the MinidumpSimpleStringDictionary, the new \a entry will //! replace the previous one. //! //! \note Valid in #kStateMutable. void AddEntry( std::unique_ptr<MinidumpSimpleStringDictionaryEntryWriter> entry); //! \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 entries 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<MinidumpWritable*> Children() override; bool WriteObject(FileWriterInterface* file_writer) override; private: // This object owns the MinidumpSimpleStringDictionaryEntryWriter objects. std::map<std::string, MinidumpSimpleStringDictionaryEntryWriter*> entries_; std::unique_ptr<MinidumpSimpleStringDictionary> simple_string_dictionary_base_; }; } // namespace crashpad #endif // CRASHPAD_MINIDUMP_MINIDUMP_SIMPLE_STRING_DICTIONARY_WRITER_H_