diff --git a/.travis.yml b/.travis.yml index 08b4373..f7a7544 100644 --- a/.travis.yml +++ b/.travis.yml @@ -20,6 +20,8 @@ env: - export NODE_VERSION="0.12" - export NODE_VERSION="4" - export NODE_VERSION="5" + - export NODE_VERSION="6" + - export NODE_VERSION="7" global: - node_pre_gyp_region="eu-central-1" diff --git a/CHANGES.md b/CHANGES.md new file mode 100644 index 0000000..3ebef4b --- /dev/null +++ b/CHANGES.md @@ -0,0 +1,349 @@ +2017-03-28, Version 1.0.1 +========================= + + * fix: fix the deprecated warnings (#40) (淘小杰) + + +2017-03-23, Version 1.0.0 +========================= + + * feat: config node7 on appveyor (#39) (淘小杰) + + * fix: make it work on node7.x (#38) (淘小杰) + + * Update release script (Yury Puzynya) + + +2016-05-10, Version 0.7.7 +========================= + + * Return node 4 x86 build (Yury Puzynya) + + +2016-05-08, Version 0.7.6 +========================= + + + +2016-05-08, Version 0.7.5 +========================= + + + +2016-04-28, Version 0.7.4 +========================= + + * fix publishing (Yury Puzynya) + + +2016-04-28, Version 0.7.3 +========================= + + * Update nan (Yury Puzynya) + + * Exclude 4.0.0-win32-ia32 from prebuilts (Yury Puzynya) + + +2016-03-12, Version 0.7.2 +========================= + + * New release script (Yury Puzynya) + + +2016-01-26, Version 0.7.1 +========================= + + * Fix prepublish script (Yury Puzynya) + + * Fix #21: this.extendedProcessDebugJSONRequest_ is not a function (Shawn Van Ittersum) + + * Update build script (Yury Puzynya) + + * Update prepublish (Yury Puzynya) + + +2015-12-06, Version 0.7.0 +========================= + + * Add prepublish script (Yury Puzynya) + + * Add .npmignore (Yury Puzynya) + + * Update .gitignore (Yury Puzynya) + + +2015-12-06, Version 0.6.2 +========================= + + * Update build scripts (Yury Puzynya) + + +2015-11-29, Version 0.6.1 +========================= + + * Build configuration updated (Yury Puzynya) + + +2015-10-22, Version 0.6.0 +========================= + + * Code prepared for NODE_NEXT logic (Yury Puzynya) + + * InjectedScriptSource updated (Yury Puzynya) + + * Added InjectedScriptHost.cc (Yury Puzynya) + + * Fixed preinstall script (Yury Puzynya) + + +2015-09-17, Version 0.5.4 +========================= + + + +2015-09-13, Version 0.5.3 +========================= + + * Update travis build (Yury Puzynya) + + * Fix src for node v4 (Yury Puzynya) + + * Updated cloud build (Yury Puzynya) + + +2015-08-09, Version 0.5.2 +========================= + + * Version changed to 0.5.2 (3y3) + + * Fix error rethrowing (3y3) + + +2015-08-09, Version 0.5.1 +========================= + + * Version changed to 0.5.1 (3y3) + + * Update cloud build (3y3) + + * Fix build for iojs-3 (3y3) + + * Readme.md updated (3y3) + + +2015-07-23, Version 0.5.0 +========================= + + * Version changed to 0.5.0 (3y3) + + * Readme.md updated (3y3) + + * Added `getFromFrame` func (3y3) + + +2015-05-19, Version 0.4.6 +========================= + + * Version changed to 0.4.6 (3y3) + + * Enable win_delay_load_hook for 1.* (3y3) + + +2015-05-19, Version 0.4.5 +========================= + + * Version changed to 0.4.5 (3y3) + + * Cleanup CI configs (3y3) + + +2015-05-09, Version 0.4.4 +========================= + + * Version changed to 0.4.4 (3y3) + + * Update CI settings (3y3) + + * Unbundle node-pre-gyp (3y3) + + * Update TravisCI badge (3y3) + + +2015-05-01, Version 0.4.3 +========================= + + * Version changed to 0.4.3 (3y3) + + * Update dependencies (3y3) + + * Added npm version badge (3y3) + + +2015-02-22, Version 0.4.2 +========================= + + * Version changed to 0.4.2 (3y3) + + * Webkit API refactoring (3y3) + + * Allocate Debug Context for 0.12+ (3y3) + + +2015-02-19, Version 0.4.1 +========================= + + * Version changed to 0.4.1 (3y3) + + * Fixes for 0.10.36 (3y3) + + * Bump node-pre-gyp to ^0.6.4 for iojs (Jim Cummins) + + +2015-02-15, Version 0.4.0 +========================= + + * Version changed to 0.4.0 (3y3) + + * Temporary fix for io.js testing (3y3) + + * Fix for 0.12 and io.js (3y3) + + * Update build matrix (3y3) + + +2015-02-08, Version 0.3.5 +========================= + + * Version changed to 0.3.5 (3y3) + + * Skip failing test for build (3y3) + + * Add v0.12 to build matrix (3y3) + + * Rename Signal to SendCommand (3y3) + + * Upgrade npm dependencies, notably nan to 1.6.2 (James Ide) + + * Suppress compile warnings (3y3) + + * Added AppVeyor badge (3y3) + + * Update build matrix (3y3) + + * Fix errors and warning when compiling with iojs (Leo Koppelkamm) + + +2015-01-25, Version 0.3.4 +========================= + + * Version changed to 0.3.4 (3y3) + + * Use seq = 0 by default instead of 1 (3y3) + + * Fix Linux compatibility (3y3) + + * Update `nan` to 1.5.0 (3y3) + + * Fix tests race condition (3y3) + + * Fix paths for injected usage (3y3) + + * Added test for registerAgentCommand (3y3) + + * Added Webkit protocol support (3y3) + + * Node-pre-gyp updated to ^0.6.0 (3y3) + + * allow_natives_syntax flag moved to `allowNatives` method (3y3) + + * Depreceted undocumented method `mirror` (3y3) + + +2015-01-10, Version 0.3.3 +========================= + + * Version changed to 0.3.3 (3y3) + + +2015-01-09, Version 0.3.2 +========================= + + * Version changed to 0.3.2 (3y3) + + * Finish prebuild binaries (3y3) + + * Linux/OSX prebuild binaries (3y3) + + * Added `registerAsync` command (3y3) + + * Convert line endings to LF (3y3) + + +2014-12-07, Version 0.3.1 +========================= + + * Windows prebuild binaries (3y3) + + +2014-11-27, Version 0.3.0 +========================= + + * Version changed to 0.3.0 (3y3) + + * Update readme.md (Moshe Kolodny) + + * Readme updated (3y3) + + * API updated (3y3) + + +2014-10-02, Version 0.2.0 +========================= + + * Version changed to 0.2.0 (3y3) + + * Allow natives syntax flag enabled (3y3) + + * Ignore v8 protocol serializer for custom commands (3y3) + + * v8-debug.js refactored (3y3) + + * Added runInDebugContext function (3y3) + + * Fixed newline in readme.md (3y3) + + +2014-09-28, Version 0.1.5 +========================= + + * Version changed to 0.1.5 (3y3) + + * Fix compatibility with 0.10.x (3y3) + + +2014-09-28, Version 0.1.4 +========================= + + * Version changed to 0.1.4 (3y3) + + * Fast fix for Node v0.11.14 (3y3) + + * Move DebugCommandProcessor to closure (3y3) + + * Added mirror API (3y3) + + +2014-06-29, Version 0.1.3 +========================= + + * Version changed to 0.1.3 (3y3) + + * Remove 'v8-debug' from cache after disconnect (3y3) + + * Safely handling errors (3y3) + + +2014-06-26, Version 0.1.2 +========================= + + * First release! diff --git a/appveyor.yml b/appveyor.yml index 86c9a91..11ae3e8 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -5,6 +5,14 @@ environment: secure: jJxKoyWputzRz2EjAT9i/vBzYt2+lcjKZ5D6O5TBaS9+anpYHn2XWbOut5dkOgh0 node_pre_gyp_region: eu-central-1 matrix: + - NODE_VERSION: 7 + platform: x64 + - NODE_VERSION: 7 + platform: x86 + - NODE_VERSION: 6 + platform: x64 + - NODE_VERSION: 6 + platform: x86 - NODE_VERSION: 5 platform: x64 - NODE_VERSION: 5 @@ -31,6 +39,11 @@ install: - IF %NODE_VERSION% LSS 1 npm -g install npm - IF %NODE_VERSION% LSS 1 set PATH=%APPDATA%\npm;%PATH% + # work around an issue with node-gyp v3.3.1 and node 4x + # package.json has no certificates in it so we're cool + # https://github.com/nodejs/node-gyp/issues/921 + - IF %NODE_VERSION% == 4 npm config set -g cafile=package.json + - IF %NODE_VERSION% == 4 npm config set -g strict-ssl=false # Check if new tag released and publish binary in this case. - SET PUBLISH_BINARY=%APPVEYOR_REPO_TAG% diff --git a/package.json b/package.json index 21da994..bb2b69f 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "v8-debug", - "version": "0.7.2", + "version": "1.0.1", "description": "v8 debugger extending API", "homepage": "http://github.com/node-inspector/v8-debug", "author": "3y3 Ghoti <3y3@bk.ru>", @@ -28,7 +28,7 @@ }, "main": "v8-debug", "dependencies": { - "nan": "^2.0.4", + "nan": "^2.3.2", "node-pre-gyp": "^0.6.5" }, "devDependencies": { diff --git a/src/InjectedScriptHost.cc b/src/InjectedScriptHost.cc index 82839ef..561f987 100644 --- a/src/InjectedScriptHost.cc +++ b/src/InjectedScriptHost.cc @@ -170,7 +170,7 @@ namespace nodex { Local constructorSymbol = CHK(New("constructor")); if (object->HasRealNamedProperty(constructorSymbol) && !object->HasRealNamedCallbackProperty(constructorSymbol)) { TryCatch tryCatch; - Local constructor = object->GetRealNamedProperty(constructorSymbol); + Local constructor = Nan::GetRealNamedProperty(object, constructorSymbol).ToLocalChecked(); if (!constructor.IsEmpty() && constructor->IsFunction()) { Local constructorName = functionDisplayName(Handle::Cast(constructor)); if (!constructorName.IsEmpty() && !tryCatch.HasCaught()) diff --git a/src/debug.cc b/src/debug.cc index 43482e6..d75e227 100644 --- a/src/debug.cc +++ b/src/debug.cc @@ -35,15 +35,24 @@ namespace nodex { } Local fn = Local::Cast(info[0]); - v8::Debug::Call(fn); + #if (NODE_MODULE_VERSION > 47) + Local context = fn->GetIsolate()->GetCurrentContext(); + v8::Debug::Call(context, fn); + #else + v8::Debug::Call(fn); + #endif RETURN(Undefined()); }; static NAN_METHOD(SendCommand) { String::Value command(info[0]); #if (NODE_MODULE_VERSION > 11) + #if (NODE_MODULE_VERSION > 47) + Isolate* debug_isolate = v8::Debug::GetDebugContext(Isolate::GetCurrent())->GetIsolate(); + #else Isolate* debug_isolate = v8::Debug::GetDebugContext()->GetIsolate(); + #endif v8::HandleScope debug_scope(debug_isolate); v8::Debug::SendCommand(debug_isolate, *command, command.length()); #else @@ -58,12 +67,20 @@ namespace nodex { if (expression.IsEmpty()) RETURN(Undefined()); + #if (NODE_MODULE_VERSION > 47) + Local debug_context = v8::Debug::GetDebugContext(Isolate::GetCurrent()); + #else Local debug_context = v8::Debug::GetDebugContext(); + #endif #if (NODE_MODULE_VERSION > 45) if (debug_context.IsEmpty()) { // Force-load the debug context. v8::Debug::GetMirror(info.GetIsolate()->GetCurrentContext(), info[0]); + #if (NODE_MODULE_VERSION > 47) + debug_context = v8::Debug::GetDebugContext(Isolate::GetCurrent()); + #else debug_context = v8::Debug::GetDebugContext(); + #endif } #endif diff --git a/test/v8-debug.js b/test/v8-debug.js index 86671f6..d292f81 100644 --- a/test/v8-debug.js +++ b/test/v8-debug.js @@ -44,7 +44,9 @@ describe('v8-debug', function() { expect(v8debug.registerAgentCommand.bind(v8debug, 'command', [], function() { done(); })).to.not.throw(); - v8debug.sendCommand('command'); + process.nextTick(function() { + v8debug.sendCommand('command'); + }); }); } else { it('enableWebkitProtocol should throw error', function() { @@ -56,7 +58,9 @@ describe('v8-debug', function() { describe('events.', function() { it('Emits `close` on disconnect command', function(done) { v8debug.on('close', done); - v8debug.sendCommand('disconnect'); + process.nextTick(function() { + v8debug.sendCommand('disconnect'); + }); }); }); }); diff --git a/tools/annotate-tag.js b/tools/annotate-tag.js index be21f3a..4fcf51e 100644 --- a/tools/annotate-tag.js +++ b/tools/annotate-tag.js @@ -1,7 +1,11 @@ -var exec = require('./exec'); +'use strict'; -module.exports = function tag(version) { - var history = require('./history')(version); - var tagname = 'v' + version; - exec('git tag -a "' + tagname + '" -m "' + history + '"'); -}; +const co = require('co'); +const exec = require('./exec'); + +module.exports = co.wrap(function * (version) { + const history = yield require('./history')(version); + const tagname = 'v' + version; + + return yield exec('git tag -a "' + tagname + '" -m "' + history + '"'); +}); diff --git a/tools/commit-changes.js b/tools/commit-changes.js index 11b9d52..d22bd3a 100644 --- a/tools/commit-changes.js +++ b/tools/commit-changes.js @@ -1,6 +1,7 @@ -var exec = require('./exec'); +'use strict'; -module.exports = function commit(version) { - var changed = [/*'ChangeLog.md',*/ 'package.json'].join(' '); - exec('git commit -m "' + version + '" ' + changed); -}; +const exec = require('./exec'); +const changed = [/*'ChangeLog.md',*/ 'package.json'].join(' '); + +module.exports = + (version) => exec('git commit -m "' + version + '" ' + changed); diff --git a/tools/exec.js b/tools/exec.js index 0115766..84a7d11 100644 --- a/tools/exec.js +++ b/tools/exec.js @@ -1,5 +1,9 @@ -var _exec = require('child_process').execSync; +'use strict'; -module.exports = function(expression) { - return String(_exec(expression)).trim(); -}; +const exec = require('child_process').exec; + +module.exports = + (expression) => new Promise( + (resolve, reject) => exec(expression, + (error, result) => error ? reject(error) : resolve(String(result).trim()) +)); diff --git a/tools/history.js b/tools/history.js index 81c2c9a..87156eb 100644 --- a/tools/history.js +++ b/tools/history.js @@ -1,8 +1,12 @@ -var exec = require('./exec'); +'use strict'; -module.exports = function history() { - var _lasttag = exec('git rev-list --tags --max-count=1'); - var _version = exec('git describe --tags --abbrev=0 ' + _lasttag); - var version = _version ? ' ' + _version + '..' : ''; - return ' ' + exec('git log --no-merges --pretty="format: * %s (%an) %H%n"' + version); -} +const co = require('co'); +const exec = require('./exec'); + +module.exports = co.wrap(function * () { + const _lasttag = yield exec('git rev-list --tags --max-count=1'); + const _version = yield exec('git describe --tags --abbrev=0 ' + _lasttag); + const version = _version ? ' ' + _version + '..' : ''; + + return ' ' + (yield exec('git log --no-merges --pretty="format: * %s (%an) %H%n"' + version)); +}); diff --git a/tools/prepublish-to-npm.js b/tools/prepublish-to-npm.js index 55f145d..31225f1 100644 --- a/tools/prepublish-to-npm.js +++ b/tools/prepublish-to-npm.js @@ -1,39 +1,37 @@ -var rimraf = require('rimraf'); -var extend = require('util')._extend; -var gyp = require('node-pre-gyp'); +'use strict'; -rimraf.sync('./build'); - -var versions = ['0.10.0', '0.12.0', '4.0.0', '5.0.0']; -var matrix = { +const co = require('co'); +const rimraf = require('rimraf'); +const gyp = require('node-pre-gyp'); +const versions = ['0.10.0', '0.12.0', '4.0.0', '5.0.0', '6.0.0']; +const matrix = { x64: ['win32', 'linux', 'darwin'], ia32: ['win32'] }; -var targets = []; -Object.keys(matrix).forEach(function(arch) { - matrix[arch].forEach(function(platform) { - versions.forEach(function(version) { - targets.push({ - target: version, - target_platform: platform, - target_arch: arch - }); - }); - }); -}, []); - -module.exports = function prepublish(err) { - if (err) { - console.log(err.message); - return process.exit(1); +class Target { + constructor(arch, platform, version) { + this.target = version; + this.target_platform = platform; + this.target_arch = arch; } +} - var target = targets.pop(); +const install = target => new Promise((resolve, reject) => { + const prog = Object.assign(new gyp.Run(), {opts: target}); - if (!target) process.exit(0); + prog.commands.install([], error => error ? reject(error) : resolve()); +}); - var prog = extend(new gyp.Run(), {opts: target}); +module.exports = co.wrap(function * () { + rimraf.sync('./build'); - prog.commands.install([], prepublish); -}; + const targets = []; + Object.keys(matrix).forEach( + (arch) => matrix[arch].forEach( + (platform) => versions.forEach( + (version) => targets.push(new Target(arch, platform, version)) + ))); + + while (targets.length) yield install(targets.pop()); +}); diff --git a/tools/publish-to-npm.js b/tools/publish-to-npm.js index 829e8f0..e73f1ca 100644 --- a/tools/publish-to-npm.js +++ b/tools/publish-to-npm.js @@ -1,5 +1,6 @@ -var exec = require('./exec'); +'use strict'; -module.exports = function publish(version) { - exec('npm publish'); -}; +const exec = require('./exec'); + +module.exports = + (version) => exec('npm publish'); diff --git a/tools/push-to-githab.js b/tools/push-to-githab.js index 37314be..be9cd64 100644 --- a/tools/push-to-githab.js +++ b/tools/push-to-githab.js @@ -1,6 +1,6 @@ -var exec = require('./exec'); +'use strict'; -module.exports = function push(version) { - var tag = 'v' + version; - exec('git push && git push origin "' + tag + '"'); -}; +const exec = require('./exec'); + +module.exports = + (version) => exec('git push && git push origin "v' + version + '"'); diff --git a/tools/release.js b/tools/release.js index f61b13b..1abd25a 100644 --- a/tools/release.js +++ b/tools/release.js @@ -1,55 +1,60 @@ -var args = process.argv.slice(2); -var version = args.splice(-1); +'use strict'; -var npm = require('./update-npm-version'); -var changelog = require('./update-changelog'); -var tag = require('./annotate-tag'); -var commit = require('./commit-changes'); -var push = require('./push-to-githab'); +const co = require('co'); +const args = process.argv.slice(2); +const version = args.splice(0, 1); -var prepublish = require('./prepublish-to-npm'); -var publish = require('./publish-to-npm'); +const npm = require('./update-npm-version'); +const changelog = require('./update-changelog'); +const tag = require('./annotate-tag'); +const commit = require('./commit-changes'); +const push = require('./push-to-githab'); -var EXAMPLE = ' Example:\n' + +const prepublish = require('./prepublish-to-npm'); +const publish = require('./publish-to-npm'); + +const EXAMPLE = ' Example:\n' + 'node release.js 1.0.0 --build\n' + 'node release.js 1.0.0 --publish' -var SEMVER = /^\d+(\.\d+(\.\d+(-.*)?)?(-.*)?)?(-.*)?$/; +const SEMVER = /^\d+(\.\d+(\.\d+(-.*)?)?(-.*)?)?(-.*)?$/; console.assert(version, 'Wrong usage.' + EXAMPLE); console.assert(SEMVER.test(version), version + ' is not correct semver'); -var BUILD = args.some(function(arg) { - return /^(-b|--build)$/.test(arg); -}); +const BUILD = args.some( + (arg) => /^(-b|--build)$/.test(arg)); -var PUBLISH = args.some(function(arg) { - return /^(-p|--publish)$/.test(arg); -}); +const PUBLISH = args.some( + (arg) => /^(-p|--publish)$/.test(arg)); console.assert(BUILD || PUBLISH, 'No mode selected.' + EXAMPLE); -if (BUILD) { - console.log('--Update the version in package.json--'); - npm(version); - - // TODO: enable changelog on 1.0 version - // console.log('--Update ChangeLog.md--'); - // changelog(); - - console.log('--Commit the changes--'); - commit(version); - - console.log('--Tag the release--') - tag(version); - - console.log('--Push to github--'); - push(version); - -} else if (PUBLISH) { - console.log('--Download prebuilt binaries--'); - prepublish(); - - console.log('--Publish to npm--'); - publish(); -} +return co(function * () { + if (BUILD) { + console.log('--Update the version in package.json--'); + yield npm(version); + + // TODO: enable changelog on 1.0 version + // console.log('--Update ChangeLog.md--'); + // changelog(); + + console.log('--Commit the changes--'); + yield commit(version); + + console.log('--Tag the release--') + yield tag(version); + + console.log('--Push to github--'); + yield push(version); + } else if (PUBLISH) { + console.log('--Download prebuilt binaries--'); + yield prepublish(); + + console.log('--Publish to npm--'); + yield publish(); + } +}).catch((error) => { + console.error(error.stack); + return process.exit(1); +}); diff --git a/tools/update-npm-version.js b/tools/update-npm-version.js index e3216a4..bed668a 100644 --- a/tools/update-npm-version.js +++ b/tools/update-npm-version.js @@ -1,5 +1,6 @@ -var exec = require('./exec'); +'use strict'; -module.exports = function npm(version) { - exec('npm version --git-tag-version=false "' + version + '"'); -}; +const exec = require('./exec'); + +module.exports = + (version) => exec('npm version --git-tag-version=false "' + version + '"');