From 4c9abbd1bb7a38b78680e3496f4f2a82802cb0bc Mon Sep 17 00:00:00 2001 From: ronkorving Date: Fri, 18 Sep 2015 17:36:57 +0900 Subject: [PATCH] fs: reduced duplicate code in fs.write() PR-URL: https://github.com/nodejs/node/pull/2947 Reviewed-By: Sakthipriyan Vairamani Reviewed-By: Trevor Norris --- lib/fs.js | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/lib/fs.js b/lib/fs.js index 42d02baa9e5d91..22e00c703020d3 100644 --- a/lib/fs.js +++ b/lib/fs.js @@ -662,17 +662,14 @@ fs.readSync = function(fd, buffer, offset, length, position) { // OR // fs.write(fd, string[, position[, encoding]], callback); fs.write = function(fd, buffer, offset, length, position, callback) { - function strWrapper(err, written) { + function wrapper(err, written) { // Retain a reference to buffer so that it can't be GC'ed too soon. callback(err, written || 0, buffer); } - function bufWrapper(err, written) { - // retain reference to string in case it's external - callback(err, written || 0, buffer); - } - var req = new FSReqWrap(); + req.oncomplete = wrapper; + if (buffer instanceof Buffer) { // if no position is passed then assume null if (typeof position === 'function') { @@ -680,7 +677,6 @@ fs.write = function(fd, buffer, offset, length, position, callback) { position = null; } callback = maybeCallback(callback); - req.oncomplete = strWrapper; return binding.writeBuffer(fd, buffer, offset, length, position, req); } @@ -696,7 +692,6 @@ fs.write = function(fd, buffer, offset, length, position, callback) { length = 'utf8'; } callback = maybeCallback(position); - req.oncomplete = bufWrapper; return binding.writeString(fd, buffer, offset, length, req); };