2014-10-24 14:44:55 -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.
|
|
|
|
|
|
2014-10-24 14:58:53 -04:00
|
|
|
|
#ifndef CRASHPAD_MINIDUMP_MINIDUMP_MODULE_CRASHPAD_INFO_WRITER_H_
|
|
|
|
|
#define CRASHPAD_MINIDUMP_MINIDUMP_MODULE_CRASHPAD_INFO_WRITER_H_
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2014-10-28 17:00:46 -04:00
|
|
|
|
#include <sys/types.h>
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
|
|
#include "base/basictypes.h"
|
2014-10-27 15:01:39 -04:00
|
|
|
|
#include "base/memory/scoped_ptr.h"
|
2014-10-24 14:44:55 -04:00
|
|
|
|
#include "minidump/minidump_extensions.h"
|
2014-11-06 16:58:37 -05:00
|
|
|
|
#include "minidump/minidump_location_descriptor_list_writer.h"
|
2014-11-07 10:01:17 -05:00
|
|
|
|
#include "minidump/minidump_string_writer.h"
|
2014-10-24 14:44:55 -04:00
|
|
|
|
#include "minidump/minidump_writable.h"
|
2014-10-27 15:01:39 -04:00
|
|
|
|
#include "util/stdlib/pointer_container.h"
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
|
|
|
|
namespace crashpad {
|
|
|
|
|
|
|
|
|
|
class MinidumpSimpleStringDictionaryWriter;
|
2014-10-28 17:00:46 -04:00
|
|
|
|
class ModuleSnapshot;
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
|
|
|
|
//! \brief The writer for a MinidumpModuleCrashpadInfo object in a minidump
|
|
|
|
|
//! file.
|
|
|
|
|
class MinidumpModuleCrashpadInfoWriter final
|
|
|
|
|
: public internal::MinidumpWritable {
|
|
|
|
|
public:
|
|
|
|
|
MinidumpModuleCrashpadInfoWriter();
|
2014-10-27 15:01:39 -04:00
|
|
|
|
~MinidumpModuleCrashpadInfoWriter() override;
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
2014-11-07 11:38:13 -05:00
|
|
|
|
//! \brief Initializes MinidumpModuleCrashpadInfo based on \a module_snapshot.
|
2014-10-28 17:00:46 -04:00
|
|
|
|
//!
|
|
|
|
|
//! Only data in \a module_snapshot that is considered useful will be
|
|
|
|
|
//! included. For simple annotations, usefulness is determined by
|
|
|
|
|
//! MinidumpSimpleStringDictionaryWriter::IsUseful().
|
|
|
|
|
//!
|
|
|
|
|
//! \param[in] module_snapshot The module snapshot to use as source data.
|
|
|
|
|
//! \param[in] module_list_index The index of the MINIDUMP_MODULE initialized
|
|
|
|
|
//! from \a module_snapshot in the minidump file’s MINIDUMP_MODULE_LIST
|
|
|
|
|
//! stream.
|
|
|
|
|
//!
|
|
|
|
|
//! \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 ModuleSnapshot* module_snapshot,
|
|
|
|
|
size_t module_list_index);
|
|
|
|
|
|
2014-10-24 14:44:55 -04:00
|
|
|
|
//! \brief Sets MinidumpModuleCrashpadInfo::minidump_module_list_index.
|
|
|
|
|
void SetMinidumpModuleListIndex(uint32_t minidump_module_list_index) {
|
|
|
|
|
module_.minidump_module_list_index = minidump_module_list_index;
|
|
|
|
|
}
|
|
|
|
|
|
2014-11-07 10:01:17 -05:00
|
|
|
|
//! \brief Arranges for MinidumpModuleCrashpadInfo::list_annotations to point
|
|
|
|
|
//! to the internal::MinidumpUTF8StringListWriter object to be written by
|
|
|
|
|
//! \a list_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 SetListAnnotations(
|
2014-11-07 11:45:44 -05:00
|
|
|
|
scoped_ptr<MinidumpUTF8StringListWriter> list_annotations);
|
2014-11-07 10:01:17 -05:00
|
|
|
|
|
2014-10-24 14:44:55 -04:00
|
|
|
|
//! \brief Arranges for MinidumpModuleCrashpadInfo::simple_annotations to
|
|
|
|
|
//! point to the MinidumpSimpleStringDictionaryWriter object to be written
|
|
|
|
|
//! by \a simple_annotations.
|
|
|
|
|
//!
|
2014-10-27 15:01:39 -04:00
|
|
|
|
//! This object takes ownership of \a simple_annotations and becomes its
|
|
|
|
|
//! parent in the overall tree of internal::MinidumpWritable objects.
|
2014-10-24 14:44:55 -04:00
|
|
|
|
//!
|
|
|
|
|
//! \note Valid in #kStateMutable.
|
|
|
|
|
void SetSimpleAnnotations(
|
2014-10-27 15:01:39 -04:00
|
|
|
|
scoped_ptr<MinidumpSimpleStringDictionaryWriter> simple_annotations);
|
2014-10-24 14:44:55 -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
|
2014-11-07 10:01:17 -05:00
|
|
|
|
//! contribution to a minidump file. An object carrying list annotations or
|
|
|
|
|
//! simple annotations would be considered useful.
|
2014-10-28 17:00:46 -04:00
|
|
|
|
//!
|
|
|
|
|
//! \return `true` if the object is useful, `false` otherwise.
|
|
|
|
|
bool IsUseful() const;
|
|
|
|
|
|
2014-10-24 14:44:55 -04:00
|
|
|
|
protected:
|
|
|
|
|
// MinidumpWritable:
|
|
|
|
|
bool Freeze() override;
|
|
|
|
|
size_t SizeOfObject() override;
|
|
|
|
|
std::vector<MinidumpWritable*> Children() override;
|
|
|
|
|
bool WriteObject(FileWriterInterface* file_writer) override;
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MinidumpModuleCrashpadInfo module_;
|
2014-11-07 11:45:44 -05:00
|
|
|
|
scoped_ptr<MinidumpUTF8StringListWriter> list_annotations_;
|
2014-10-27 15:01:39 -04:00
|
|
|
|
scoped_ptr<MinidumpSimpleStringDictionaryWriter> simple_annotations_;
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(MinidumpModuleCrashpadInfoWriter);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//! \brief The writer for a MinidumpModuleCrashpadInfoList object in a minidump
|
|
|
|
|
//! file, containing a list of MinidumpModuleCrashpadInfo objects.
|
|
|
|
|
class MinidumpModuleCrashpadInfoListWriter final
|
2014-11-07 11:45:44 -05:00
|
|
|
|
: public internal::MinidumpLocationDescriptorListWriter {
|
2014-10-24 14:44:55 -04:00
|
|
|
|
public:
|
|
|
|
|
MinidumpModuleCrashpadInfoListWriter();
|
2014-10-27 15:01:39 -04:00
|
|
|
|
~MinidumpModuleCrashpadInfoListWriter() override;
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
2014-10-28 17:00:46 -04:00
|
|
|
|
//! \brief Adds an initialized MinidumpModuleCrashpadInfo for modules in \a
|
|
|
|
|
//! module_snapshots to the MinidumpModuleCrashpadInfoList.
|
|
|
|
|
//!
|
|
|
|
|
//! Only modules in \a module_snapshots that would produce a useful
|
|
|
|
|
//! MinidumpModuleCrashpadInfo structure are included. Usefulness is
|
|
|
|
|
//! determined by MinidumpModuleCrashpadInfoWriter::IsUseful().
|
|
|
|
|
//!
|
|
|
|
|
//! \param[in] module_snapshots The module snapshots to use as source data.
|
|
|
|
|
//!
|
2014-10-30 14:51:40 -04:00
|
|
|
|
//! \note Valid in #kStateMutable. AddModule() may not be called before this
|
|
|
|
|
//! method, and it is not normally necessary to call AddModule() after
|
|
|
|
|
//! this method.
|
2014-10-28 17:00:46 -04:00
|
|
|
|
void InitializeFromSnapshot(
|
|
|
|
|
const std::vector<const ModuleSnapshot*>& module_snapshots);
|
|
|
|
|
|
2014-10-24 14:44:55 -04:00
|
|
|
|
//! \brief Adds a MinidumpModuleCrashpadInfo to the
|
|
|
|
|
//! MinidumpModuleCrashpadInfoList.
|
|
|
|
|
//!
|
2014-10-27 15:01:39 -04:00
|
|
|
|
//! This object takes ownership of \a module and becomes its parent in the
|
|
|
|
|
//! overall tree of internal::MinidumpWritable objects.
|
2014-10-24 14:44:55 -04:00
|
|
|
|
//!
|
|
|
|
|
//! \note Valid in #kStateMutable.
|
2014-10-27 15:01:39 -04:00
|
|
|
|
void AddModule(scoped_ptr<MinidumpModuleCrashpadInfoWriter> module);
|
2014-10-24 14:44:55 -04:00
|
|
|
|
|
2014-11-07 11:38:13 -05: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 children would be
|
|
|
|
|
//! considered useful.
|
|
|
|
|
//!
|
|
|
|
|
//! \return `true` if the object is useful, `false` otherwise.
|
|
|
|
|
bool IsUseful() const;
|
|
|
|
|
|
2014-10-24 14:44:55 -04:00
|
|
|
|
private:
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(MinidumpModuleCrashpadInfoListWriter);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace crashpad
|
|
|
|
|
|
2014-10-24 14:58:53 -04:00
|
|
|
|
#endif // CRASHPAD_MINIDUMP_MINIDUMP_MODULE_CRASHPAD_INFO_WRITER_H_
|