Node.js JavaScript runtime 🐢🚀
 
 
 
 
 
 
Go to file
Ben Noordhuis ebf9f297b3 lib: fix guard expression in timer.unref()
Fixes the following assertion on slow systems, like our ARM buildbot:

    $ out/Debug/node test/simple/test-timers-unref.js
    node: ../src/async-wrap-inl.h:101: v8::Handle<v8::Value>
    node::AsyncWrap::MakeCallback(uint32_t, int,
    v8::Handle<v8::Value>*): Assertion `cb_v->IsFunction()' failed.
    Aborted

The reason it only manifests on slow systems is that the test starts
a 1 ms interval timer, then defers timer.unref.bind({}) to the next
tick.  On fast systems, the test completes in under a millisecond,
before the callback is called.

This commit makes timer.unref() check that the receiver actually has
a timeout callback property.

Fixes #13.

PR-URL: https://github.com/iojs/io.js/pull/165
Reviewed-By: Rod Vagg <rod@vagg.org>
2014-12-18 18:24:29 +01:00
benchmark domain: forward args to .run(fn) 2014-12-12 12:14:11 +11:00
deps uv: float patch to revert tty breakage 2014-12-09 17:57:07 +01:00
doc fs: add access() and accessSync() 2014-12-15 12:05:49 -05:00
lib lib: fix guard expression in timer.unref() 2014-12-18 18:24:29 +01:00
src fs: add access() and accessSync() 2014-12-15 12:05:49 -05:00
test lib: fix guard expression in timer.unref() 2014-12-18 18:24:29 +01:00
tools test: run tests in parallel, common improvements 2014-12-17 20:45:37 +07:00
.gitattributes Explicitly disable cr/lf conversion for test fixtures 2011-08-10 19:59:37 +02:00
.gitignore test: run tests in parallel, common improvements 2014-12-17 20:45:37 +07:00
.mailmap Update .mailmap and AUTHORS 2013-03-19 20:07:38 +01:00
AUTHORS Merge remote-tracking branch 'upstream/v0.10' into v0.12 2014-09-16 17:48:09 -07:00
BSDmakefile Tell BSD users to run `gmake` instead. 2011-07-11 14:17:23 +02:00
CONTRIBUTING.md docs: fix project name 2014-12-09 16:18:50 +01:00
ChangeLog 2014.09.24, Version 0.11.14 (Unstable) 2014-09-24 17:15:10 -07:00
LICENSE Merge remote-tracking branch 'upstream/v0.10' 2013-08-06 11:59:17 -07:00
Makefile test: run tests in parallel, common improvements 2014-12-17 20:45:37 +07:00
Makefile.build src: move debug agent from deps/ to src/ 2014-11-03 12:08:04 +01:00
README.md docs: clarify that 'io.js' is the correct name 2014-12-11 15:50:16 +01:00
android-configure build: add android support 2013-06-17 17:21:56 +02:00
common.gypi build: remove workarounds for gcc <= 4.4 2014-10-16 22:39:40 +02:00
configure build: configure return exit status from gyp 2014-12-10 17:51:58 +01:00
node.gyp lib: reintroduce v8 module 2014-12-14 18:52:57 +01:00
vcbuild.bat test: run tests in parallel, common improvements 2014-12-17 20:45:37 +07:00

README.md

io.js

![Gitter](https://badges.gitter.im/Join Chat.svg)

This repository began as a GitHub fork of joyent/node. io.js contributions, releases, and contributorship are under an open governance model. We intend to land, with increasing regularity, releases which are compatible with the npm ecosystem that has been built to date for node.js.

Is it io.js or IO.js or iojs or IOjs or iOjS?

The official name is io.js, which should never be capitalized, especially not at the start of a sentence, unless it is being displayed in a location that is customarily all-caps (such as the title of man pages.)

To build:

Prerequisites (Unix only):

  • gcc and g++ 4.8 or newer, or
  • clang and clang++ 3.3 or newer
  • Python 2.6 or 2.7
  • GNU Make 3.81 or newer
  • libexecinfo (FreeBSD and OpenBSD only)

Unix/Macintosh:

./configure
make
make install

If your python binary is in a non-standard location or has a non-standard name, run the following instead:

export PYTHON=/path/to/python
$PYTHON ./configure
make
make install

Prerequisites (Windows only):

  • Python 2.6 or 2.7
  • Visual Studio 2013 for Windows Desktop, or
  • Visual Studio Express 2013 for Windows Desktop

Windows:

vcbuild nosign

You can download pre-built binaries for various operating systems from http://nodejs.org/download/. The Windows and OS X installers will prompt you for the location in which to install. The tarballs are self-contained; you can extract them to a local directory with:

tar xzf /path/to/node-<version>-<platform>-<arch>.tar.gz

Or system-wide with:

cd /usr/local && tar --strip-components 1 -xzf \
                    /path/to/node-<version>-<platform>-<arch>.tar.gz

To run the tests:

Unix/Macintosh:

make test

Windows:

vcbuild test

To build the documentation:

make doc

To read the documentation:

man doc/node.1

To build Intl (ECMA-402) support:

Note: more docs, including how to reduce disk footprint, are on the wiki.

Use existing installed ICU (Unix/Macintosh only):

pkg-config --modversion icu-i18n && ./configure --with-intl=system-icu

Build ICU from source:

First: Unpack latest ICU icu4c-##.#-src.tgz (or .zip) as deps/icu (You'll have: deps/icu/source/...)

Unix/Macintosh:

./configure --with-intl=full-icu

Windows:

vcbuild full-icu

Resources for Newcomers