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_HANDLER_USER_STREAM_DATA_SOURCE_H_
|
|
|
|
#define CRASHPAD_HANDLER_USER_STREAM_DATA_SOURCE_H_
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace crashpad {
|
|
|
|
|
|
|
|
class MinidumpFileWriter;
|
|
|
|
class MinidumpUserExtensionStreamDataSource;
|
|
|
|
class ProcessSnapshot;
|
|
|
|
|
|
|
|
//! \brief Extensibility interface for embedders who wish to add custom streams
|
|
|
|
//! to minidumps.
|
|
|
|
class UserStreamDataSource {
|
|
|
|
public:
|
|
|
|
virtual ~UserStreamDataSource() {}
|
|
|
|
|
|
|
|
//! \brief Produce the contents for an extension stream for a crashed program.
|
|
|
|
//!
|
|
|
|
//! Called after \a process_snapshot has been initialized for the crashed
|
|
|
|
//! process to (optionally) produce the contents of a user extension stream
|
|
|
|
//! that will be attached to the minidump.
|
|
|
|
//!
|
|
|
|
//! \param[in] process_snapshot An initialized snapshot for the crashed
|
|
|
|
//! process.
|
|
|
|
//!
|
|
|
|
//! \return A new data source for the stream to add to the minidump or
|
|
|
|
//! `nullptr` on failure or to opt out of adding a stream.
|
|
|
|
virtual std::unique_ptr<MinidumpUserExtensionStreamDataSource>
|
|
|
|
ProduceStreamData(ProcessSnapshot* process_snapshot) = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
using UserStreamDataSources =
|
|
|
|
std::vector<std::unique_ptr<UserStreamDataSource>>;
|
|
|
|
|
|
|
|
//! \brief Adds user extension streams to a minidump.
|
|
|
|
//!
|
|
|
|
//! Dispatches to each source in \a user_stream_data_sources and adds returned
|
|
|
|
//! extension streams to \a minidump_file_writer.
|
|
|
|
//!
|
|
|
|
//! \param[in] user_stream_data_sources A pointer to the data sources, or
|
|
|
|
//! `nullptr`.
|
|
|
|
//! \param[in] process_snapshot An initialized snapshot to the crashing process.
|
|
|
|
//! \param[in] minidump_file_writer Any extension streams will be added to this
|
|
|
|
//! minidump.
|
|
|
|
void AddUserExtensionStreams(
|
|
|
|
const UserStreamDataSources* user_stream_data_sources,
|
|
|
|
ProcessSnapshot* process_snapshot,
|
|
|
|
MinidumpFileWriter* minidump_file_writer);
|
|
|
|
|
|
|
|
} // namespace crashpad
|
|
|
|
|
|
|
|
#endif // CRASHPAD_HANDLER_USER_STREAM_DATA_SOURCE_H_
|