From 3368fdde484561c68940680777186e9d385969dd Mon Sep 17 00:00:00 2001 From: youngvform Date: Tue, 26 Jan 2021 21:08:06 +0900 Subject: [PATCH] Fix to parse REACT_EDITOR in env (#21331) I made an issue #[21330](https://github.com/vercel/next.js/issues/21330). I think this line https://github.com/vercel/next.js/blob/0bd175264b000895cccd75f4499bdf55daad4882/packages/react-dev-overlay/src/internal/helpers/launchEditor.ts#L216 return string array and toLowerCase is undefined in string array so throw error. I fixed it by referring to [launchEditor](https://github.com/facebook/create-react-app/blob/7e4949a20fc828577fb7626a3262832422f3ae3b/packages/react-dev-utils/launchEditor.js) of create react app. --- .../src/internal/helpers/launchEditor.ts | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/packages/react-dev-overlay/src/internal/helpers/launchEditor.ts b/packages/react-dev-overlay/src/internal/helpers/launchEditor.ts index 8efcf9d9e8a57..5cd817c8e8d0e 100644 --- a/packages/react-dev-overlay/src/internal/helpers/launchEditor.ts +++ b/packages/react-dev-overlay/src/internal/helpers/launchEditor.ts @@ -210,7 +210,7 @@ function getArgumentsForLineNumber( } } -function guessEditor(): string | null { +function guessEditor(): string[] { // Explicit config always wins if (process.env.REACT_EDITOR) { return shellQuote.parse(process.env.REACT_EDITOR) @@ -226,7 +226,7 @@ function guessEditor(): string | null { for (let i = 0; i < processNames.length; i++) { const processName = processNames[i] if (output.indexOf(processName) !== -1) { - return (COMMON_EDITORS_MACOS as any)[processName] + return [(COMMON_EDITORS_MACOS as any)[processName]] } } } else if (process.platform === 'win32') { @@ -242,7 +242,7 @@ function guessEditor(): string | null { const processPath = runningProcesses[i].trim() const processName = path.basename(processPath) if (COMMON_EDITORS_WIN.indexOf(processName) !== -1) { - return processPath + return [processPath] } } } else if (process.platform === 'linux') { @@ -256,7 +256,7 @@ function guessEditor(): string | null { for (let i = 0; i < processNames.length; i++) { const processName = processNames[i] if (output.indexOf(processName) !== -1) { - return (COMMON_EDITORS_LINUX as any)[processName] as string + return [(COMMON_EDITORS_LINUX as any)[processName] as string] } } } @@ -266,12 +266,12 @@ function guessEditor(): string | null { // Last resort, use old skool env vars if (process.env.VISUAL) { - return process.env.VISUAL + return [process.env.VISUAL] } else if (process.env.EDITOR) { - return process.env.EDITOR + return [process.env.EDITOR] } - return null + return [] } function printInstructions(fileName: string, errorMessage: string | null) { @@ -317,8 +317,7 @@ function launchEditor(fileName: string, lineNumber: number, colNumber: number) { colNumber = 1 } - const editor = guessEditor() - let args: string[] = [] + let [editor, ...args] = guessEditor() if (!editor) { printInstructions(fileName, null)