{
  "_args": [
    [
      {
        "raw": "flagged-respawn@^1.0.0",
        "scope": null,
        "escapedName": "flagged-respawn",
        "name": "flagged-respawn",
        "rawSpec": "^1.0.0",
        "spec": ">=1.0.0 <2.0.0",
        "type": "range"
      },
      "E:\\Mine\\Project\\git\\laya\\dawawa\\layaairdoc_cmd\\node_modules\\liftoff"
    ]
  ],
  "_from": "flagged-respawn@^1.0.0",
  "_hasShrinkwrap": false,
  "_id": "flagged-respawn@1.0.1",
  "_location": "/flagged-respawn",
  "_nodeVersion": "8.11.1",
  "_npmOperationalInternal": {
    "host": "s3://npm-registry-packages",
    "tmp": "tmp/flagged-respawn_1.0.1_1544555649674_0.741443184349275"
  },
  "_npmUser": {
    "name": "phated",
    "email": "blaine.bublitz@gmail.com"
  },
  "_npmVersion": "5.6.0",
  "_phantomChildren": {},
  "_requested": {
    "raw": "flagged-respawn@^1.0.0",
    "scope": null,
    "escapedName": "flagged-respawn",
    "name": "flagged-respawn",
    "rawSpec": "^1.0.0",
    "spec": ">=1.0.0 <2.0.0",
    "type": "range"
  },
  "_requiredBy": [
    "/liftoff"
  ],
  "_resolved": "https://registry.npmjs.org/flagged-respawn/-/flagged-respawn-1.0.1.tgz",
  "_shasum": "e7de6f1279ddd9ca9aac8a5971d618606b3aab41",
  "_shrinkwrap": null,
  "_spec": "flagged-respawn@^1.0.0",
  "_where": "E:\\Mine\\Project\\git\\laya\\dawawa\\layaairdoc_cmd\\node_modules\\liftoff",
  "author": {
    "name": "Gulp Team",
    "email": "team@gulpjs.com",
    "url": "http://gulpjs.com/"
  },
  "bugs": {
    "url": "https://github.com/gulpjs/flagged-respawn/issues"
  },
  "contributors": [
    {
      "name": "Takayuki Sato",
      "email": "sttk.xslet@gmail.com"
    },
    {
      "name": "Bertrand Marron",
      "email": "bertrand.marron@ionisx.com"
    },
    {
      "name": "Tyler Kellen",
      "email": "tyler@sleekcode.net"
    },
    {
      "name": "Blaine Bublitz",
      "email": "blaine.bublitz@gmail.com"
    }
  ],
  "dependencies": {},
  "description": "A tool for respawning node binaries when special flags are present.",
  "devDependencies": {
    "eslint": "^2.13.0",
    "eslint-config-gulp": "^3.0.1",
    "expect": "^1.20.2",
    "istanbul": "^0.4.3",
    "istanbul-coveralls": "^1.0.3",
    "mocha": "^3.5.3",
    "nyc": "^11.3.0",
    "v8flags": "^3.0.1"
  },
  "directories": {},
  "dist": {
    "integrity": "sha512-lNaHNVymajmk0OJMBn8fVUAU1BtDeKIqKoVhk4xAALB57aALg6b4W0MfJ/cUE0g9YBXy5XhSlPIpYIJ7HaY/3Q==",
    "shasum": "e7de6f1279ddd9ca9aac8a5971d618606b3aab41",
    "tarball": "https://registry.npmjs.org/flagged-respawn/-/flagged-respawn-1.0.1.tgz",
    "fileCount": 8,
    "unpackedSize": 10361,
    "npm-signature": "-----BEGIN PGP SIGNATURE-----\r\nVersion: OpenPGP.js v3.0.4\r\nComment: https://openpgpjs.org\r\n\r\nwsFcBAEBCAAQBQJcEAyCCRA9TVsSAnZWagAAhsYP/2AY4Pl0bYf+9yQcpER9\nNCMnLhkopAYRi5jJwsXm5V6BsAQRO4dWgmUwN4cxHx9BbaKaA0kcnrCyohiW\nrcPODIT2oEip6FAJPfgsp0JFuDDTN8YW0ieKDP3f5IkL70RqHZjaCLRLVPCI\n3vpYIqQcvkCupqCNyB0aaYIZRFVqAK/oB5Vps3w2Bt0L67EnD63mV5I5e3HS\n5BOGROpxJms9KK6r4QPoCquGhe9UuwzCA2sbNcgdkz2LIykyixgO5tGpY6hQ\nq27t0GNw8zmZv+NNo0/3BFtb1MdDFj2PaUEVkFQjeLSGpoxEt4AYwzixx8jk\nNTh6hDVV9JKOeMeXhqpTYftnMfUDrVsKs28OEGr38e9CjAyTEMDEPyTmPLyO\nkT4cV8OktbGu9me3cbSLOrofTeE1YjLGFP9arAkdQX076JFM8bU49YRoH7f0\ngySuqY526bBdtwasGwGlKHvvXP61IE1La6Q187pyDi6RjFH8sBwfQuhP1AwG\nKZc43eoRplWu8G0KJQ1KmHiVbf4nU20fb9enTyeRM0WEUvp4YJHmJYxB/VxH\nkrvz7xZaaKRcI9r2qzxBxDC4jGdT0nbjc82e409UC7SP9IvvgmQbPnYi75Gu\nXZ+EgPFg4XEKl/yLvdWCLB2lUzv5iIC/z45RYMqp6ovbR7L9QrnBHezEwKM4\nWnvN\r\n=pTd5\r\n-----END PGP SIGNATURE-----\r\n"
  },
  "engines": {
    "node": ">= 0.10"
  },
  "files": [
    "index.js",
    "lib/",
    "LICENSE"
  ],
  "gitHead": "2640711d748a1bea801b502d4861277425706721",
  "homepage": "https://github.com/gulpjs/flagged-respawn#readme",
  "keywords": [
    "respawn",
    "flags"
  ],
  "license": "MIT",
  "main": "index.js",
  "maintainers": [
    {
      "name": "contra",
      "email": "yo@contra.io"
    },
    {
      "name": "phated",
      "email": "blaine.bublitz@gmail.com"
    },
    {
      "name": "sttk",
      "email": "sttk.xslet@gmail.com"
    },
    {
      "name": "tkellen",
      "email": "tyler@sleekcode.net"
    }
  ],
  "name": "flagged-respawn",
  "optionalDependencies": {},
  "readme": "<p align=\"center\">\n  <a href=\"http://gulpjs.com\">\n    <img height=\"257\" width=\"114\" src=\"https://raw.githubusercontent.com/gulpjs/artwork/master/gulp-2x.png\">\n  </a>\n</p>\n\n# flagged-respawn\n\n[![NPM version][npm-image]][npm-url] [![Downloads][downloads-image]][npm-url] [![Travis Build Status][travis-image]][travis-url] [![AppVeyor Build Status][appveyor-image]][appveyor-url] [![Coveralls Status][coveralls-image]][coveralls-url] [![Gitter chat][gitter-image]][gitter-url]\n\nA tool for respawning node binaries when special flags are present.\n\n## What is it?\n\nSay you wrote a command line tool that runs arbitrary javascript (e.g. task runner, test framework, etc). For the sake of discussion, let's pretend it's a testing harness you've named `testify`.\n\nEverything is going splendidly until one day you decide to test some code that relies on a feature behind a v8 flag in node (`--harmony`, for example).  Without much thought, you run `testify --harmony spec tests.js`.\n\nIt doesn't work. After digging around for a bit, you realize this produces a [`process.argv`](http://nodejs.org/docs/latest/api/process.html#process_process_argv) of:\n\n`['node', '/usr/local/bin/test', '--harmony', 'spec', 'tests.js']`\n\nCrap. The `--harmony` flag is in the wrong place! It should be applied to the **node** command, not our binary. What we actually wanted was this:\n\n`['node', '--harmony', '/usr/local/bin/test', 'spec', 'tests.js']`\n\nFlagged-respawn fixes this problem and handles all the edge cases respawning creates, such as:\n- Providing a method to determine if a respawn is needed.\n- Piping stderr/stdout from the child into the parent.\n- Making the parent process exit with the same code as the child.\n- If the child is killed, making the parent exit with the same signal.\n\nTo see it in action, clone this repository and run `npm install` / `npm run respawn` / `npm run nospawn`.\n\n## Sample Usage\n\n```js\n#!/usr/bin/env node\n\nconst flaggedRespawn = require('flagged-respawn');\n\n// get a list of all possible v8 flags for the running version of node\nconst v8flags = require('v8flags').fetch();\n\nflaggedRespawn(v8flags, process.argv, function (ready, child) {\n  if (ready) {\n    console.log('Running!');\n    // your cli code here\n  } else {\n    console.log('Special flags found, respawning.');\n  }\n  if (process.pid !== child.pid) {\n    console.log('Respawned to PID:', child.pid);\n  }\n});\n\n```\n\n\n## API\n\n### <u>flaggedRespawn(flags, argv, [ forcedFlags, ] callback) : Void</u>\n\nRespawns the script itself when *argv* has special flag contained in *flags* and/or *forcedFlags* is not empty. Because members of *flags* and *forcedFlags* are passed to `node` command, each of them needs to be a node flag or a V8 flag.\n\n#### Forbid respawning\n\nIf `--no-respawning` flag is given in *argv*, this function does not respawned even if *argv* contains members of flags or *forcedFlags* is not empty. (This flag is also used internally to prevent from respawning more than once).\n\n#### Parameter:\n\n| Parameter     |  Type  | Description |\n|:--------------|:------:|:----------------------------------------------------|\n| *flags*       | Array  | An array of node flags and V8 flags which are available when present in *argv*. |\n| *argv*        | Array  | Command line arguments to respawn.   |\n| *forcedFlags* | Array or String  | An array of node flags or a string of a single flag and V8 flags for respawning forcely. |\n| *callback*    | function | A called function when not respawning or after respawned. |\n\n* **<u><i>callback</i>(ready, proc, argv) : Void</u>**\n\n    *callback* function is called both when respawned or not, and it can be distinguished by callback's argument: *ready*. (*ready* indicates whether a process spawned its child process (false) or not (true), but it does not indicate whether a process is a spawned child process or not. *ready* for a spawned child process is true.)\n\n    *argv* is an array of command line arguments which is respawned (when *ready* is false) or is passed current process except flags within *flags* and `--no-respawning` (when *ready* is true).\n\n    **Parameter:**\n\n    | Parameter |  Type   | Description               |\n    |:----------|:-------:|:--------------------------|\n    | *ready*   | boolean | True, if not respawning and is ready to execute main function. |\n    | *proc*    | object  | Child process object if respawned, otherwise current process object. |\n    | *argv*    | Array   | An array of command line arguments. |\n\n## License\n\nMIT\n\n[downloads-image]: http://img.shields.io/npm/dm/flagged-respawn.svg\n[npm-url]: https://www.npmjs.com/package/flagged-respawn\n[npm-image]: http://img.shields.io/npm/v/flagged-respawn.svg\n\n[travis-url]: https://travis-ci.org/gulpjs/flagged-respawn\n[travis-image]: http://img.shields.io/travis/gulpjs/flagged-respawn.svg?label=travis-ci\n\n[appveyor-url]: https://ci.appveyor.com/project/gulpjs/flagged-respawn\n[appveyor-image]: https://img.shields.io/appveyor/ci/gulpjs/flagged-respawn.svg?label=appveyor\n\n[coveralls-url]: https://coveralls.io/r/gulpjs/flagged-respawn\n[coveralls-image]: http://img.shields.io/coveralls/gulpjs/flagged-respawn/master.svg\n\n[gitter-url]: https://gitter.im/gulpjs/gulp\n[gitter-image]: https://badges.gitter.im/gulpjs/gulp.svg\n",
  "readmeFilename": "README.md",
  "repository": {
    "type": "git",
    "url": "git+https://github.com/gulpjs/flagged-respawn.git"
  },
  "scripts": {
    "cover": "nyc --reporter=lcov --reporter=text-summary npm test",
    "coveralls": "npm run cover && istanbul-coveralls",
    "lint": "eslint .",
    "nospawn": "node test/bin/respawner test",
    "pretest": "npm run lint",
    "respawn": "node test/bin/respawner --harmony test",
    "test": "mocha --async-only"
  },
  "version": "1.0.1"
}
