Table of Contents
When editing this page please be as detailed as possible. Examples are encouraged!
V8
0.12.0 ships with V8 version 3.28.73, which was released in August 2014.
Resource Management
- On Unix soft
ulimit
values are ignored.
Buffers
Module API Changes
Buffer
class has been removed and replaced with a namespace. Sousing node::Buffer
will no longer work.- All
node::Buffer::New()
variants now returnLocal<Object>
instead ofBuffer*
. - The return value for
node::Buffer::New()
is an instantiated JSBuffer
object. node::Buffer::New(Handle<String>)
now accepts an optional second argument ofenum encoding
.- API addition of
node::Buffer::Use()
which will use the passedchar*
instead of making a copy. - API addition of
node::Crypto::Certificate
which handlesnode::Crypto::Certificate::verifySpkac(Handle<String>)
,node::Crypto::Certificate::exportPublicKey(Handle<String>)
&node::Crypto::Certificte::exportChallenge(Handle<String>)
for working naively with SPKAC (Signed public key & challenges) coming from the HTML5keygen
element.
JS API Changes
- External memory is now allocated using
smalloc
, instead of usingSlowBuffer
as the parent backing. SlowBuffer
has been repurposed to return aBuffer
instance that has no parent backing.buffer.parent
now points to an object that has been allocated viasmalloc.alloc
, not aBuffer
instance, and only if the buffer is a slice.buffer.offset
is now a read-only prototype property equal to zero since no instance methods require working on the parent backing.- API additions
Buffer.alloc()
andBuffer.dispose()
have been added. Buffer#fill()
has been extended to fill with the entire passed value.(new Buffer('text\0!', 'ascii')).toString()
outputs'text !'
in 0.10 and'text\u0000!'
in 0.12.- Writable stream
_write()
gets called with 'buffer' encoding when chunk is a Buffer (#6119). - Writable stream emits 'finish' on next tick if there was a
write()
(#6118).
Process
process.maxTickDepth
has been removed, allowingprocess.nextTick
to starve I/O indefinitely. This is due to addingsetImmediate
in 0.10.
Child Process
customFds
option tochild_process.spawn
is deprecated. Instead ofcustomFds
you can usestdio
like https://github.com/mochajs/mocha/pull/1364/files
https
SNICallback
required returning asecureContext
synchronously asfunction (hostname) {}
. The function signature is nowfunction (hostname, cb) { cb(null, secureContext); }
. You can feature detect with'function' === typeof cb
.
Signal handling
In node 0.10.x, exit from a fatal signal was accomplished by a signal handler in
node which called exit(128 + signo)
. So for SIGINT
(signal 2), a node process
observing the exit of a spawned node process would observe that process exiting 130,
but no signal would be noted (see waitid(2)
for more information on how a process
waiting for another determines if the waitee exited due to a signal). In node
0.12.x, a node process observing the exit of a spawned child node process will
see a null code
, and a 'SIGINT'
as the signal.
Here is a pair of test programs which illustrates the difference.
$ cat sleeper.js
setTimeout(function () {}, 300000)
$ cat test.js
cp = require("child_process");
p = cp.spawn("node", ["sleeper.js"]);
report = function (code, signal) { console.log("code=" + code + ", signal=" + signal); }
p.on('exit', report);
setTimeout(function() { p.kill('SIGINT') }, 2000);
On node 0.10 this produces:
$ node test.js
code=130, signal=null
On node 0.12 this produces:
$ node test.js
code=null, signal=SIGINT
This can be a subtle porting issue for multi-process node environments which care
about signals (such as test harnesses). This change was introduced by
main: Handle SIGINT properly
.