Skip to content
This repository was archived by the owner on Oct 15, 2020. It is now read-only.
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
3d7245c
test: refactor test-util-inspect.js
aqrln Mar 10, 2017
6a5ab5d
fs: include more fs.stat*() optimizations
mscdex Mar 12, 2017
7109774
fs: more realpath*() optimizations
mscdex Mar 12, 2017
1a210c4
test: added test for indexed properties
AnnaMag Mar 9, 2017
db277f0
readline: remove unneeded eslint-disable comment
Trott Mar 14, 2017
5bd1642
lib: remove unused msg parameter in debug_agent
mr-spd Mar 13, 2017
b5eccc4
lib, test: add duplicate symbol checking in E()
davidtaikocha Mar 13, 2017
e296ffb
doc: fix mistakes in stream doc (object mode)
chdh Mar 12, 2017
474e9d6
test: add more test cases of server.listen option
joyeecheung Mar 10, 2017
5bfd13b
util: display Symbol keys in inspect by default
mightyiam Nov 21, 2016
db39273
doc: increase Buffer.concat() documentation
cjihrig Mar 14, 2017
7b830f4
test: add more and refactor test cases to net.connect
joyeecheung Mar 13, 2017
746339e
doc: gcc version is at least 4.8.5 in BUILDING.md
detailyang Mar 14, 2017
5e3d536
test: fix flaky test-domain-abort-on-uncaught
Trott Mar 12, 2017
303962a
doc: linkable commit message guidelines
sam-github Mar 10, 2017
4cdb0e8
tls: keep track of stream that is closed
jBarz Mar 9, 2017
d099f8e
src: remove explicit UTF-8 validity check in url
TimothyGu Mar 15, 2017
d631af5
test: delay child exit in AIX for pseudo-tty tests
gireeshpunathil Mar 6, 2017
f0d4237
build: mac OBJ_DIR should point to obj.target
danbev Mar 15, 2017
c7b6016
repl: Empty command should be sent to eval function
Mar 15, 2017
379eec3
build: add cpp linting to windows build
Mar 15, 2017
6473737
test: failing behaviour on sandboxed Proxy
AnnaMag Mar 2, 2017
38299d2
Fix #7065: cli help documentation for --inspect
Mar 16, 2017
b57f9ee
deps: Add node-inspect 1.10.6
Mar 15, 2017
7042631
lib: Fix swallowed events in inspect integration
Mar 15, 2017
c8acd08
benchmark: benchmark comparing forEach with for
jasnell Feb 26, 2017
910a899
stream: avoid using forEach
jasnell Feb 26, 2017
5aa7d4d
tls: avoid using forEach
jasnell Feb 26, 2017
a993beb
fs: avoid using forEach
jasnell Feb 26, 2017
4d09085
lib: avoid using forEach in LazyTransform
jasnell Feb 27, 2017
42e55eb
net: avoid using forEach
jasnell Feb 27, 2017
53cf483
readline: avoid using forEach
jasnell Feb 27, 2017
ae9e640
repl: avoid using forEach
jasnell Feb 27, 2017
2d230fa
module: avoid using forEach
jasnell Feb 27, 2017
f6dbead
util: avoid using forEach
jasnell Feb 27, 2017
989713d
lib: avoid using forEach
jasnell Feb 27, 2017
2e74b0d
doc: add note that vm module is not a security mechanism
krydos Feb 25, 2017
df69d95
test: add coverage for child_process bounds check
Trott Mar 11, 2017
5bda5fa
readline: add option to stop duplicates in history
DannyNemer Sep 21, 2015
08a0e89
Merge remote-tracking branch 'nodejs/master' into xplat
kunalspathak Mar 17, 2017
b7a68b5
src,test: Fixed merge conflicts
kunalspathak Mar 17, 2017
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fs: include more fs.stat*() optimizations
Including:

* Move async *stat() functions to FillStatsArray() now used by the
sync *stat() functions

* Avoid creating fs.Stats instances for implicit async/sync *stat()
calls used in various fs functions

* Store reference to Float64Array data on C++ side for easier/faster
access, instead of passing from JS to C++ on every async/sync *stat()
call

PR-URL: nodejs/node#11665
Reviewed-By: Ben Noordhuis <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Anna Henningsen <[email protected]>
Reviewed-By: Matteo Collina <[email protected]>
Reviewed-By: Colin Ihrig <[email protected]>
  • Loading branch information
mscdex authored and jasnell committed Mar 15, 2017
commit 6a5ab5d550719f416683ec0d588461b8bc9a8787
22 changes: 16 additions & 6 deletions benchmark/fs/bench-stat.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,30 @@ const common = require('../common');
const fs = require('fs');

const bench = common.createBenchmark(main, {
n: [1e4],
kind: ['lstat', 'stat']
n: [20e4],
kind: ['fstat', 'lstat', 'stat']
});


function main(conf) {
const n = conf.n >>> 0;
const kind = conf.kind;
var arg;
if (kind === 'fstat')
arg = fs.openSync(__filename, 'r');
else
arg = __filename;

bench.start();
(function r(cntr, fn) {
if (cntr-- <= 0)
return bench.end(n);
fn(__filename, function() {
if (cntr-- <= 0) {
bench.end(n);
if (kind === 'fstat')
fs.closeSync(arg);
return;
}
fn(arg, function() {
r(cntr, fn);
});
}(n, fs[conf.kind]));
}(n, fs[kind]));
}
37 changes: 12 additions & 25 deletions benchmark/fs/bench-statSync.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,36 +4,23 @@ const common = require('../common');
const fs = require('fs');

const bench = common.createBenchmark(main, {
n: [1e4],
n: [1e6],
kind: ['fstatSync', 'lstatSync', 'statSync']
});


function main(conf) {
const n = conf.n >>> 0;
var fn;
var i;
switch (conf.kind) {
case 'statSync':
case 'lstatSync':
fn = fs[conf.kind];
bench.start();
for (i = 0; i < n; i++) {
fn(__filename);
}
bench.end(n);
break;
case 'fstatSync':
fn = fs.fstatSync;
const fd = fs.openSync(__filename, 'r');
bench.start();
for (i = 0; i < n; i++) {
fn(fd);
}
bench.end(n);
fs.closeSync(fd);
break;
default:
throw new Error('Invalid kind argument');
const kind = conf.kind;
const arg = (kind === 'fstatSync' ? fs.openSync(__filename, 'r') : __dirname);
const fn = fs[conf.kind];

bench.start();
for (var i = 0; i < n; i++) {
fn(arg);
}
bench.end(n);

if (kind === 'fstat')
fs.closeSync(arg);
}
17 changes: 17 additions & 0 deletions benchmark/fs/readFileSync.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
'use strict';

var common = require('../common.js');
var fs = require('fs');

var bench = common.createBenchmark(main, {
n: [60e4]
});

function main(conf) {
var n = +conf.n;

bench.start();
for (var i = 0; i < n; ++i)
fs.readFileSync(__filename);
bench.end(n);
}
Loading