Added path tools (from node.js) and normalization to API methods.
This commit is contained in:
parent
f4189c7e8b
commit
380b00ca3a
|
@ -15,7 +15,7 @@ require.config({
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
require(["../../javascript-debug/debug", "src/filesystem"], function(debug, IDBFS) {
|
require(["src/filesystem"], function(IDBFS) {
|
||||||
|
|
||||||
IDBFS.mount("default", function(error, fs) {
|
IDBFS.mount("default", function(error, fs) {
|
||||||
fs.mkdir("/tmp", function(error) {
|
fs.mkdir("/tmp", function(error) {
|
||||||
|
@ -29,27 +29,6 @@ require(["../../javascript-debug/debug", "src/filesystem"], function(debug, IDBF
|
||||||
});
|
});
|
||||||
}, true);
|
}, true);
|
||||||
|
|
||||||
/*
|
|
||||||
var fs = new IdbFS(undefined, true);
|
|
||||||
fs.then(function(fs) {
|
|
||||||
fs.mkdir("/tmp").then(function(result) {
|
|
||||||
var d = fs.open("/tmp/0", IdbFS.O_CREATE, IdbFS.FMODE_RW);
|
|
||||||
d.then(function(fd) {
|
|
||||||
fs.dump(document.getElementById("stdout"));
|
|
||||||
}, function(e) {
|
|
||||||
console.log(e);
|
|
||||||
});
|
|
||||||
}, function(error) {
|
|
||||||
console.log(error);
|
|
||||||
});
|
|
||||||
fs.stat("/tmp").then(function(result) {
|
|
||||||
console.log(result);
|
|
||||||
}, function(error) {
|
|
||||||
console.log(error);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
*/
|
|
||||||
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
</html>
|
</html>
|
|
@ -16,6 +16,7 @@ define(function(require) {
|
||||||
|
|
||||||
var debug = require("debug");
|
var debug = require("debug");
|
||||||
var _ = require("lodash");
|
var _ = require("lodash");
|
||||||
|
var path = require("src/path");
|
||||||
|
|
||||||
var indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB;
|
var indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB;
|
||||||
var BlobBuilder = window.BlobBuilder || window.MozBlobBuilder || window.WebKitBlobBuilder;
|
var BlobBuilder = window.BlobBuilder || window.MozBlobBuilder || window.WebKitBlobBuilder;
|
||||||
|
@ -27,23 +28,8 @@ define(function(require) {
|
||||||
}).toUpperCase();
|
}).toUpperCase();
|
||||||
}
|
}
|
||||||
|
|
||||||
function dirname(path) {
|
|
||||||
var components = path.split("/");
|
|
||||||
if(1 === components.length) {
|
|
||||||
return ".";
|
|
||||||
}
|
|
||||||
if(0 === _.last(components).length) {
|
|
||||||
components.pop();
|
|
||||||
}
|
|
||||||
components.pop();
|
|
||||||
if(components.length <= 1) {
|
|
||||||
return "/";
|
|
||||||
}
|
|
||||||
return components.join("/");
|
|
||||||
}
|
|
||||||
|
|
||||||
function makeDirectoryEntry(name, modtime) {
|
function makeDirectoryEntry(name, modtime) {
|
||||||
var parent = ("/" === name) ? null : dirname(name);
|
var parent = path.dirname(name);
|
||||||
return {
|
return {
|
||||||
"parent": parent,
|
"parent": parent,
|
||||||
"name": name,
|
"name": name,
|
||||||
|
@ -53,7 +39,7 @@ define(function(require) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function makeFileEntry(name, oid, size, modtime) {
|
function makeFileEntry(name, oid, size, modtime) {
|
||||||
var parent = ("/" === name) ? null : dirname(name);
|
var parent = path.dirname(name);
|
||||||
return {
|
return {
|
||||||
"parent": parent,
|
"parent": parent,
|
||||||
"name": name,
|
"name": name,
|
||||||
|
@ -64,9 +50,6 @@ define(function(require) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
function FileSystem(name, optFormat) {
|
function FileSystem(name, optFormat) {
|
||||||
function Transaction(db, scope, mode) {
|
function Transaction(db, scope, mode) {
|
||||||
|
@ -465,6 +448,8 @@ define(function(require) {
|
||||||
|
|
||||||
// API
|
// API
|
||||||
|
|
||||||
|
// Flags: CREATE, APPEND, TRUNCATE, DIRECTORY
|
||||||
|
// Modes: RO, RW
|
||||||
function open(pathname, flags, mode, callback) {
|
function open(pathname, flags, mode, callback) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -475,6 +460,7 @@ define(function(require) {
|
||||||
|
|
||||||
function mkdir(transaction, pathname, callback) {
|
function mkdir(transaction, pathname, callback) {
|
||||||
debug.info("mkdir -->");
|
debug.info("mkdir -->");
|
||||||
|
pathname = path.normalize(pathname);
|
||||||
transaction = transaction || db.transaction([METADATA_STORE_NAME], IDB_RW);
|
transaction = transaction || db.transaction([METADATA_STORE_NAME], IDB_RW);
|
||||||
var store = transaction.objectStore(METADATA_STORE_NAME);
|
var store = transaction.objectStore(METADATA_STORE_NAME);
|
||||||
var nameIndex = store.index(NAME_INDEX);
|
var nameIndex = store.index(NAME_INDEX);
|
||||||
|
@ -502,15 +488,12 @@ define(function(require) {
|
||||||
|
|
||||||
function rmdir(pathname, callback) {
|
function rmdir(pathname, callback) {
|
||||||
debug.info("rmdir -->");
|
debug.info("rmdir -->");
|
||||||
var onerror = genericIDBErrorHandler("rmdir", callback);
|
pathname = path.normalize(pathname);
|
||||||
if("/" === pathname) {
|
|
||||||
onerror(new IDBFSError(T_RMDIR, E_BUSY));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
transaction = db.transaction([METADATA_STORE_NAME, FILE_STORE_NAME], IDB_RW);
|
transaction = db.transaction([METADATA_STORE_NAME, FILE_STORE_NAME], IDB_RW);
|
||||||
var metaStore = transaction.objectStore(METADATA_STORE_NAME);
|
var metaStore = transaction.objectStore(METADATA_STORE_NAME);
|
||||||
var nameIndex = metaStore.index(NAME_INDEX);
|
var nameIndex = metaStore.index(NAME_INDEX);
|
||||||
var parentIndex = metaStore.index(PARENT_INDEX);
|
var parentIndex = metaStore.index(PARENT_INDEX);
|
||||||
|
var onerror = genericIDBErrorHandler("rmdir", callback);
|
||||||
|
|
||||||
var getRequest = nameIndex.get(pathname);
|
var getRequest = nameIndex.get(pathname);
|
||||||
getRequest.onsuccess = function(e) {
|
getRequest.onsuccess = function(e) {
|
||||||
|
@ -544,6 +527,7 @@ define(function(require) {
|
||||||
|
|
||||||
function stat(transaction, pathname, callback) {
|
function stat(transaction, pathname, callback) {
|
||||||
debug.info("stat -->");
|
debug.info("stat -->");
|
||||||
|
pathname = path.normalize(pathname);
|
||||||
transaction = transaction || db.transaction([METADATA_STORE_NAME], IDB_RO);
|
transaction = transaction || db.transaction([METADATA_STORE_NAME], IDB_RO);
|
||||||
var store = transaction.objectStore(METADATA_STORE_NAME);
|
var store = transaction.objectStore(METADATA_STORE_NAME);
|
||||||
var nameIndex = store.index(NAME_INDEX);
|
var nameIndex = store.index(NAME_INDEX);
|
||||||
|
@ -674,7 +658,8 @@ define(function(require) {
|
||||||
|
|
||||||
var IDBFS = {
|
var IDBFS = {
|
||||||
mount: mount,
|
mount: mount,
|
||||||
umount: undefined
|
umount: undefined,
|
||||||
|
path: path
|
||||||
};
|
};
|
||||||
|
|
||||||
return IDBFS;
|
return IDBFS;
|
||||||
|
|
|
@ -0,0 +1,122 @@
|
||||||
|
// Copyright Joyent, Inc. and other Node contributors.
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
// copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to permit
|
||||||
|
// persons to whom the Software is furnished to do so, subject to the
|
||||||
|
// following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included
|
||||||
|
// in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
||||||
|
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||||
|
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||||
|
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
// https://github.com/joyent/node/blob/41e53e557992a7d552a8e23de035f9463da25c99/lib/path.js
|
||||||
|
|
||||||
|
define(function(require) {
|
||||||
|
|
||||||
|
// Split a filename into [root, dir, basename, ext], unix version
|
||||||
|
// 'root' is just a slash, or nothing.
|
||||||
|
var splitPathRe =
|
||||||
|
/^(\/?)([\s\S]+\/(?!$)|\/)?((?:\.{1,2}$|[\s\S]+?)?(\.[^.\/]*)?)$/;
|
||||||
|
var splitPath = function(filename) {
|
||||||
|
var result = splitPathRe.exec(filename);
|
||||||
|
return [result[1] || '', result[2] || '', result[3] || '', result[4] || ''];
|
||||||
|
};
|
||||||
|
|
||||||
|
// resolves . and .. elements in a path array with directory names there
|
||||||
|
// must be no slashes, empty elements, or device names (c:\) in the array
|
||||||
|
// (so also no leading and trailing slashes - it does not distinguish
|
||||||
|
// relative and absolute paths)
|
||||||
|
function normalizeArray(parts, allowAboveRoot) {
|
||||||
|
// if the path tries to go above the root, `up` ends up > 0
|
||||||
|
var up = 0;
|
||||||
|
for (var i = parts.length - 1; i >= 0; i--) {
|
||||||
|
var last = parts[i];
|
||||||
|
if (last === '.') {
|
||||||
|
parts.splice(i, 1);
|
||||||
|
} else if (last === '..') {
|
||||||
|
parts.splice(i, 1);
|
||||||
|
up++;
|
||||||
|
} else if (up) {
|
||||||
|
parts.splice(i, 1);
|
||||||
|
up--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if the path is allowed to go above the root, restore leading ..s
|
||||||
|
if (allowAboveRoot) {
|
||||||
|
for (; up--; up) {
|
||||||
|
parts.unshift('..');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return parts;
|
||||||
|
}
|
||||||
|
|
||||||
|
// path.normalize(path)
|
||||||
|
// posix version
|
||||||
|
function normalize(path) {
|
||||||
|
var isAbsolute = path.charAt(0) === '/';
|
||||||
|
// var trailingSlash = path.substr(-1) === '/';
|
||||||
|
|
||||||
|
// Normalize the path
|
||||||
|
path = normalizeArray(path.split('/').filter(function(p) {
|
||||||
|
return !!p;
|
||||||
|
}), !isAbsolute).join('/');
|
||||||
|
|
||||||
|
if (!path && !isAbsolute) {
|
||||||
|
path = '.';
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
if (path && trailingSlash) {
|
||||||
|
path += '/';
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
return (isAbsolute ? '/' : '') + path;
|
||||||
|
};
|
||||||
|
|
||||||
|
function dirname(path) {
|
||||||
|
var result = splitPath(path),
|
||||||
|
root = result[0],
|
||||||
|
dir = result[1];
|
||||||
|
|
||||||
|
if (!root && !dir) {
|
||||||
|
// No dirname whatsoever
|
||||||
|
return '.';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dir) {
|
||||||
|
// It has a dirname, strip trailing slash
|
||||||
|
dir = dir.substr(0, dir.length - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return root + dir;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
function basename(path, ext) {
|
||||||
|
var f = splitPath(path)[2];
|
||||||
|
// TODO: make this comparison case-insensitive on windows?
|
||||||
|
if (ext && f.substr(-1 * ext.length) === ext) {
|
||||||
|
f = f.substr(0, f.length - ext.length);
|
||||||
|
}
|
||||||
|
return f;
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
normalize: normalize,
|
||||||
|
dirname: dirname,
|
||||||
|
basename: basename
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
Loading…
Reference in New Issue