win: Start as crash service when ATOM_SHELL_INTERNAL_CRASH_SERVICE is set.
This commit is contained in:
parent
4bab284f2e
commit
6f8c46d2f4
4 changed files with 37 additions and 4 deletions
|
@ -17,6 +17,7 @@
|
||||||
|
|
||||||
#include "app/atom_main_delegate.h"
|
#include "app/atom_main_delegate.h"
|
||||||
#include "base/environment.h"
|
#include "base/environment.h"
|
||||||
|
#include "common/crash_reporter/win/crash_service_main.h"
|
||||||
#include "content/public/app/startup_helper_win.h"
|
#include "content/public/app/startup_helper_win.h"
|
||||||
#include "sandbox/win/src/sandbox_types.h"
|
#include "sandbox/win/src/sandbox_types.h"
|
||||||
#else // defined(OS_WIN)
|
#else // defined(OS_WIN)
|
||||||
|
@ -47,7 +48,7 @@ int APIENTRY wWinMain(HINSTANCE instance, HINSTANCE, wchar_t* cmd, int) {
|
||||||
freopen_s(&dontcare, "CON", "r", stdin);
|
freopen_s(&dontcare, "CON", "r", stdin);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string node_indicator;
|
std::string node_indicator, crash_service_indicator;
|
||||||
if (env->GetVar("ATOM_SHELL_INTERNAL_RUN_AS_NODE", &node_indicator) &&
|
if (env->GetVar("ATOM_SHELL_INTERNAL_RUN_AS_NODE", &node_indicator) &&
|
||||||
node_indicator == "1") {
|
node_indicator == "1") {
|
||||||
// Convert argv to to UTF8
|
// Convert argv to to UTF8
|
||||||
|
@ -85,6 +86,10 @@ int APIENTRY wWinMain(HINSTANCE instance, HINSTANCE, wchar_t* cmd, int) {
|
||||||
}
|
}
|
||||||
// Now that conversion is done, we can finally start.
|
// Now that conversion is done, we can finally start.
|
||||||
return node::Start(argc, argv);
|
return node::Start(argc, argv);
|
||||||
|
} else if (env->GetVar("ATOM_SHELL_INTERNAL_CRASH_SERVICE",
|
||||||
|
&crash_service_indicator) &&
|
||||||
|
crash_service_indicator == "1") {
|
||||||
|
return crash_service::Main(cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
sandbox::SandboxInterfaceInfo sandbox_info = {0};
|
sandbox::SandboxInterfaceInfo sandbox_info = {0};
|
||||||
|
|
1
atom.gyp
1
atom.gyp
|
@ -340,6 +340,7 @@
|
||||||
'-limm32.lib',
|
'-limm32.lib',
|
||||||
'-loleacc.lib',
|
'-loleacc.lib',
|
||||||
'-lComdlg32.lib',
|
'-lComdlg32.lib',
|
||||||
|
'-lWininet.lib',
|
||||||
'<(atom_source_root)/<(libchromiumcontent_library_dir)/chromiumviews.lib',
|
'<(atom_source_root)/<(libchromiumcontent_library_dir)/chromiumviews.lib',
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|
|
@ -4,10 +4,37 @@
|
||||||
|
|
||||||
#include "common/crash_reporter/win/crash_service_main.h"
|
#include "common/crash_reporter/win/crash_service_main.h"
|
||||||
|
|
||||||
|
#include "base/at_exit.h"
|
||||||
|
#include "base/command_line.h"
|
||||||
|
#include "base/files/file_path.h"
|
||||||
|
#include "base/path_service.h"
|
||||||
|
#include "base/logging.h"
|
||||||
|
#include "common/crash_reporter/win/crash_service.h"
|
||||||
|
|
||||||
namespace crash_service {
|
namespace crash_service {
|
||||||
|
|
||||||
int Main() {
|
int Main(const wchar_t* cmd_line) {
|
||||||
return 0;
|
// Initialize all Chromium things.
|
||||||
|
base::AtExitManager exit_manager;
|
||||||
|
CommandLine::Init(0, NULL);
|
||||||
|
|
||||||
|
VLOG(1) << "Session start. cmdline is [" << cmd_line << "]";
|
||||||
|
|
||||||
|
wchar_t temp_dir[MAX_PATH] = { 0 };
|
||||||
|
::GetTempPathW(MAX_PATH, temp_dir);
|
||||||
|
base::FilePath temp_path(temp_dir);
|
||||||
|
|
||||||
|
breakpad::CrashService crash_service;
|
||||||
|
if (!crash_service.Initialize(temp_path, temp_path))
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
VLOG(1) << "Ready to process crash requests";
|
||||||
|
|
||||||
|
// Enter the message loop.
|
||||||
|
int retv = crash_service.ProcessingLoop();
|
||||||
|
// Time to exit.
|
||||||
|
VLOG(1) << "Session end. return code is " << retv;
|
||||||
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace crash_service
|
} // namespace crash_service
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
namespace crash_service {
|
namespace crash_service {
|
||||||
|
|
||||||
// Program entry, should be called by main();
|
// Program entry, should be called by main();
|
||||||
int Main();
|
int Main(const wchar_t* cmd_line);
|
||||||
|
|
||||||
} // namespace crash_service
|
} // namespace crash_service
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue