From 386b9219143775c600d29841138bb3e3f704a418 Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Tue, 26 Nov 2013 22:05:32 +0800 Subject: [PATCH] win: Register msdia80.dll automatically when dumping symbols. --- docs/development/build-instructions-windows.md | 8 -------- package.json | 1 + tools/win/generate_breakpad_symbols.py | 8 ++++++++ tools/win/register_msdia80_dll.js | 12 ++++++++++++ 4 files changed, 21 insertions(+), 8 deletions(-) create mode 100644 tools/win/register_msdia80_dll.js diff --git a/docs/development/build-instructions-windows.md b/docs/development/build-instructions-windows.md index 4a9613cec39..cfa2e656b8b 100644 --- a/docs/development/build-instructions-windows.md +++ b/docs/development/build-instructions-windows.md @@ -18,14 +18,6 @@ softwares: * [Windows 7 SDK](http://www.microsoft.com/en-us/download/details.aspx?id=8279) * `Windows Headers` and `Visual C++ Compilers` are required. -If you want to dump breakpad symbols you also need to do this (you are free to -skip this step if you don't know what it is): - -1. Get a copy of `msdia80.dll` and put it in - `C:\Program Files\Common Files\Microsoft Shared\VC\`. -2. As Administrator, run: - `regsvr32 "C:\Program Files\Common Files\Microsoft Shared\VC\msdia80.dll"`. - The instructions bellow are executed under [cygwin](http://www.cygwin.com), but it's not a requirement, you can also build atom-shell under Windows's console or other terminals. diff --git a/package.json b/package.json index fcdba23b76d..81f9c618974 100644 --- a/package.json +++ b/package.json @@ -7,6 +7,7 @@ "coffeelint": "~0.6.1", "mocha": "~1.13.0", "walkdir": "~0.0.7", + "runas": "~0.2.0", "formidable": "~1.0.14", "unzip": "~0.1.9", diff --git a/tools/win/generate_breakpad_symbols.py b/tools/win/generate_breakpad_symbols.py index 2e0c07c1850..254b3592721 100644 --- a/tools/win/generate_breakpad_symbols.py +++ b/tools/win/generate_breakpad_symbols.py @@ -47,6 +47,13 @@ def mkdir_p(path): else: raise +def RegisterRequiredDll(): + register = os.path.join(os.path.dirname(__file__), 'register_msdia80_dll.js') + node = os.path.join(SOURCE_ROOT, 'out', 'Release', 'atom.exe') + os.environ['ATOM_SHELL_INTERNAL_RUN_AS_NODE'] = '1' + subprocess.check_call([node, register]); + + def GenerateSymbols(options, binaries): """Dumps the symbols of binary and places them in the given directory.""" @@ -118,6 +125,7 @@ def main(): for directory in directories: pdbs += glob.glob(os.path.join(directory, '*.pdb')) + RegisterRequiredDll(); GenerateSymbols(options, pdbs) return 0 diff --git a/tools/win/register_msdia80_dll.js b/tools/win/register_msdia80_dll.js new file mode 100644 index 00000000000..a5a0508e18f --- /dev/null +++ b/tools/win/register_msdia80_dll.js @@ -0,0 +1,12 @@ +var fs = require('fs'); +var path = require('path'); +var runas = require('runas'); + +var source = path.resolve(__dirname, '..', '..', 'vendor', 'breakpad', 'msdia80.dll'); +var target = 'C:\\Program Files\\Common Files\\Microsoft Shared\\VC\\msdia80.dll'; +if (fs.existsSync(target)) + return; + +var copy = 'copy "' + source + '" "' + target + '"'; +var register = 'regsvr32 "' + target + '"'; +runas('cmd', ['/K', copy + ' & ' + register + ' & exit']);