// Copyright 2015 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_HANDLER_HANDLER_MAIN_H_ #define CRASHPAD_HANDLER_HANDLER_MAIN_H_ #include "build/build_config.h" #include "handler/user_stream_data_source.h" namespace crashpad { //! \brief The `main()` of the `crashpad_handler` binary. //! //! This is exposed so that `crashpad_handler` can be embedded into another //! binary, but called and used as if it were a standalone executable. //! //! \param[in] argc \a argc as passed to `main()`. //! \param[in] argv \a argv as passed to `main()`. //! \param[in] user_stream_sources An optional vector containing the //! extensibility data sources to call on crash. Each time a minidump is //! created, the sources are called in turn. Any streams returned are added //! to the minidump. int HandlerMain(int argc, char* argv[], const UserStreamDataSources* user_stream_sources); #if BUILDFLAG(IS_ANDROID) //! \brief The `main()` entry point for Android libraries. //! //! This symbol is the entry point for crashpad when it is dynamically loaded //! using /system/bin/linker. //! //! \sa CrashpadClient::StartHandlerWithLinkerAtCrash() extern "C" int CrashpadHandlerMain(int argc, char* argv[]); #endif } // namespace crashpad #endif // CRASHPAD_HANDLER_HANDLER_MAIN_H_