2023-01-28 04:54:20 +00:00
|
|
|
|
// Copyright 2017 The Crashpad Authors
|
2022-04-02 01:21:55 +00:00
|
|
|
|
//
|
|
|
|
|
// 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_ANNOTATION_WRITER_H_
|
|
|
|
|
#define CRASHPAD_MINIDUMP_MINIDUMP_ANNOTATION_WRITER_H_
|
|
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
|
|
#include "minidump/minidump_byte_array_writer.h"
|
|
|
|
|
#include "minidump/minidump_extensions.h"
|
|
|
|
|
#include "minidump/minidump_string_writer.h"
|
|
|
|
|
#include "minidump/minidump_writable.h"
|
|
|
|
|
#include "snapshot/annotation_snapshot.h"
|
|
|
|
|
|
|
|
|
|
namespace crashpad {
|
|
|
|
|
|
|
|
|
|
//! \brief The writer for a MinidumpAnnotation object in a minidump file.
|
|
|
|
|
//!
|
|
|
|
|
//! Because MinidumpAnnotation objects only appear as elements
|
|
|
|
|
//! of MinidumpAnnotationList objects, this class does not write any
|
|
|
|
|
//! data on its own. It makes its MinidumpAnnotation data available to its
|
|
|
|
|
//! MinidumpAnnotationList parent, which writes it as part of a
|
|
|
|
|
//! MinidumpAnnotationList.
|
|
|
|
|
class MinidumpAnnotationWriter final : public internal::MinidumpWritable {
|
|
|
|
|
public:
|
|
|
|
|
MinidumpAnnotationWriter();
|
|
|
|
|
|
|
|
|
|
MinidumpAnnotationWriter(const MinidumpAnnotationWriter&) = delete;
|
|
|
|
|
MinidumpAnnotationWriter& operator=(const MinidumpAnnotationWriter&) = delete;
|
|
|
|
|
|
|
|
|
|
~MinidumpAnnotationWriter();
|
|
|
|
|
|
|
|
|
|
//! \brief Initializes the annotation writer with data from an
|
|
|
|
|
//! AnnotationSnapshot.
|
|
|
|
|
void InitializeFromSnapshot(const AnnotationSnapshot& snapshot);
|
|
|
|
|
|
|
|
|
|
//! \brief Initializes the annotation writer with data values.
|
|
|
|
|
void InitializeWithData(const std::string& name,
|
|
|
|
|
uint16_t type,
|
|
|
|
|
const std::vector<uint8_t>& data);
|
|
|
|
|
|
|
|
|
|
//! \brief Returns the MinidumpAnnotation referencing this object’s data.
|
|
|
|
|
const MinidumpAnnotation* minidump_annotation() const { return &annotation_; }
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
// MinidumpWritable:
|
|
|
|
|
|
|
|
|
|
bool Freeze() override;
|
|
|
|
|
size_t SizeOfObject() override;
|
|
|
|
|
std::vector<internal::MinidumpWritable*> Children() override;
|
|
|
|
|
bool WriteObject(FileWriterInterface* file_writer) override;
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MinidumpAnnotation annotation_;
|
|
|
|
|
internal::MinidumpUTF8StringWriter name_;
|
|
|
|
|
MinidumpByteArrayWriter value_;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//! \brief The writer for a MinidumpAnnotationList object in a minidump file,
|
|
|
|
|
//! containing a list of MinidumpAnnotation objects.
|
|
|
|
|
class MinidumpAnnotationListWriter final : public internal::MinidumpWritable {
|
|
|
|
|
public:
|
|
|
|
|
MinidumpAnnotationListWriter();
|
|
|
|
|
|
|
|
|
|
MinidumpAnnotationListWriter(const MinidumpAnnotationListWriter&) = delete;
|
|
|
|
|
MinidumpAnnotationListWriter& operator=(const MinidumpAnnotationListWriter&) =
|
|
|
|
|
delete;
|
|
|
|
|
|
|
|
|
|
~MinidumpAnnotationListWriter();
|
|
|
|
|
|
|
|
|
|
//! \brief Initializes the annotation list writer with a list of
|
|
|
|
|
//! AnnotationSnapshot objects.
|
|
|
|
|
void InitializeFromList(const std::vector<AnnotationSnapshot>& list);
|
|
|
|
|
|
|
|
|
|
//! \brief Adds a single MinidumpAnnotationWriter to the list to be written.
|
|
|
|
|
void AddObject(std::unique_ptr<MinidumpAnnotationWriter> annotation_writer);
|
|
|
|
|
|
|
|
|
|
//! \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<internal::MinidumpWritable*> Children() override;
|
|
|
|
|
bool WriteObject(FileWriterInterface* file_writer) override;
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
std::unique_ptr<MinidumpAnnotationList> minidump_list_;
|
|
|
|
|
std::vector<std::unique_ptr<MinidumpAnnotationWriter>> objects_;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace crashpad
|
|
|
|
|
|
|
|
|
|
#endif // CRASHPAD_MINIDUMP_MINIDUMP_ANNOTATION_WRITER_H_
|