= Proposed Self Contained Change: Node.js 0.12 =
https://fedoraproject.org/wiki/Changes/NodeJS012

Change owner(s): T.C. Hollingsworth <tchollingsworth at gmail dot com>

Fedora 23 will be updated to Node.js 0.12, the latest release of the platform 
built on Chrome's JavaScript runtime for easily building fast, scalable network 
applications. 

== Detailed Description ==
Node.js has seen many changes between v0.10 and v0.12. There is a listing of 
changes documented on the wiki. Note that this release includes API updates 
that may require dependency updates. Following are some highlights:

* Streams 3
        The Streams implementation now works the way you thought it already 
should, without introducing any changes to the API. Basically this means no 
more getting stuck in "old mode", there are only streams that are flowing or 
not.
        Streams now support the use of cork and uncork mechanisms to prevent 
flushing writes out to the system if an application is going to be performing 
many writes in a row. There is an implicit uncork performed when you end a 
writable stream. 

* HTTP
        maxSockets are no longer limited to 5. The default is now set to 
Infinity with the developer and the operating system given control over how 
many simultaneous connections an application can keep open to a given host.
        Proper KeepAlive support means that sockets will stay open until they 
timeout at the configured time, are closed by the remote side, or the process 
exits. Developer's no longer have to make sure requests have been pipelined to 
keep the socket open, or use an alternative module to get that support.
        Developers can also now explicitly flushHeaders to ensure time to first 
byte is low and proxied connections are held open. 

* Cluster
        Now has two modes of operation, the new default is a round robin 
distribution mechanism where the master accepts new connections and distributes 
them to your workers. If you want you can still opt back into the old method 
where your workers are responsible for acception connections. 

* TLS
        We have the new TLSWrap mechanism under the hood, this eliminates quite 
a few of the hops back and forth between JavaScript and our C++ implementations.
        Added APIs for asynchronous SNI callbacks, OCSP stapling, and storage 
events. 

* Buffer
        We use a more accurate mechanism for allocating memory for buffers now, 
which means you'll see less overhead and impact from holding onto to small 
slices of Buffers. This reduces the amount of memory pressure on the system, 
which means GC runs are quicker, which means Node.js is on CPU less, and thus 
lower latency for your applications. 

* child_process
        spawnSync/execSync have been added to facilitate synchronous child 
processes, warning your node process won't make forward progress while waiting 
for the child to exit, caveat emptor! 

* Crypto
        Added APIs for loading custom engines for use with compiled in OpenSSL.
        More APIs support supplying the pass phrases.
        Added APIs for RSA public/private key encryption/decryption. 

* VM
        The module is now based on the Contextify module, which shares values 
from the sandbox to avoid missing changes inside the execution from appearing 
in the parent context.
        Initial support for ECMAScript Internationalization API 1.0 (ECMA-402)
        By default, Node.js v0.12.0 binaries are shipped with ECMA-402 support, 
but only for the English language. In other words, the ECMA-402 API is working 
as you would expect, but only data for the English language is included. You 
can find more info on how to include more languages in the Wiki. 

These are just some of the changes you can find in this release of v0.12, and 
it's thanks to the hard work of the community and the members of team curating 
Node.js.

We are also pleased to report that this release of Node.js has tests passing on 
all of our supported platforms. On the one hand, this seems obvious (what are 
tests for if not to verify before you release it?!), but this is actually the 
first release of Node.js that has operated under this constraint. Requiring 
that all tests pass before releasing Node.js marks an important development for 
the project, and is essential for building a solid path moving forward. 

== Scope ==
* Proposal owners:
  -- Update v8
  -- Update nodejs
  -- Rebuild all binary modules, apply patches as necessary
  -- Update npm 
* Other developers:
  -- Other Node.js packagers' attention may be required if the update causes 
issues for their packages. 
* Release engineering: N/A (not a System Wide Change) 
* Policies and guidelines:
  -- Some minor updates to the Node.js guidelines are planned, however they are 
just Nice To Have for the purposes of this specific change. 
* Trademark approval: N/A (not needed for this Change) 
-- 
Jan Kuřík
_______________________________________________
devel-announce mailing list
devel-annou...@lists.fedoraproject.org
https://admin.fedoraproject.org/mailman/listinfo/devel-announce
-- 
devel mailing list
devel@lists.fedoraproject.org
https://admin.fedoraproject.org/mailman/listinfo/devel
Fedora Code of Conduct: http://fedoraproject.org/code-of-conduct

Reply via email to