yanchengPowerSupply/node_modules/node-cmd/README.md

159 lines
3.8 KiB
Markdown

# node-cmd
*Node.js commandline/terminal interface.*
Simple commandline, terminal, or shell interface to allow you to run cli or bash style commands as if you were in the terminal.
Run commands asynchronously, and if needed can get the output as a string.
#### NPM Stats
npm info :
[![NPM](https://nodei.co/npm/node-cmd.png?downloads=true&downloadRank=true&stars=true)](https://nodei.co/npm/node-cmd/)
[See npm trends and stats for node-cmd](http://npm-stat.com/charts.html?package=node-cmd&author=&from=&to=)
![node-cmd npm version](https://img.shields.io/npm/v/node-cmd.svg) ![supported node version for node-cmd](https://img.shields.io/node/v/node-cmd.svg) ![total npm downloads for node-cmd](https://img.shields.io/npm/dt/node-cmd.svg) ![monthly npm downloads for node-cmd](https://img.shields.io/npm/dm/node-cmd.svg) ![npm licence for node-cmd](https://img.shields.io/npm/l/node-cmd.svg)
[![RIAEvangelist](https://avatars3.githubusercontent.com/u/369041?v=3&s=100)](https://github.com/RIAEvangelist)
GitHub info :
![node-cmd GitHub Release](https://img.shields.io/github/release/RIAEvangelist/node-cmd.svg) ![GitHub license node-cmd license](https://img.shields.io/github/license/RIAEvangelist/node-cmd.svg) ![open issues for node-cmd on GitHub](https://img.shields.io/github/issues/RIAEvangelist/node-cmd.svg)
Package details websites :
* [GitHub.io site](http://riaevangelist.github.io/node-cmd/ "node-cmd documentation"). A prettier version of this site.
* [NPM Module](https://www.npmjs.org/package/node-cmd "node-cmd npm module"). The npm page for the node-cmd module.
This work is licenced via the MIT Licence.
# Methods
|method | arguments | functionality | returns |
|-------|-----------|---------------|---------|
|run | command, callback | runs a command asynchronously| args for callback `err`,`data`,`stderr` |
|runSync| command | runs a command ***synchronously*** | obj {`err`,`data`,`stderr`} |
## Examples
```javascript
//*nix
var cmd=require('node-cmd');
//*nix supports multiline commands
cmd.runSync('touch ./example/example.created.file');
cmd.run(
`cd ./example
ls`,
function(err, data, stderr){
console.log('examples dir now contains the example file along with : ',data)
}
);
```
```javascript
//Windows
var cmd=require('node-cmd');
//Windows multiline commands are not guaranteed to work try condensing to a single line.
const syncDir=cmd.runSync('cd ./example & dir');
console.log(`
Sync Err ${syncDir.err}
Sync stderr: ${syncDir.stderr}
Sync Data ${syncDir.data}
`);
cmd.run(`dir`,
function(err, data, stderr){
console.log('the node-cmd dir contains : ',data)
}
);
```
```javascript
//clone this repo!
var cmd=require('node-cmd');
const syncClone=cmd.runSync('git clone https://github.com/RIAEvangelist/node-cmd.git');
console.log(syncClone);
```
### Getting the CMD Process ID
```javascript
var cmd=require('node-cmd');
var process=cmd.run('node');
console.log(process.pid);
```
### Running a python shell from node
```javascript
const cmd=require('node-cmd');
const processRef=cmd.run('python -i');
let data_line = '';
//listen to the python terminal output
processRef.stdout.on(
'data',
function(data) {
data_line += data;
if (data_line[data_line.length-1] == '\n') {
console.log(data_line);
}
}
);
const pythonTerminalInput=`primes = [2, 3, 5, 7]
for prime in primes:
print(prime)
`;
//show what we are doing
console.log(`>>>${pythonTerminalInput}`);
//send it to the open python terminal
processRef.stdin.write(pythonTerminalInput);
```
Output :
```python
>>>primes = [2, 3, 5, 7]
for prime in primes:
print(prime)
2
3
5
7
```