'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _path = require('path'); var _path2 = _interopRequireDefault(_path); var _isWindows = require('./is-windows'); var _isWindows2 = _interopRequireDefault(_isWindows); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } exports.default = commandConvert; /** * Converts an environment variable usage to be appropriate for the current OS * @param {String} command Command to convert * @param {Object} env Map of the current environment variable names and their values * @param {boolean} normalize If the command should be normalized using `path` * after converting * @returns {String} Converted command */ function commandConvert(command, env) { var normalize = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; if (!(0, _isWindows2.default)()) { return command; } var envUnixRegex = /\$(\w+)|\${(\w+)}/g; // $my_var or ${my_var} var convertedCmd = command.replace(envUnixRegex, function (match, $1, $2) { var varName = $1 || $2; // In Windows, non-existent variables are not replaced by the shell, // so for example "echo %FOO%" will literally print the string "%FOO%", as // opposed to printing an empty string in UNIX. See kentcdodds/cross-env#145 // If the env variable isn't defined at runtime, just strip it from the command entirely return env[varName] ? `%${varName}%` : ''; }); // Normalization is required for commands with relative paths // For example, `./cmd.bat`. See kentcdodds/cross-env#127 // However, it should not be done for command arguments. // See https://github.com/kentcdodds/cross-env/pull/130#issuecomment-319887970 return normalize === true ? _path2.default.normalize(convertedCmd) : convertedCmd; }