Start refactoring of fs.js

This commit is contained in:
David Humphrey (:humph) david.humphrey@senecacollege.ca 2014-03-18 12:29:20 -04:00
parent 5c5c4a6070
commit 8dcc38de82
8 changed files with 105 additions and 105 deletions

View File

@ -29,7 +29,12 @@ module.exports = function(grunt) {
'src/fswatcher.js', 'src/fswatcher.js',
'src/environment.js', 'src/environment.js',
'src/providers/**/*.js', 'src/providers/**/*.js',
'src/adapters/**/*.js' 'src/adapters/**/*.js',
'src/directory-entry.js',
'src/open-file-description.js',
'src/super-node.js',
'src/node.js',
'src/stats.js'
] ]
}, },

8
src/directory-entry.js Normal file
View File

@ -0,0 +1,8 @@
define(['src/constants'], function(Constants) {
return function DirectoryEntry(id, type) {
this.id = id;
this.type = type || Constants.MODE_FILE;
};
});

113
src/fs.js
View File

@ -12,7 +12,6 @@ define(function(require) {
var isAbsolutePath = require('src/path').isAbsolute; var isAbsolutePath = require('src/path').isAbsolute;
var isNullPath = require('src/path').isNull; var isNullPath = require('src/path').isNull;
var guid = require('src/shared').guid;
var hash = require('src/shared').hash; var hash = require('src/shared').hash;
var nop = require('src/shared').nop; var nop = require('src/shared').nop;
@ -42,110 +41,16 @@ define(function(require) {
var providers = require('src/providers/providers'); var providers = require('src/providers/providers');
var adapters = require('src/adapters/adapters'); var adapters = require('src/adapters/adapters');
var Shell = require('src/shell'); var Shell = require('src/shell');
var Intercom = require('intercom'); var Intercom = require('intercom');
var FSWatcher = require('src/fswatcher'); var FSWatcher = require('src/fs-watcher');
var Errors = require('src/errors'); var Errors = require('src/errors');
var DirectoryEntry = require('src/directory-entry');
/* var OpenFileDescription = require('src/open-file-description');
* DirectoryEntry var SuperNode = require('src/super-node');
*/ var Node = require('src/node');
var Stats = require('src/stats');
function DirectoryEntry(id, type) {
this.id = id;
this.type = type || MODE_FILE;
}
/*
* OpenFileDescription
*/
function OpenFileDescription(path, id, flags, position) {
this.path = path;
this.id = id;
this.flags = flags;
this.position = position;
}
/*
* SuperNode
*/
function SuperNode(atime, ctime, mtime) {
var now = Date.now();
this.id = SUPER_NODE_ID;
this.mode = MODE_META;
this.atime = atime || now;
this.ctime = ctime || now;
this.mtime = mtime || now;
this.rnode = guid(); // root node id (randomly generated)
}
/*
* Node
*/
function Node(id, mode, size, atime, ctime, mtime, flags, xattrs, nlinks, version) {
var now = Date.now();
this.id = id || guid();
this.mode = mode || MODE_FILE; // node type (file, directory, etc)
this.size = size || 0; // size (bytes for files, entries for directories)
this.atime = atime || now; // access time (will mirror ctime after creation)
this.ctime = ctime || now; // creation/change time
this.mtime = mtime || now; // modified time
this.flags = flags || []; // file flags
this.xattrs = xattrs || {}; // extended attributes
this.nlinks = nlinks || 0; // links count
this.version = version || 0; // node version
this.blksize = undefined; // block size
this.nblocks = 1; // blocks count
this.data = guid(); // id for data object
}
/*
* Stats
*/
function Stats(fileNode, devName) {
this.node = fileNode.id;
this.dev = devName;
this.size = fileNode.size;
this.nlinks = fileNode.nlinks;
this.atime = fileNode.atime;
this.mtime = fileNode.mtime;
this.ctime = fileNode.ctime;
this.type = fileNode.mode;
}
Stats.prototype.isFile = function() {
return this.type === MODE_FILE;
};
Stats.prototype.isDirectory = function() {
return this.type === MODE_DIRECTORY;
};
Stats.prototype.isBlockDevice = function() {
return false;
};
Stats.prototype.isCharacterDevice = function() {
return false;
};
Stats.prototype.isSymbolicLink = function() {
return this.type === MODE_SYMBOLIC_LINK;
};
Stats.prototype.isFIFO = function() {
return false;
};
Stats.prototype.isSocket = function() {
return false;
};
/* /*
* Update node times. Only passed times are modified (undefined times are ignored) * Update node times. Only passed times are modified (undefined times are ignored)
@ -1630,7 +1535,7 @@ define(function(require) {
if(FS_READY == fs.readyState) { if(FS_READY == fs.readyState) {
operation.call(fs); operation.call(fs);
} else if(FS_ERROR == fs.readyState) { } else if(FS_ERROR == fs.readyState) {
error = new EFileSystemError('unknown error'); error = new Errors.EFILESYSTEMERROR('unknown error');
} else { } else {
queue.push(operation); queue.push(operation);
} }
@ -1834,7 +1739,7 @@ define(function(require) {
var ofd = fs.openFiles[fd]; var ofd = fs.openFiles[fd];
if(!ofd) { if(!ofd) {
callback(new EBadFileDescriptor('invalid file descriptor')); callback(new Errors.EBADF());
} else { } else {
fstat_file(context, ofd, check_result); fstat_file(context, ofd, check_result);
} }

21
src/node.js Normal file
View File

@ -0,0 +1,21 @@
define(['src/constants', 'src/shared'], function(Constants, Shared) {
return function Node(id, mode, size, atime, ctime, mtime, flags, xattrs, nlinks, version) {
var now = Date.now();
this.id = id || Shared.guid();
this.mode = mode || Constants.MODE_FILE; // node type (file, directory, etc)
this.size = size || 0; // size (bytes for files, entries for directories)
this.atime = atime || now; // access time (will mirror ctime after creation)
this.ctime = ctime || now; // creation/change time
this.mtime = mtime || now; // modified time
this.flags = flags || []; // file flags
this.xattrs = xattrs || {}; // extended attributes
this.nlinks = nlinks || 0; // links count
this.version = version || 0; // node version
this.blksize = undefined; // block size
this.nblocks = 1; // blocks count
this.data = Shared.guid(); // id for data object
};
});

View File

@ -0,0 +1,10 @@
define(function(require) {
return function OpenFileDescription(path, id, flags, position) {
this.path = path;
this.id = id;
this.flags = flags;
this.position = position;
};
});

37
src/stats.js Normal file
View File

@ -0,0 +1,37 @@
define(['src/constants'], function(Constants) {
function Stats(fileNode, devName) {
this.node = fileNode.id;
this.dev = devName;
this.size = fileNode.size;
this.nlinks = fileNode.nlinks;
this.atime = fileNode.atime;
this.mtime = fileNode.mtime;
this.ctime = fileNode.ctime;
this.type = fileNode.mode;
}
Stats.prototype.isFile = function() {
return this.type === Constants.MODE_FILE;
};
Stats.prototype.isDirectory = function() {
return this.type === Constants.MODE_DIRECTORY;
};
Stats.prototype.isSymbolicLink = function() {
return this.type === Constants.MODE_SYMBOLIC_LINK;
};
// These will always be false in Filer.
Stats.prototype.isSocket =
Stats.prototype.isFIFO =
Stats.prototype.isCharacterDevice =
Stats.prototype.isBlockDevice =
function() {
return false;
};
return Stats;
});

14
src/super-node.js Normal file
View File

@ -0,0 +1,14 @@
define(['src/constants', 'src/shared'], function(Constants, Shared) {
return function SuperNode(atime, ctime, mtime) {
var now = Date.now();
this.id = Constants.SUPER_NODE_ID;
this.mode = Constants.MODE_META;
this.atime = atime || now;
this.ctime = ctime || now;
this.mtime = mtime || now;
this.rnode = Shared.guid(); // root node id (randomly generated)
};
});