Skip to content

Commit d261274

Browse files
aduh95Renegade334
authored andcommitted
doc: deprecate passing an empty string to options.shell
Co-authored-by: Renegade334 <[email protected]> PR-URL: #58564 Reviewed-By: Marco Ippolito <[email protected]> Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Ulises Gascón <[email protected]> Reviewed-By: James M Snell <[email protected]>
1 parent efb28f7 commit d261274

File tree

1 file changed

+24
-0
lines changed

1 file changed

+24
-0
lines changed

doc/api/deprecations.md

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3955,6 +3955,29 @@ Instantiating classes without the `new` qualifier exported by the `node:http` mo
39553955
It is recommended to use the `new` qualifier instead. This applies to all http classes, such as
39563956
`OutgoingMessage`, `IncomingMessage`, `ServerResponse` and `ClientRequest`.
39573957

3958+
### DEP0196: Calling `node:child_process` functions with `options.shell` as an empty string
3959+
3960+
<!-- YAML
3961+
changes:
3962+
- version: REPLACEME
3963+
pr-url: https://github.com/nodejs/node/pull/58564
3964+
description: Documentation-only deprecation.
3965+
-->
3966+
3967+
Type: Documentation-only
3968+
3969+
Calling the process-spawning functions with `{ shell: '' }` is almost certainly
3970+
unintentional, and can cause aberrant behavior.
3971+
3972+
To make [`child_process.execFile`][] or [`child_process.spawn`][] invoke the
3973+
default shell, use `{ shell: true }`. If the intention is not to invoke a shell
3974+
(default behavior), either omit the `shell` option, or set it to `false` or a
3975+
nullish value.
3976+
3977+
To make [`child_process.exec`][] invoke the default shell, either omit the
3978+
`shell` option, or set it to a nullish value. If the intention is not to invoke
3979+
a shell, use [`child_process.execFile`][] instead.
3980+
39583981
[DEP0142]: #dep0142-repl_builtinlibs
39593982
[NIST SP 800-38D]: https://nvlpubs.nist.gov/nistpubs/Legacy/SP/nistspecialpublication800-38d.pdf
39603983
[RFC 6066]: https://tools.ietf.org/html/rfc6066#section-3
@@ -3985,6 +4008,7 @@ It is recommended to use the `new` qualifier instead. This applies to all http c
39854008
[`asyncResource.runInAsyncScope()`]: async_context.md#asyncresourceruninasyncscopefn-thisarg-args
39864009
[`buffer.subarray`]: buffer.md#bufsubarraystart-end
39874010
[`child_process.execFile`]: child_process.md#child_processexecfilefile-args-options-callback
4011+
[`child_process.exec`]: child_process.md#child_processexeccommand-options-callback
39884012
[`child_process.spawn`]: child_process.md#child_processspawncommand-args-options
39894013
[`child_process`]: child_process.md
39904014
[`clearInterval()`]: timers.md#clearintervaltimeout

0 commit comments

Comments
 (0)