system_assignation/node_modules/cross-spawn-windows-exe/README.md

68 lines
2.4 KiB
Markdown
Raw Normal View History

2022-03-24 09:22:39 -04:00
# `cross-spawn-windows-exe`
> Cross-platform support for running Windows executables via Node.js.
[![CI](https://github.com/malept/cross-spawn-windows-exe/workflows/CI/badge.svg)](https://github.com/malept/cross-spawn-windows-exe/actions?query=workflow%3ACI)
[![codecov](https://codecov.io/gh/malept/cross-spawn-windows-exe/branch/main/graph/badge.svg)](https://codecov.io/gh/malept/cross-spawn-windows-exe)
Utilizes [`@malept/cross-spawn-promise`](https://npm.im/@malept/cross-spawn-promise) (and by
extension, [`cross-spawn`](https://npm.im/cross-spawn)) to execute Windows executables regardless
of platform.
For all platforms, Node 10 or above is required.
On non-Windows, non-WSL host systems, the following dependencies are required:
- .NET executables: [Mono](https://www.mono-project.com/)
- All other Windows executables: [Wine](https://www.winehq.org/)
## Usage
Using the `cross-spawn-windows-exe` API is similar in terms of function signature to `spawn` in
`@malept/cross-spawn-promise`.
### Running a .NET executable
```javascript
// Note: top-level await exists in Node >= 14.8.0. In earlier versions of Node, please wrap in an
// async function.
const { spawnDotNet } = require("cross-spawn-windows-exe");
await spawnDotNet("./hellodotnet.exe", ["--arg1"]);
```
### Running a Windows executable
```javascript
// Note: top-level await exists in Node >= 14.8.0. In earlier versions of Node, please wrap in an
// async function.
const { spawnExe } = require("cross-spawn-windows-exe");
await spawnExe("./hellowindows.exe", ["--arg1"]);
```
### Normalizing Paths
Executables generally can't handle UNIX-style paths that Windows Subsystem for Linux (WSL) passes
in, since it's a Linux environment. This module provides a function to convert those paths from
UNIX-style to Windows-style (via `wslpath`, which should be installed by default on every WSL
distribution), if the host system is determined to be WSL. For non-WSL environments, this is a
no-op.
```javascript
// Note: top-level await exists in Node >= 14.8.0. In earlier versions of Node, please wrap in an
// async function.
const { normalizePath, spawnExe } = require("cross-spawn-windows-exe");
const normalizedPath = await normalizePath("/tmp/foo");
await spawnExe("./openfile.exe", ["--filename", normalizedPath]);
```
## Legal
This module is licensed under the [Apache License, version 2.0](https://www.apache.org/licenses/LICENSE-2.0).
See `LICENSE` for details.