103 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
 | |
| }) : (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     o[k2] = m[k];
 | |
| }));
 | |
| var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
 | |
|     Object.defineProperty(o, "default", { enumerable: true, value: v });
 | |
| }) : function(o, v) {
 | |
|     o["default"] = v;
 | |
| });
 | |
| var __importStar = (this && this.__importStar) || function (mod) {
 | |
|     if (mod && mod.__esModule) return mod;
 | |
|     var result = {};
 | |
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
 | |
|     __setModuleDefault(result, mod);
 | |
|     return result;
 | |
| };
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.getExecOutput = exports.exec = void 0;
 | |
| const string_decoder_1 = require("string_decoder");
 | |
| const tr = __importStar(require("./toolrunner"));
 | |
| /**
 | |
|  * Exec a command.
 | |
|  * Output will be streamed to the live console.
 | |
|  * Returns promise with return code
 | |
|  *
 | |
|  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped.
 | |
|  * @param     args               optional arguments for tool. Escaping is handled by the lib.
 | |
|  * @param     options            optional exec options.  See ExecOptions
 | |
|  * @returns   Promise<number>    exit code
 | |
|  */
 | |
| function exec(commandLine, args, options) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         const commandArgs = tr.argStringToArray(commandLine);
 | |
|         if (commandArgs.length === 0) {
 | |
|             throw new Error(`Parameter 'commandLine' cannot be null or empty.`);
 | |
|         }
 | |
|         // Path to tool to execute should be first arg
 | |
|         const toolPath = commandArgs[0];
 | |
|         args = commandArgs.slice(1).concat(args || []);
 | |
|         const runner = new tr.ToolRunner(toolPath, args, options);
 | |
|         return runner.exec();
 | |
|     });
 | |
| }
 | |
| exports.exec = exec;
 | |
| /**
 | |
|  * Exec a command and get the output.
 | |
|  * Output will be streamed to the live console.
 | |
|  * Returns promise with the exit code and collected stdout and stderr
 | |
|  *
 | |
|  * @param     commandLine           command to execute (can include additional args). Must be correctly escaped.
 | |
|  * @param     args                  optional arguments for tool. Escaping is handled by the lib.
 | |
|  * @param     options               optional exec options.  See ExecOptions
 | |
|  * @returns   Promise<ExecOutput>   exit code, stdout, and stderr
 | |
|  */
 | |
| function getExecOutput(commandLine, args, options) {
 | |
|     var _a, _b;
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         let stdout = '';
 | |
|         let stderr = '';
 | |
|         //Using string decoder covers the case where a mult-byte character is split
 | |
|         const stdoutDecoder = new string_decoder_1.StringDecoder('utf8');
 | |
|         const stderrDecoder = new string_decoder_1.StringDecoder('utf8');
 | |
|         const originalStdoutListener = (_a = options === null || options === void 0 ? void 0 : options.listeners) === null || _a === void 0 ? void 0 : _a.stdout;
 | |
|         const originalStdErrListener = (_b = options === null || options === void 0 ? void 0 : options.listeners) === null || _b === void 0 ? void 0 : _b.stderr;
 | |
|         const stdErrListener = (data) => {
 | |
|             stderr += stderrDecoder.write(data);
 | |
|             if (originalStdErrListener) {
 | |
|                 originalStdErrListener(data);
 | |
|             }
 | |
|         };
 | |
|         const stdOutListener = (data) => {
 | |
|             stdout += stdoutDecoder.write(data);
 | |
|             if (originalStdoutListener) {
 | |
|                 originalStdoutListener(data);
 | |
|             }
 | |
|         };
 | |
|         const listeners = Object.assign(Object.assign({}, options === null || options === void 0 ? void 0 : options.listeners), { stdout: stdOutListener, stderr: stdErrListener });
 | |
|         const exitCode = yield exec(commandLine, args, Object.assign(Object.assign({}, options), { listeners }));
 | |
|         //flush any remaining characters
 | |
|         stdout += stdoutDecoder.end();
 | |
|         stderr += stderrDecoder.end();
 | |
|         return {
 | |
|             exitCode,
 | |
|             stdout,
 | |
|             stderr
 | |
|         };
 | |
|     });
 | |
| }
 | |
| exports.getExecOutput = getExecOutput;
 | |
| //# sourceMappingURL=exec.js.map
 | 
