diff options
| author | Nevena Bojovic <nenabojov@gmail.com> | 2022-03-01 20:05:50 +0100 | 
|---|---|---|
| committer | Nevena Bojovic <nenabojov@gmail.com> | 2022-03-01 20:05:50 +0100 | 
| commit | 291803c31f829fe0d32bb3207bc11def95a7408c (patch) | |
| tree | c7d43107d79291b19d8c9eceefbe91c9f9a52acf /sandbox/testAppNevena/Front/node_modules/tmp | |
| parent | 1fa69862057db4db53cfda5be9c24b4228ef63f7 (diff) | |
Urađena test aplikacija. Povezan front i back.
Diffstat (limited to 'sandbox/testAppNevena/Front/node_modules/tmp')
4 files changed, 984 insertions, 0 deletions
| diff --git a/sandbox/testAppNevena/Front/node_modules/tmp/LICENSE b/sandbox/testAppNevena/Front/node_modules/tmp/LICENSE new file mode 100644 index 00000000..72418bd9 --- /dev/null +++ b/sandbox/testAppNevena/Front/node_modules/tmp/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014 KARASZI István + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/sandbox/testAppNevena/Front/node_modules/tmp/README.md b/sandbox/testAppNevena/Front/node_modules/tmp/README.md new file mode 100644 index 00000000..810b0482 --- /dev/null +++ b/sandbox/testAppNevena/Front/node_modules/tmp/README.md @@ -0,0 +1,314 @@ +# Tmp + +A simple temporary file and directory creator for [node.js.][1] + +[](https://travis-ci.org/raszi/node-tmp) +[](https://david-dm.org/raszi/node-tmp) +[](https://badge.fury.io/js/tmp) +[](https://raszi.github.io/node-tmp/) +[](https://snyk.io/test/npm/tmp) + +## About + +This is a [widely used library][2] to create temporary files and directories +in a [node.js][1] environment. + +Tmp offers both an asynchronous and a synchronous API. For all API calls, all +the parameters are optional. There also exists a promisified version of the +API, see (5) under references below. + +Tmp uses crypto for determining random file names, or, when using templates, +a six letter random identifier. And just in case that you do not have that much +entropy left on your system, Tmp will fall back to pseudo random numbers. + +You can set whether you want to remove the temporary file on process exit or +not, and the destination directory can also be set. + +## How to install + +```bash +npm install tmp +``` + +## Usage + +Please also check [API docs][4]. + +### Asynchronous file creation + +Simple temporary file creation, the file will be closed and unlinked on process exit. + +```javascript +var tmp = require('tmp'); + +tmp.file(function _tempFileCreated(err, path, fd, cleanupCallback) { +  if (err) throw err; + +  console.log('File: ', path); +  console.log('Filedescriptor: ', fd); +   +  // If we don't need the file anymore we could manually call the cleanupCallback +  // But that is not necessary if we didn't pass the keep option because the library +  // will clean after itself. +  cleanupCallback(); +}); +``` + +### Synchronous file creation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.fileSync(); +console.log('File: ', tmpobj.name); +console.log('Filedescriptor: ', tmpobj.fd); +   +// If we don't need the file anymore we could manually call the removeCallback +// But that is not necessary if we didn't pass the keep option because the library +// will clean after itself. +tmpobj.removeCallback(); +``` + +Note that this might throw an exception if either the maximum limit of retries +for creating a temporary name fails, or, in case that you do not have the permission +to write to the directory where the temporary file should be created in. + +### Asynchronous directory creation + +Simple temporary directory creation, it will be removed on process exit. + +If the directory still contains items on process exit, then it won't be removed. + +```javascript +var tmp = require('tmp'); + +tmp.dir(function _tempDirCreated(err, path, cleanupCallback) { +  if (err) throw err; + +  console.log('Dir: ', path); +   +  // Manual cleanup +  cleanupCallback(); +}); +``` + +If you want to cleanup the directory even when there are entries in it, then +you can pass the `unsafeCleanup` option when creating it. + +### Synchronous directory creation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.dirSync(); +console.log('Dir: ', tmpobj.name); +// Manual cleanup +tmpobj.removeCallback(); +``` + +Note that this might throw an exception if either the maximum limit of retries +for creating a temporary name fails, or, in case that you do not have the permission +to write to the directory where the temporary directory should be created in. + +### Asynchronous filename generation + +It is possible with this library to generate a unique filename in the specified +directory. + +```javascript +var tmp = require('tmp'); + +tmp.tmpName(function _tempNameGenerated(err, path) { +    if (err) throw err; + +    console.log('Created temporary filename: ', path); +}); +``` + +### Synchronous filename generation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var name = tmp.tmpNameSync(); +console.log('Created temporary filename: ', name); +``` + +## Advanced usage + +### Asynchronous file creation + +Creates a file with mode `0644`, prefix will be `prefix-` and postfix will be `.txt`. + +```javascript +var tmp = require('tmp'); + +tmp.file({ mode: 0644, prefix: 'prefix-', postfix: '.txt' }, function _tempFileCreated(err, path, fd) { +  if (err) throw err; + +  console.log('File: ', path); +  console.log('Filedescriptor: ', fd); +}); +``` + +### Synchronous file creation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.fileSync({ mode: 0644, prefix: 'prefix-', postfix: '.txt' }); +console.log('File: ', tmpobj.name); +console.log('Filedescriptor: ', tmpobj.fd); +``` + +### Controlling the Descriptor + +As a side effect of creating a unique file `tmp` gets a file descriptor that is +returned to the user as the `fd` parameter.  The descriptor may be used by the +application and is closed when the `removeCallback` is invoked. + +In some use cases the application does not need the descriptor, needs to close it +without removing the file, or needs to remove the file without closing the +descriptor.  Two options control how the descriptor is managed: + +* `discardDescriptor` - if `true` causes `tmp` to close the descriptor after the file +  is created.  In this case the `fd` parameter is undefined. +* `detachDescriptor` - if `true` causes `tmp` to return the descriptor in the `fd` +  parameter, but it is the application's responsibility to close it when it is no +  longer needed. + +```javascript +var tmp = require('tmp'); + +tmp.file({ discardDescriptor: true }, function _tempFileCreated(err, path, fd, cleanupCallback) { +  if (err) throw err; +  // fd will be undefined, allowing application to use fs.createReadStream(path) +  // without holding an unused descriptor open. +}); +``` + +```javascript +var tmp = require('tmp'); + +tmp.file({ detachDescriptor: true }, function _tempFileCreated(err, path, fd, cleanupCallback) { +  if (err) throw err; + +  cleanupCallback(); +  // Application can store data through fd here; the space used will automatically +  // be reclaimed by the operating system when the descriptor is closed or program +  // terminates. +}); +``` + +### Asynchronous directory creation + +Creates a directory with mode `0755`, prefix will be `myTmpDir_`. + +```javascript +var tmp = require('tmp'); + +tmp.dir({ mode: 0750, prefix: 'myTmpDir_' }, function _tempDirCreated(err, path) { +  if (err) throw err; + +  console.log('Dir: ', path); +}); +``` + +### Synchronous directory creation + +Again, a synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.dirSync({ mode: 0750, prefix: 'myTmpDir_' }); +console.log('Dir: ', tmpobj.name); +``` + +### mkstemp like, asynchronously + +Creates a new temporary directory with mode `0700` and filename like `/tmp/tmp-nk2J1u`. + +```javascript +var tmp = require('tmp'); + +tmp.dir({ template: '/tmp/tmp-XXXXXX' }, function _tempDirCreated(err, path) { +  if (err) throw err; + +  console.log('Dir: ', path); +}); +``` + +### mkstemp like, synchronously + +This will behave similarly to the asynchronous version. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.dirSync({ template: '/tmp/tmp-XXXXXX' }); +console.log('Dir: ', tmpobj.name); +``` + +### Asynchronous filename generation + +The `tmpName()` function accepts the `prefix`, `postfix`, `dir`, etc. parameters also: + +```javascript +var tmp = require('tmp'); + +tmp.tmpName({ template: '/tmp/tmp-XXXXXX' }, function _tempNameGenerated(err, path) { +    if (err) throw err; + +    console.log('Created temporary filename: ', path); +}); +``` + +### Synchronous filename generation + +The `tmpNameSync()` function works similarly to `tmpName()`. + +```javascript +var tmp = require('tmp'); +var tmpname = tmp.tmpNameSync({ template: '/tmp/tmp-XXXXXX' }); +console.log('Created temporary filename: ', tmpname); +``` + +## Graceful cleanup + +One may want to cleanup the temporary files even when an uncaught exception +occurs. To enforce this, you can call the `setGracefulCleanup()` method: + +```javascript +var tmp = require('tmp'); + +tmp.setGracefulCleanup(); +``` + +## Options + +All options are optional :) + +  * `mode`: the file mode to create with, it fallbacks to `0600` on file creation and `0700` on directory creation +  * `prefix`: the optional prefix, fallbacks to `tmp-` if not provided +  * `postfix`: the optional postfix, fallbacks to `.tmp` on file creation +  * `template`: [`mkstemp`][3] like filename template, no default +  * `dir`: the optional temporary directory, fallbacks to system default (guesses from environment) +  * `tries`: how many times should the function try to get a unique filename before giving up, default `3` +  * `keep`: signals that the temporary file or directory should not be deleted on exit, default is `false`, means delete +    * Please keep in mind that it is recommended in this case to call the provided `cleanupCallback` function manually. +  * `unsafeCleanup`: recursively removes the created temporary directory, even when it's not empty. default is `false` + +[1]: http://nodejs.org/ +[2]: https://www.npmjs.com/browse/depended/tmp +[3]: http://www.kernel.org/doc/man-pages/online/pages/man3/mkstemp.3.html +[4]: https://raszi.github.io/node-tmp/ +[5]: https://github.com/benjamingr/tmp-promise diff --git a/sandbox/testAppNevena/Front/node_modules/tmp/lib/tmp.js b/sandbox/testAppNevena/Front/node_modules/tmp/lib/tmp.js new file mode 100644 index 00000000..41b83dbe --- /dev/null +++ b/sandbox/testAppNevena/Front/node_modules/tmp/lib/tmp.js @@ -0,0 +1,611 @@ +/*! + * Tmp + * + * Copyright (c) 2011-2017 KARASZI Istvan <github@spam.raszi.hu> + * + * MIT Licensed + */ + +/* + * Module dependencies. + */ +const fs = require('fs'); +const path = require('path'); +const crypto = require('crypto'); +const osTmpDir = require('os-tmpdir'); +const _c = process.binding('constants'); + +/* + * The working inner variables. + */ +const +  /** +   * The temporary directory. +   * @type {string} +   */ +  tmpDir = osTmpDir(), + +  // the random characters to choose from +  RANDOM_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz', + +  TEMPLATE_PATTERN = /XXXXXX/, + +  DEFAULT_TRIES = 3, + +  CREATE_FLAGS = (_c.O_CREAT || _c.fs.O_CREAT) | (_c.O_EXCL || _c.fs.O_EXCL) | (_c.O_RDWR || _c.fs.O_RDWR), + +  EBADF = _c.EBADF || _c.os.errno.EBADF, +  ENOENT = _c.ENOENT || _c.os.errno.ENOENT, + +  DIR_MODE = 448 /* 0o700 */, +  FILE_MODE = 384 /* 0o600 */, + +  // this will hold the objects need to be removed on exit +  _removeObjects = []; + +var +  _gracefulCleanup = false, +  _uncaughtException = false; + +/** + * Random name generator based on crypto. + * Adapted from http://blog.tompawlak.org/how-to-generate-random-values-nodejs-javascript + * + * @param {number} howMany + * @returns {string} the generated random name + * @private + */ +function _randomChars(howMany) { +  var +    value = [], +    rnd = null; + +  // make sure that we do not fail because we ran out of entropy +  try { +    rnd = crypto.randomBytes(howMany); +  } catch (e) { +    rnd = crypto.pseudoRandomBytes(howMany); +  } + +  for (var i = 0; i < howMany; i++) { +    value.push(RANDOM_CHARS[rnd[i] % RANDOM_CHARS.length]); +  } + +  return value.join(''); +} + +/** + * Checks whether the `obj` parameter is defined or not. + * + * @param {Object} obj + * @returns {boolean} true if the object is undefined + * @private + */ +function _isUndefined(obj) { +  return typeof obj === 'undefined'; +} + +/** + * Parses the function arguments. + * + * This function helps to have optional arguments. + * + * @param {(Options|Function)} options + * @param {Function} callback + * @returns {Array} parsed arguments + * @private + */ +function _parseArguments(options, callback) { +  if (typeof options == 'function') { +    return [callback || {}, options]; +  } + +  if (_isUndefined(options)) { +    return [{}, callback]; +  } + +  return [options, callback]; +} + +/** + * Generates a new temporary name. + * + * @param {Object} opts + * @returns {string} the new random name according to opts + * @private + */ +function _generateTmpName(opts) { +  if (opts.name) { +    return path.join(opts.dir || tmpDir, opts.name); +  } + +  // mkstemps like template +  if (opts.template) { +    return opts.template.replace(TEMPLATE_PATTERN, _randomChars(6)); +  } + +  // prefix and postfix +  const name = [ +    opts.prefix || 'tmp-', +    process.pid, +    _randomChars(12), +    opts.postfix || '' +  ].join(''); + +  return path.join(opts.dir || tmpDir, name); +} + +/** + * Gets a temporary file name. + * + * @param {(Options|tmpNameCallback)} options options or callback + * @param {?tmpNameCallback} callback the callback function + */ +function tmpName(options, callback) { +  var +    args = _parseArguments(options, callback), +    opts = args[0], +    cb = args[1], +    tries = opts.name ? 1 : opts.tries || DEFAULT_TRIES; + +  if (isNaN(tries) || tries < 0) +    return cb(new Error('Invalid tries')); + +  if (opts.template && !opts.template.match(TEMPLATE_PATTERN)) +    return cb(new Error('Invalid template provided')); + +  (function _getUniqueName() { +    const name = _generateTmpName(opts); + +    // check whether the path exists then retry if needed +    fs.stat(name, function (err) { +      if (!err) { +        if (tries-- > 0) return _getUniqueName(); + +        return cb(new Error('Could not get a unique tmp filename, max tries reached ' + name)); +      } + +      cb(null, name); +    }); +  }()); +} + +/** + * Synchronous version of tmpName. + * + * @param {Object} options + * @returns {string} the generated random name + * @throws {Error} if the options are invalid or could not generate a filename + */ +function tmpNameSync(options) { +  var +    args = _parseArguments(options), +    opts = args[0], +    tries = opts.name ? 1 : opts.tries || DEFAULT_TRIES; + +  if (isNaN(tries) || tries < 0) +    throw new Error('Invalid tries'); + +  if (opts.template && !opts.template.match(TEMPLATE_PATTERN)) +    throw new Error('Invalid template provided'); + +  do { +    const name = _generateTmpName(opts); +    try { +      fs.statSync(name); +    } catch (e) { +      return name; +    } +  } while (tries-- > 0); + +  throw new Error('Could not get a unique tmp filename, max tries reached'); +} + +/** + * Creates and opens a temporary file. + * + * @param {(Options|fileCallback)} options the config options or the callback function + * @param {?fileCallback} callback + */ +function file(options, callback) { +  var +    args = _parseArguments(options, callback), +    opts = args[0], +    cb = args[1]; + +  opts.postfix = (_isUndefined(opts.postfix)) ? '.tmp' : opts.postfix; + +  // gets a temporary filename +  tmpName(opts, function _tmpNameCreated(err, name) { +    if (err) return cb(err); + +    // create and open the file +    fs.open(name, CREATE_FLAGS, opts.mode || FILE_MODE, function _fileCreated(err, fd) { +      if (err) return cb(err); + +      if (opts.discardDescriptor) { +        return fs.close(fd, function _discardCallback(err) { +          if (err) { +            // Low probability, and the file exists, so this could be +            // ignored.  If it isn't we certainly need to unlink the +            // file, and if that fails too its error is more +            // important. +            try { +              fs.unlinkSync(name); +            } catch (e) { +              if (!isENOENT(e)) { +                err = e; +              } +            } +            return cb(err); +          } +          cb(null, name, undefined, _prepareTmpFileRemoveCallback(name, -1, opts)); +        }); +      } +      if (opts.detachDescriptor) { +        return cb(null, name, fd, _prepareTmpFileRemoveCallback(name, -1, opts)); +      } +      cb(null, name, fd, _prepareTmpFileRemoveCallback(name, fd, opts)); +    }); +  }); +} + +/** + * Synchronous version of file. + * + * @param {Options} options + * @returns {FileSyncObject} object consists of name, fd and removeCallback + * @throws {Error} if cannot create a file + */ +function fileSync(options) { +  var +    args = _parseArguments(options), +    opts = args[0]; + +  opts.postfix = opts.postfix || '.tmp'; + +  const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor; +  const name = tmpNameSync(opts); +  var fd = fs.openSync(name, CREATE_FLAGS, opts.mode || FILE_MODE); +  if (opts.discardDescriptor) { +    fs.closeSync(fd);  +    fd = undefined; +  } + +  return { +    name: name, +    fd: fd, +    removeCallback: _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts) +  }; +} + +/** + * Removes files and folders in a directory recursively. + * + * @param {string} root + * @private + */ +function _rmdirRecursiveSync(root) { +  const dirs = [root]; + +  do { +    var +      dir = dirs.pop(), +      deferred = false, +      files = fs.readdirSync(dir); + +    for (var i = 0, length = files.length; i < length; i++) { +      var +        file = path.join(dir, files[i]), +        stat = fs.lstatSync(file); // lstat so we don't recurse into symlinked directories + +      if (stat.isDirectory()) { +        if (!deferred) { +          deferred = true; +          dirs.push(dir); +        } +        dirs.push(file); +      } else { +        fs.unlinkSync(file); +      } +    } + +    if (!deferred) { +      fs.rmdirSync(dir); +    } +  } while (dirs.length !== 0); +} + +/** + * Creates a temporary directory. + * + * @param {(Options|dirCallback)} options the options or the callback function + * @param {?dirCallback} callback + */ +function dir(options, callback) { +  var +    args = _parseArguments(options, callback), +    opts = args[0], +    cb = args[1]; + +  // gets a temporary filename +  tmpName(opts, function _tmpNameCreated(err, name) { +    if (err) return cb(err); + +    // create the directory +    fs.mkdir(name, opts.mode || DIR_MODE, function _dirCreated(err) { +      if (err) return cb(err); + +      cb(null, name, _prepareTmpDirRemoveCallback(name, opts)); +    }); +  }); +} + +/** + * Synchronous version of dir. + * + * @param {Options} options + * @returns {DirSyncObject} object consists of name and removeCallback + * @throws {Error} if it cannot create a directory + */ +function dirSync(options) { +  var +    args = _parseArguments(options), +    opts = args[0]; + +  const name = tmpNameSync(opts); +  fs.mkdirSync(name, opts.mode || DIR_MODE); + +  return { +    name: name, +    removeCallback: _prepareTmpDirRemoveCallback(name, opts) +  }; +} + +/** + * Prepares the callback for removal of the temporary file. + * + * @param {string} name the path of the file + * @param {number} fd file descriptor + * @param {Object} opts + * @returns {fileCallback} + * @private + */ +function _prepareTmpFileRemoveCallback(name, fd, opts) { +  const removeCallback = _prepareRemoveCallback(function _removeCallback(fdPath) { +    try { +      if (0 <= fdPath[0]) { +        fs.closeSync(fdPath[0]); +      } +    } +    catch (e) { +      // under some node/windows related circumstances, a temporary file +      // may have not be created as expected or the file was already closed +      // by the user, in which case we will simply ignore the error +      if (!isEBADF(e) && !isENOENT(e)) { +        // reraise any unanticipated error +        throw e; +      } +    } +    try { +      fs.unlinkSync(fdPath[1]); +    } +    catch (e) { +      if (!isENOENT(e)) { +        // reraise any unanticipated error +        throw e; +      } +    } +  }, [fd, name]); + +  if (!opts.keep) { +    _removeObjects.unshift(removeCallback); +  } + +  return removeCallback; +} + +/** + * Prepares the callback for removal of the temporary directory. + * + * @param {string} name + * @param {Object} opts + * @returns {Function} the callback + * @private + */ +function _prepareTmpDirRemoveCallback(name, opts) { +  const removeFunction = opts.unsafeCleanup ? _rmdirRecursiveSync : fs.rmdirSync.bind(fs); +  const removeCallback = _prepareRemoveCallback(removeFunction, name); + +  if (!opts.keep) { +    _removeObjects.unshift(removeCallback); +  } + +  return removeCallback; +} + +/** + * Creates a guarded function wrapping the removeFunction call. + * + * @param {Function} removeFunction + * @param {Object} arg + * @returns {Function} + * @private + */ +function _prepareRemoveCallback(removeFunction, arg) { +  var called = false; + +  return function _cleanupCallback(next) { +    if (!called) { +      const index = _removeObjects.indexOf(_cleanupCallback); +      if (index >= 0) { +        _removeObjects.splice(index, 1); +      } + +      called = true; +      removeFunction(arg); +    } + +    if (next) next(null); +  }; +} + +/** + * The garbage collector. + * + * @private + */ +function _garbageCollector() { +  if (_uncaughtException && !_gracefulCleanup) { +    return; +  } + +  // the function being called removes itself from _removeObjects, +  // loop until _removeObjects is empty +  while (_removeObjects.length) { +    try { +      _removeObjects[0].call(null); +    } catch (e) { +      // already removed? +    } +  } +} + +/** + * Helper for testing against EBADF to compensate changes made to Node 7.x under Windows. + */ +function isEBADF(error) { +  return isExpectedError(error, -EBADF, 'EBADF'); +} + +/** + * Helper for testing against ENOENT to compensate changes made to Node 7.x under Windows. + */ +function isENOENT(error) { +  return isExpectedError(error, -ENOENT, 'ENOENT'); +} + +/** + * Helper to determine whether the expected error code matches the actual code and errno, + * which will differ between the supported node versions. + * + * - Node >= 7.0: + *   error.code {String} + *   error.errno {String|Number} any numerical value will be negated + * + * - Node >= 6.0 < 7.0: + *   error.code {String} + *   error.errno {Number} negated + * + * - Node >= 4.0 < 6.0: introduces SystemError + *   error.code {String} + *   error.errno {Number} negated + * + * - Node >= 0.10 < 4.0: + *   error.code {Number} negated + *   error.errno n/a + */ +function isExpectedError(error, code, errno) { +  return error.code == code || error.code == errno; +} + +/** + * Sets the graceful cleanup. + * + * Also removes the created files and directories when an uncaught exception occurs. + */ +function setGracefulCleanup() { +  _gracefulCleanup = true; +} + +const version = process.versions.node.split('.').map(function (value) { +  return parseInt(value, 10); +}); + +if (version[0] === 0 && (version[1] < 9 || version[1] === 9 && version[2] < 5)) { +  process.addListener('uncaughtException', function _uncaughtExceptionThrown(err) { +    _uncaughtException = true; +    _garbageCollector(); + +    throw err; +  }); +} + +process.addListener('exit', function _exit(code) { +  if (code) _uncaughtException = true; +  _garbageCollector(); +}); + +/** + * Configuration options. + * + * @typedef {Object} Options + * @property {?number} tries the number of tries before give up the name generation + * @property {?string} template the "mkstemp" like filename template + * @property {?string} name fix name + * @property {?string} dir the tmp directory to use + * @property {?string} prefix prefix for the generated name + * @property {?string} postfix postfix for the generated name + */ + +/** + * @typedef {Object} FileSyncObject + * @property {string} name the name of the file + * @property {string} fd the file descriptor + * @property {fileCallback} removeCallback the callback function to remove the file + */ + +/** + * @typedef {Object} DirSyncObject + * @property {string} name the name of the directory + * @property {fileCallback} removeCallback the callback function to remove the directory + */ + +/** + * @callback tmpNameCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + */ + +/** + * @callback fileCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {number} fd the file descriptor + * @param {cleanupCallback} fn the cleanup callback function + */ + +/** + * @callback dirCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {cleanupCallback} fn the cleanup callback function + */ + +/** + * Removes the temporary created file or directory. + * + * @callback cleanupCallback + * @param {simpleCallback} [next] function to call after entry was removed + */ + +/** + * Callback function for function composition. + * @see {@link https://github.com/raszi/node-tmp/issues/57|raszi/node-tmp#57} + * + * @callback simpleCallback + */ + +// exporting all the needed methods +module.exports.tmpdir = tmpDir; + +module.exports.dir = dir; +module.exports.dirSync = dirSync; + +module.exports.file = file; +module.exports.fileSync = fileSync; + +module.exports.tmpName = tmpName; +module.exports.tmpNameSync = tmpNameSync; + +module.exports.setGracefulCleanup = setGracefulCleanup; diff --git a/sandbox/testAppNevena/Front/node_modules/tmp/package.json b/sandbox/testAppNevena/Front/node_modules/tmp/package.json new file mode 100644 index 00000000..e8aaf3b3 --- /dev/null +++ b/sandbox/testAppNevena/Front/node_modules/tmp/package.json @@ -0,0 +1,38 @@ +{ +  "name": "tmp", +  "version": "0.0.33", +  "description": "Temporary file and directory creator", +  "author": "KARASZI István <github@spam.raszi.hu> (http://raszi.hu/)", +  "keywords": [ +    "temporary", +    "tmp", +    "temp", +    "tempdir", +    "tempfile", +    "tmpdir", +    "tmpfile" +  ], +  "license": "MIT", +  "repository": "raszi/node-tmp", +  "homepage": "http://github.com/raszi/node-tmp", +  "bugs": { +    "url": "http://github.com/raszi/node-tmp/issues" +  }, +  "engines": { +    "node": ">=0.6.0" +  }, +  "dependencies": { +    "os-tmpdir": "~1.0.2" +  }, +  "devDependencies": { +    "vows": "~0.7.0" +  }, +  "main": "lib/tmp.js", +  "files": [ +    "lib/" +  ], +  "scripts": { +    "test": "vows test/*-test.js", +    "doc": "jsdoc -c .jsdoc.json" +  } +} | 
