fix: no more need to hijack process.stdout on Win32 (#25765)
This commit is contained in:
parent
9717dff4fa
commit
57dc170e81
10 changed files with 9 additions and 63 deletions
1
BUILD.gn
1
BUILD.gn
|
@ -1149,6 +1149,7 @@ if (is_mac) {
|
||||||
"wtsapi32.lib",
|
"wtsapi32.lib",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
configs -= [ "//build/config/win:console" ]
|
||||||
configs += [
|
configs += [
|
||||||
"//build/config/win:windowed",
|
"//build/config/win:windowed",
|
||||||
"//build/config/win:delayloads",
|
"//build/config/win:delayloads",
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
import { Buffer } from 'buffer';
|
|
||||||
import { EventEmitter } from 'events';
|
import { EventEmitter } from 'events';
|
||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
import { Socket } from 'net';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as util from 'util';
|
|
||||||
|
|
||||||
const Module = require('module');
|
const Module = require('module');
|
||||||
|
|
||||||
|
@ -19,28 +16,6 @@ require('@electron/internal/common/init');
|
||||||
|
|
||||||
process._linkedBinding('electron_browser_event_emitter').setEventEmitterPrototype(EventEmitter.prototype);
|
process._linkedBinding('electron_browser_event_emitter').setEventEmitterPrototype(EventEmitter.prototype);
|
||||||
|
|
||||||
if (process.platform === 'win32') {
|
|
||||||
// Redirect node's console to use our own implementations, since node can not
|
|
||||||
// handle console output when running as GUI program.
|
|
||||||
const consoleLog = (...args: any[]) => {
|
|
||||||
// @ts-ignore this typing is incorrect; 'format' is an optional parameter
|
|
||||||
// See https://nodejs.org/api/util.html#util_util_format_format_args
|
|
||||||
return process.log(util.format(...args) + '\n');
|
|
||||||
};
|
|
||||||
const streamWrite: Socket['write'] = function (chunk: Buffer | string, encoding?: any, callback?: Function) {
|
|
||||||
if (Buffer.isBuffer(chunk)) {
|
|
||||||
chunk = chunk.toString(encoding);
|
|
||||||
}
|
|
||||||
process.log(chunk);
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
console.log = console.error = console.warn = consoleLog;
|
|
||||||
process.stdout.write = process.stderr.write = streamWrite;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Don't quit on fatal error.
|
// Don't quit on fatal error.
|
||||||
process.on('uncaughtException', function (error) {
|
process.on('uncaughtException', function (error) {
|
||||||
// Do nothing if the user has a custom uncaught exception handler.
|
// Do nothing if the user has a custom uncaught exception handler.
|
||||||
|
|
|
@ -11,7 +11,6 @@ feat_add_new_built_with_electron_variable_to_config_gypi.patch
|
||||||
feat_add_flags_for_low-level_hooks_and_exceptions.patch
|
feat_add_flags_for_low-level_hooks_and_exceptions.patch
|
||||||
fix_expose_tracing_agent_and_use_tracing_tracingcontroller_instead.patch
|
fix_expose_tracing_agent_and_use_tracing_tracingcontroller_instead.patch
|
||||||
pass_all_globals_through_require.patch
|
pass_all_globals_through_require.patch
|
||||||
call_process_log_from_fallback_stream_on_windows.patch
|
|
||||||
fixme_remove_async_id_assertion_check.patch
|
fixme_remove_async_id_assertion_check.patch
|
||||||
fixme_comment_trace_event_macro.patch
|
fixme_comment_trace_event_macro.patch
|
||||||
fix_key_gen_apis_are_not_available_in_boringssl.patch
|
fix_key_gen_apis_are_not_available_in_boringssl.patch
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Kevin Sawicki <kevinsawicki@gmail.com>
|
|
||||||
Date: Wed, 12 Oct 2016 09:43:26 -0700
|
|
||||||
Subject: Call process.log from fallback stream on Windows
|
|
||||||
|
|
||||||
(cherry picked from commit d31e629b4f2daf3500a485caab2b2990a41e3ad4)
|
|
||||||
|
|
||||||
diff --git a/lib/internal/bootstrap/switches/is_main_thread.js b/lib/internal/bootstrap/switches/is_main_thread.js
|
|
||||||
index 08623898edafacfa8cee47ab35bd75887f9d3e2a..828589d4047ac49d16e9080ad1f364484941aa6e 100644
|
|
||||||
--- a/lib/internal/bootstrap/switches/is_main_thread.js
|
|
||||||
+++ b/lib/internal/bootstrap/switches/is_main_thread.js
|
|
||||||
@@ -85,6 +85,11 @@ function createWritableStdioStream(fd) {
|
|
||||||
const { Writable } = require('stream');
|
|
||||||
stream = new Writable({
|
|
||||||
write(buf, enc, cb) {
|
|
||||||
+ if (process.platform === 'win32' &&
|
|
||||||
+ process.env.ELECTRON_RUN_AS_NODE &&
|
|
||||||
+ !process.env.ELECTRON_NO_ATTACH_CONSOLE) {
|
|
||||||
+ process.log(buf.toString());
|
|
||||||
+ }
|
|
||||||
cb();
|
|
||||||
}
|
|
||||||
});
|
|
|
@ -212,9 +212,6 @@ int NodeMain(int argc, char* argv[]) {
|
||||||
node::SetIsolateUpForNode(isolate, is);
|
node::SetIsolateUpForNode(isolate, is);
|
||||||
|
|
||||||
gin_helper::Dictionary process(isolate, env->process_object());
|
gin_helper::Dictionary process(isolate, env->process_object());
|
||||||
#if defined(OS_WIN)
|
|
||||||
process.SetMethod("log", &ElectronBindings::Log);
|
|
||||||
#endif
|
|
||||||
process.SetMethod("crash", &ElectronBindings::Crash);
|
process.SetMethod("crash", &ElectronBindings::Crash);
|
||||||
|
|
||||||
// Setup process.crashReporter in child node processes
|
// Setup process.crashReporter in child node processes
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
#include "shell/common/api/electron_bindings.h"
|
#include "shell/common/api/electron_bindings.h"
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <iostream>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -48,7 +47,6 @@ void ElectronBindings::BindProcess(v8::Isolate* isolate,
|
||||||
// These bindings are shared between sandboxed & unsandboxed renderers
|
// These bindings are shared between sandboxed & unsandboxed renderers
|
||||||
process->SetMethod("crash", &Crash);
|
process->SetMethod("crash", &Crash);
|
||||||
process->SetMethod("hang", &Hang);
|
process->SetMethod("hang", &Hang);
|
||||||
process->SetMethod("log", &Log);
|
|
||||||
process->SetMethod("getCreationTime", &GetCreationTime);
|
process->SetMethod("getCreationTime", &GetCreationTime);
|
||||||
process->SetMethod("getHeapStatistics", &GetHeapStatistics);
|
process->SetMethod("getHeapStatistics", &GetHeapStatistics);
|
||||||
process->SetMethod("getBlinkMemoryInfo", &GetBlinkMemoryInfo);
|
process->SetMethod("getBlinkMemoryInfo", &GetBlinkMemoryInfo);
|
||||||
|
@ -126,11 +124,6 @@ void ElectronBindings::OnCallNextTick(uv_async_t* handle) {
|
||||||
self->pending_next_ticks_.clear();
|
self->pending_next_ticks_.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
|
||||||
void ElectronBindings::Log(const base::string16& message) {
|
|
||||||
std::cout << message << std::flush;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void ElectronBindings::Crash() {
|
void ElectronBindings::Crash() {
|
||||||
volatile int* zero = nullptr;
|
volatile int* zero = nullptr;
|
||||||
|
|
|
@ -12,7 +12,6 @@
|
||||||
#include "base/macros.h"
|
#include "base/macros.h"
|
||||||
#include "base/memory/scoped_refptr.h"
|
#include "base/memory/scoped_refptr.h"
|
||||||
#include "base/process/process_metrics.h"
|
#include "base/process/process_metrics.h"
|
||||||
#include "base/strings/string16.h"
|
|
||||||
#include "shell/common/gin_helper/promise.h"
|
#include "shell/common/gin_helper/promise.h"
|
||||||
#include "shell/common/node_bindings.h"
|
#include "shell/common/node_bindings.h"
|
||||||
#include "uv.h" // NOLINT(build/include_directory)
|
#include "uv.h" // NOLINT(build/include_directory)
|
||||||
|
@ -48,7 +47,6 @@ class ElectronBindings {
|
||||||
gin_helper::Dictionary* process,
|
gin_helper::Dictionary* process,
|
||||||
base::ProcessMetrics* metrics);
|
base::ProcessMetrics* metrics);
|
||||||
|
|
||||||
static void Log(const base::string16& message);
|
|
||||||
static void Crash();
|
static void Crash();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -159,6 +159,12 @@ describe('node feature', () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('process.stdout', () => {
|
||||||
|
it('is a real Node stream', () => {
|
||||||
|
expect((process.stdout as any)._type).to.not.be.undefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
ifdescribe(features.isRunAsNodeEnabled())('inspector', () => {
|
ifdescribe(features.isRunAsNodeEnabled())('inspector', () => {
|
||||||
let child: childProcess.ChildProcessWithoutNullStreams;
|
let child: childProcess.ChildProcessWithoutNullStreams;
|
||||||
let exitPromise: Promise<any[]>;
|
let exitPromise: Promise<any[]>;
|
||||||
|
|
2
spec/fixtures/module/run-as-node.js
vendored
2
spec/fixtures/module/run-as-node.js
vendored
|
@ -1,5 +1,5 @@
|
||||||
console.log(JSON.stringify({
|
console.log(JSON.stringify({
|
||||||
processLog: typeof process.log,
|
stdoutType: process.stdout._type,
|
||||||
processType: typeof process.type,
|
processType: typeof process.type,
|
||||||
window: typeof window
|
window: typeof window
|
||||||
}));
|
}));
|
||||||
|
|
|
@ -122,7 +122,7 @@ describe('node feature', () => {
|
||||||
});
|
});
|
||||||
await emittedOnce(child.stdout, 'close');
|
await emittedOnce(child.stdout, 'close');
|
||||||
expect(JSON.parse(output)).to.deep.equal({
|
expect(JSON.parse(output)).to.deep.equal({
|
||||||
processLog: process.platform === 'win32' ? 'function' : 'undefined',
|
stdoutType: 'pipe',
|
||||||
processType: 'undefined',
|
processType: 'undefined',
|
||||||
window: 'undefined'
|
window: 'undefined'
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue