diff options
author | Felix Geisendörfer <felix@debuggable.com> | 2010-06-14 19:34:34 +0200 |
---|---|---|
committer | Ryan Dahl <ry@tinyclouds.org> | 2010-06-14 10:58:17 -0700 |
commit | 5f3906b65e3bced391de60b513299f6d7790fb2e (patch) | |
tree | 31eb8ed775c6fb37d5988d78809f91477e2048ca | |
parent | 02da5ed4a1f63bb0990b8e7b1fd0793cd045cbb0 (diff) | |
download | node-new-5f3906b65e3bced391de60b513299f6d7790fb2e.tar.gz |
Fix: fs.writeFile could not handle utf8
-rw-r--r-- | lib/fs.js | 11 | ||||
-rw-r--r-- | test/simple/test-fs-write-file.js | 34 |
2 files changed, 40 insertions, 5 deletions
@@ -360,17 +360,17 @@ fs.chownSync = function(path, uid, gid) { return binding.chown(path, uid, gid); }; -function writeAll (fd, data, encoding, callback) { - fs.write(fd, data, 0, encoding, function (writeErr, written) { +function writeAll (fd, buffer, callback) { + fs.write(fd, buffer, 0, buffer.length, null, function (writeErr, written) { if (writeErr) { fs.close(fd, function () { if (callback) callback(writeErr); }); } else { - if (written === data.length) { + if (written === buffer.length) { fs.close(fd, callback); } else { - writeAll(fd, data.slice(written), encoding, callback); + writeAll(fd, buffer.slice(written), callback); } } }); @@ -384,7 +384,8 @@ fs.writeFile = function (path, data, encoding_, callback) { if (openErr) { if (callback) callback(openErr); } else { - writeAll(fd, data, encoding, callback); + var buffer = new Buffer(data, encoding); + writeAll(fd, buffer, callback); } }); }; diff --git a/test/simple/test-fs-write-file.js b/test/simple/test-fs-write-file.js new file mode 100644 index 0000000000..cc0fdfabfe --- /dev/null +++ b/test/simple/test-fs-write-file.js @@ -0,0 +1,34 @@ +require('../common'); + +join = require('path').join; +fs = require('fs'); +Buffer = require('buffer').Buffer; + +filename = join(fixturesDir, 'test.txt'); + +error('writing to ' + filename); + +s = "南越国是前203年至前111年存在于岭南地区的一个国家,国都位于番禺,疆域包括今天中国的广东、广西两省区的大部份地区,福建省、湖南、贵州、云南的一小部份地区和越南的北部。南越国是秦朝灭亡后,由南海郡尉赵佗于前203年起兵兼并桂林郡和象郡后建立。前196年和前179年,南越国曾先后两次名义上臣属于西汉,成为西汉的“外臣”。前112年,南越国末代君主赵建德与西汉发生战争,被汉武帝于前111年所灭。南越国共存在93年,历经五代君主。南越国是岭南地区的第一个有记载的政权国家,采用封建制和郡县制并存的制度,它的建立保证了秦末乱世岭南地区社会秩序的稳定,有效的改善了岭南地区落后的政治、##济现状。\n"; + +ncallbacks = 0; + +fs.writeFile(filename, s, function (e) { + if (e) throw e; + + ncallbacks++; + error('file written'); + + fs.readFile(filename, function (e, buffer) { + if (e) throw e; + error('file read'); + ncallbacks++; + assert.equal(Buffer.byteLength(s), buffer.length); + }); +}); + + +process.addListener('exit', function () { + error('done'); + + assert.equal(2, ncallbacks); +});
\ No newline at end of file |