189 lines
6.3 KiB
C++
189 lines
6.3 KiB
C++
// 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_STRING_WRITER_H_
|
||
#define CRASHPAD_MINIDUMP_MINIDUMP_STRING_WRITER_H_
|
||
|
||
#include <windows.h>
|
||
#include <dbghelp.h>
|
||
#include <sys/types.h>
|
||
|
||
#include <memory>
|
||
#include <string>
|
||
#include <vector>
|
||
|
||
#include "minidump/minidump_extensions.h"
|
||
#include "minidump/minidump_rva_list_writer.h"
|
||
#include "minidump/minidump_writable.h"
|
||
|
||
namespace crashpad {
|
||
namespace internal {
|
||
|
||
//! \cond
|
||
|
||
struct MinidumpStringWriterUTF16Traits {
|
||
using StringType = std::u16string;
|
||
using MinidumpStringType = MINIDUMP_STRING;
|
||
};
|
||
|
||
struct MinidumpStringWriterUTF8Traits {
|
||
using StringType = std::string;
|
||
using MinidumpStringType = MinidumpUTF8String;
|
||
};
|
||
|
||
//! \endcond
|
||
|
||
//! \brief Writes a variable-length string to a minidump file in accordance with
|
||
//! the string type’s characteristics.
|
||
//!
|
||
//! MinidumpStringWriter objects should not be instantiated directly. To write
|
||
//! strings to minidump file, use the MinidumpUTF16StringWriter and
|
||
//! MinidumpUTF8StringWriter subclasses instead.
|
||
template <typename Traits>
|
||
class MinidumpStringWriter : public MinidumpWritable {
|
||
public:
|
||
MinidumpStringWriter();
|
||
|
||
MinidumpStringWriter(const MinidumpStringWriter&) = delete;
|
||
MinidumpStringWriter& operator=(const MinidumpStringWriter&) = delete;
|
||
|
||
~MinidumpStringWriter() override;
|
||
|
||
protected:
|
||
using MinidumpStringType = typename Traits::MinidumpStringType;
|
||
using StringType = typename Traits::StringType;
|
||
|
||
bool Freeze() override;
|
||
size_t SizeOfObject() override;
|
||
bool WriteObject(FileWriterInterface* file_writer) override;
|
||
|
||
//! \brief Sets the string to be written.
|
||
//!
|
||
//! \note Valid in #kStateMutable.
|
||
void set_string(const StringType& string) { string_.assign(string); }
|
||
|
||
//! \brief Retrieves the string to be written.
|
||
//!
|
||
//! \note Valid in any state.
|
||
const StringType& string() const { return string_; }
|
||
|
||
private:
|
||
std::unique_ptr<MinidumpStringType> string_base_;
|
||
StringType string_;
|
||
};
|
||
|
||
//! \brief Writes a variable-length UTF-16-encoded MINIDUMP_STRING to a minidump
|
||
//! file.
|
||
//!
|
||
//! MinidumpUTF16StringWriter objects should not be instantiated directly
|
||
//! outside of the MinidumpWritable family of classes.
|
||
class MinidumpUTF16StringWriter final
|
||
: public MinidumpStringWriter<MinidumpStringWriterUTF16Traits> {
|
||
public:
|
||
MinidumpUTF16StringWriter() : MinidumpStringWriter() {}
|
||
|
||
MinidumpUTF16StringWriter(const MinidumpUTF16StringWriter&) = delete;
|
||
MinidumpUTF16StringWriter& operator=(const MinidumpUTF16StringWriter&) =
|
||
delete;
|
||
|
||
~MinidumpUTF16StringWriter() override;
|
||
|
||
//! \brief Converts a UTF-8 string to UTF-16 and sets it as the string to be
|
||
//! written.
|
||
//!
|
||
//! \note Valid in #kStateMutable.
|
||
void SetUTF8(const std::string& string_utf8);
|
||
};
|
||
|
||
//! \brief Writes a variable-length UTF-8-encoded MinidumpUTF8String to a
|
||
//! minidump file.
|
||
//!
|
||
//! MinidumpUTF8StringWriter objects should not be instantiated directly outside
|
||
//! of the MinidumpWritable family of classes.
|
||
class MinidumpUTF8StringWriter final
|
||
: public MinidumpStringWriter<MinidumpStringWriterUTF8Traits> {
|
||
public:
|
||
MinidumpUTF8StringWriter() : MinidumpStringWriter() {}
|
||
|
||
MinidumpUTF8StringWriter(const MinidumpUTF8StringWriter&) = delete;
|
||
MinidumpUTF8StringWriter& operator=(const MinidumpUTF8StringWriter&) = delete;
|
||
|
||
~MinidumpUTF8StringWriter() override;
|
||
|
||
//! \brief Sets the string to be written.
|
||
//!
|
||
//! \note Valid in #kStateMutable.
|
||
void SetUTF8(const std::string& string_utf8) { set_string(string_utf8); }
|
||
|
||
//! \brief Retrieves the string to be written.
|
||
//!
|
||
//! \note Valid in any state.
|
||
const std::string& UTF8() const { return string(); }
|
||
};
|
||
|
||
//! \brief The writer for a MinidumpRVAList object in a minidump file,
|
||
//! containing a list of \a MinidumpStringWriterType objects.
|
||
template <typename MinidumpStringWriterType>
|
||
class MinidumpStringListWriter final : public MinidumpRVAListWriter {
|
||
public:
|
||
MinidumpStringListWriter();
|
||
|
||
MinidumpStringListWriter(const MinidumpStringListWriter&) = delete;
|
||
MinidumpStringListWriter& operator=(const MinidumpStringListWriter&) = delete;
|
||
|
||
~MinidumpStringListWriter() override;
|
||
|
||
//! \brief Adds a new \a Traits::MinidumpStringWriterType for each element in
|
||
//! \a vector to the MinidumpRVAList.
|
||
//!
|
||
//! \param[in] vector The vector to use as source data. Each string in the
|
||
//! vector is treated as a UTF-8 string, and a new string writer will be
|
||
//! created for each one and made a child of the MinidumpStringListWriter.
|
||
//!
|
||
//! \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 InitializeFromVector(const std::vector<std::string>& vector);
|
||
|
||
//! \brief Creates a new \a Traits::MinidumpStringWriterType object and adds
|
||
//! it to the MinidumpRVAList.
|
||
//!
|
||
//! This object creates a new string writer with string value \a string_utf8,
|
||
//! takes ownership of it, and becomes its parent in the overall tree of
|
||
//! MinidumpWritable objects.
|
||
//!
|
||
//! \note Valid in #kStateMutable.
|
||
void AddStringUTF8(const std::string& string_utf8);
|
||
|
||
//! \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;
|
||
};
|
||
|
||
} // namespace internal
|
||
|
||
using MinidumpUTF16StringListWriter = internal::MinidumpStringListWriter<
|
||
internal::MinidumpUTF16StringWriter>;
|
||
using MinidumpUTF8StringListWriter = internal::MinidumpStringListWriter<
|
||
internal::MinidumpUTF8StringWriter>;
|
||
|
||
} // namespace crashpad
|
||
|
||
#endif // CRASHPAD_MINIDUMP_MINIDUMP_STRING_WRITER_H_
|