| Server IP : 68.183.124.220 / Your IP : 216.73.217.137 Web Server : Apache/2.4.18 (Ubuntu) System : Linux Sandbox-A 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : gavin ( 1000) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/gavin/workspace/happymandarin/node_modules/selenium-webdriver/io/ |
Upload File : |
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The SFC licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
'use strict';
var fs = require('fs'),
path = require('path'),
rimraf = require('rimraf'),
tmp = require('tmp');
// PUBLIC API
/**
* Recursively removes a directory and all of its contents. This is equivalent
* to {@code rm -rf} on a POSIX system.
* @param {string} dirPath Path to the directory to remove.
* @return {!Promise} A promise to be resolved when the operation has
* completed.
*/
exports.rmDir = function(dirPath) {
return new Promise(function(fulfill, reject) {
var numAttempts = 0;
attemptRm();
function attemptRm() {
numAttempts += 1;
rimraf(dirPath, function(err) {
if (err) {
if (err.code === 'ENOTEMPTY' && numAttempts < 2) {
attemptRm();
return;
}
reject(err);
} else {
fulfill();
}
});
}
});
};
/**
* Copies one file to another.
* @param {string} src The source file.
* @param {string} dst The destination file.
* @return {!Promise<string>} A promise for the copied file's path.
*/
exports.copy = function(src, dst) {
return new Promise(function(fulfill, reject) {
var rs = fs.createReadStream(src);
rs.on('error', reject);
rs.on('end', () => fulfill(dst));
var ws = fs.createWriteStream(dst);
ws.on('error', reject);
rs.pipe(ws);
});
};
/**
* Recursively copies the contents of one directory to another.
* @param {string} src The source directory to copy.
* @param {string} dst The directory to copy into.
* @param {(RegExp|function(string): boolean)=} opt_exclude An exclusion filter
* as either a regex or predicate function. All files matching this filter
* will not be copied.
* @return {!Promise<string>} A promise for the destination
* directory's path once all files have been copied.
*/
exports.copyDir = function(src, dst, opt_exclude) {
var predicate = opt_exclude;
if (opt_exclude && typeof opt_exclude !== 'function') {
predicate = function(p) {
return !opt_exclude.test(p);
};
}
// TODO(jleyba): Make this function completely async.
if (!fs.existsSync(dst)) {
fs.mkdirSync(dst);
}
var files = fs.readdirSync(src);
files = files.map(function(file) {
return path.join(src, file);
});
if (predicate) {
files = files.filter(/** @type {function(string): boolean} */(predicate));
}
var results = [];
files.forEach(function(file) {
var stats = fs.statSync(file);
var target = path.join(dst, path.basename(file));
if (stats.isDirectory()) {
if (!fs.existsSync(target)) {
fs.mkdirSync(target, stats.mode);
}
results.push(exports.copyDir(file, target, predicate));
} else {
results.push(exports.copy(file, target));
}
});
return Promise.all(results).then(() => dst);
};
/**
* Tests if a file path exists.
* @param {string} aPath The path to test.
* @return {!Promise<boolean>} A promise for whether the file exists.
*/
exports.exists = function(aPath) {
return new Promise(function(fulfill, reject) {
let type = typeof aPath;
if (type !== 'string') {
reject(TypeError(`expected string path, but got ${type}`));
} else {
fs.exists(aPath, fulfill);
}
});
};
/**
* Deletes a name from the filesystem and possibly the file it refers to. Has
* no effect if the file does not exist.
* @param {string} aPath The path to remove.
* @return {!Promise} A promise for when the file has been removed.
*/
exports.unlink = function(aPath) {
return new Promise(function(fulfill, reject) {
fs.exists(aPath, function(exists) {
if (exists) {
fs.unlink(aPath, function(err) {
err && reject(err) || fulfill();
});
} else {
fulfill();
}
});
});
};
/**
* @return {!Promise<string>} A promise for the path to a temporary directory.
* @see https://www.npmjs.org/package/tmp
*/
exports.tmpDir = function() {
return new Promise(function(fulfill, reject) {
tmp.dir(function(error, value) {
error ? reject(error) : fulfill(value);
});
});
};
/**
* @param {{postfix: string}=} opt_options Temporary file options.
* @return {!Promise<string>} A promise for the path to a temporary file.
* @see https://www.npmjs.org/package/tmp
*/
exports.tmpFile = function(opt_options) {
return new Promise(function(fulfill, reject) {
let callback = function(
/** Error */err,
/** (string|undefined) */value) {
err ? reject(err) : fulfill(value);
};
// |tmp.file| checks arguments length to detect options rather than doing a
// truthy check, so we must only pass options if there are some to pass.
if (opt_options) {
tmp.file(opt_options, callback);
} else {
tmp.file(callback);
}
});
};
/**
* Searches the {@code PATH} environment variable for the given file.
* @param {string} file The file to locate on the PATH.
* @param {boolean=} opt_checkCwd Whether to always start with the search with
* the current working directory, regardless of whether it is explicitly
* listed on the PATH.
* @return {?string} Path to the located file, or {@code null} if it could
* not be found.
*/
exports.findInPath = function(file, opt_checkCwd) {
let dirs = [];
if (opt_checkCwd) {
dirs.push(process.cwd());
}
dirs.push.apply(dirs, process.env['PATH'].split(path.delimiter));
let foundInDir = dirs.find(dir => {
let tmp = path.join(dir, file);
try {
let stats = fs.statSync(tmp);
return stats.isFile() && !stats.isDirectory();
} catch (ex) {
return false;
}
});
return foundInDir ? path.join(foundInDir, file) : null;
};