diff options
-rw-r--r-- | src/node_file.cc | 29 | ||||
-rw-r--r-- | test/mjsunit/test-readdir.js | 41 |
2 files changed, 19 insertions, 51 deletions
diff --git a/src/node_file.cc b/src/node_file.cc index 7cf12bc351..07f8ab5cec 100644 --- a/src/node_file.cc +++ b/src/node_file.cc @@ -10,8 +10,6 @@ #include <string.h> #include <errno.h> -#include <dirent.h> - namespace node { using namespace v8; @@ -326,10 +324,6 @@ static Handle<Value> SendFile(const Arguments& args) { } } -static inline int scandir_one(struct dirent *unused) { - return 1; -} - static Handle<Value> ReadDir(const Arguments& args) { HandleScope scope; @@ -342,26 +336,9 @@ static Handle<Value> ReadDir(const Arguments& args) { if (args[1]->IsFunction()) { ASYNC_CALL(readdir, args[1], *path, 0 /*flags*/) } else { - struct dirent **eps; - int n = scandir(*path, &eps, scandir_one, alphasort); - - if ( n >= 0) { - int cnt; - char *name; - - Local<Array> res = Array::New(n); - - for(cnt = 0; cnt < n; ++cnt) { - name = eps[cnt]->d_name; - - if (name [0] != '.') { - res->Set(Integer::New(cnt), String::New(name)); - } - } - return scope.Close(res); - } else { - return ThrowException(errno_exception(errno)); - } + // TODO + return ThrowException(Exception::Error( + String::New("synchronous readdir() not yet supported."))); } } diff --git a/test/mjsunit/test-readdir.js b/test/mjsunit/test-readdir.js index 4ded485571..f740560a55 100644 --- a/test/mjsunit/test-readdir.js +++ b/test/mjsunit/test-readdir.js @@ -2,37 +2,28 @@ process.mixin(require("./common")); var got_error = false; -var files = ['a.js' - , 'b' - , 'cycles' - , 'echo.js' - , 'multipart.js' - , 'nested-index' - , 'print-chars.js' - , 'test_ca.pem' - , 'test_cert.pem' - , 'test_key.pem' - , 'throws_error.js' - , 'x.txt' - ]; - - -puts('readdirSync ' + fixturesDir); -var f = fs.readdirSync(fixturesDir); -p(f); -assert.deepEqual(files, f.sort()); - - -puts("readdir " + fixturesDir); -fs.readdir(fixturesDir, function (err, f) { +fs.readdir(fixturesDir, function (err, files) { if (err) { puts("error"); got_error = true; } else { - p(f); - assert.deepEqual(files, f.sort()); + p(files); + assert.deepEqual(['a.js' + , 'b' + , 'cycles' + , 'echo.js' + , 'multipart.js' + , 'nested-index' + , 'print-chars.js' + , 'test_ca.pem' + , 'test_cert.pem' + , 'test_key.pem' + , 'throws_error.js' + , 'x.txt' + ], files.sort()); } }); +puts("readdir " + fixturesDir); process.addListener("exit", function () { assert.equal(false, got_error); |