2014-10-16 18:09:18 -04:00
|
|
|
|
// 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>
|
2016-04-25 12:13:07 -07:00
|
|
|
|
#include <memory>
|
2016-01-06 12:22:50 -05:00
|
|
|
|
#include <string>
|
2014-10-16 18:09:18 -04:00
|
|
|
|
#include <vector>
|
|
|
|
|
|
2016-01-06 12:22:50 -05:00
|
|
|
|
#include "base/macros.h"
|
2014-10-16 18:09:18 -04:00
|
|
|
|
#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();
|
2014-10-27 15:01:39 -04:00
|
|
|
|
~MinidumpSimpleStringDictionaryEntryWriter() override;
|
2014-10-16 18:09:18 -04:00
|
|
|
|
|
|
|
|
|
//! \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*
|
|
|
|
|
MinidumpSimpleStringDictionaryEntry() 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_;
|
|
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(MinidumpSimpleStringDictionaryEntryWriter);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//! \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();
|
2014-10-27 15:01:39 -04:00
|
|
|
|
~MinidumpSimpleStringDictionaryWriter() override;
|
2014-10-16 18:09:18 -04:00
|
|
|
|
|
2014-10-28 17:00:46 -04:00
|
|
|
|
//! \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);
|
|
|
|
|
|
2014-10-16 18:09:18 -04:00
|
|
|
|
//! \brief Adds a MinidumpSimpleStringDictionaryEntryWriter to the
|
|
|
|
|
//! MinidumpSimpleStringDictionary.
|
|
|
|
|
//!
|
2014-10-27 15:01:39 -04:00
|
|
|
|
//! This object takes ownership of \a entry and becomes its parent in the
|
|
|
|
|
//! overall tree of internal::MinidumpWritable objects.
|
2014-10-16 18:09:18 -04:00
|
|
|
|
//!
|
|
|
|
|
//! 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.
|
2016-04-25 12:13:07 -07:00
|
|
|
|
void AddEntry(
|
|
|
|
|
std::unique_ptr<MinidumpSimpleStringDictionaryEntryWriter> entry);
|
2014-10-16 18:09:18 -04:00
|
|
|
|
|
2014-10-28 17:00:46 -04:00
|
|
|
|
//! \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;
|
|
|
|
|
|
2014-10-16 18:09:18 -04:00
|
|
|
|
protected:
|
|
|
|
|
// MinidumpWritable:
|
|
|
|
|
|
|
|
|
|
bool Freeze() override;
|
|
|
|
|
size_t SizeOfObject() override;
|
|
|
|
|
std::vector<MinidumpWritable*> Children() override;
|
|
|
|
|
bool WriteObject(FileWriterInterface* file_writer) override;
|
|
|
|
|
|
|
|
|
|
private:
|
2014-10-27 15:01:39 -04:00
|
|
|
|
// This object owns the MinidumpSimpleStringDictionaryEntryWriter objects.
|
|
|
|
|
std::map<std::string, MinidumpSimpleStringDictionaryEntryWriter*> entries_;
|
2014-10-16 18:09:18 -04:00
|
|
|
|
|
2016-04-25 12:13:07 -07:00
|
|
|
|
std::unique_ptr<MinidumpSimpleStringDictionary>
|
|
|
|
|
simple_string_dictionary_base_;
|
2015-02-04 17:34:43 -08:00
|
|
|
|
|
2014-10-16 18:09:18 -04:00
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(MinidumpSimpleStringDictionaryWriter);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace crashpad
|
|
|
|
|
|
|
|
|
|
#endif // CRASHPAD_MINIDUMP_MINIDUMP_SIMPLE_STRING_DICTIONARY_WRITER_H_
|