forked from adobe/brackets
-
Notifications
You must be signed in to change notification settings - Fork 279
File System API Migration
Peter Flynn edited this page Oct 25, 2013
·
30 revisions
Here are the API changes that will result from the [File System Evolution](File System) plan:
Old API | New API | Suggested action | Usage |
FileEntry DirectoryEntry |
File Directory |
These objects are drop-in compatible (same fields), so unless you reference them by name nothing will break | (lots) |
FileUtils.readAsText(fileEntry) | FileUtils.readAsText(file) | Drop-in compatible | 13 |
FileUtils.writeText(fileEntry) | FileUtils.writeText(file) | Drop-in compatible | 5 |
FileIndexManager.getFileInfoList("all") FileIndexManager.getFileInfoList("...") |
ProjectManager.getAllFiles() ProjectManager.getAllFiles(filter) _Note: returns an array of actual Files, but they provide the same properties as the old FileInfos)_ |
Shim with deprecation warning | 7 |
FileIndexManager.getFilenameMatches("...", filename) | ProjectManager.getAllFiles(filter) | Shim with deprecation warning | None |
new NativeFileSystem.FileEntry(fullPath) new NativeFileSystem.DirectoryEntry(fullPath) |
filesystem.getFileForPath(fullPath) filesystem.getDirectoryForPath(fullPath) |
Shim with deprecation warning | 19 |
DirectoryEntry.getFile(relpath) | filesystem.resolve(dirFullPath + relpath) | TODO: Consider offering same/similar API on Directory | 4 |
NativeFileSystem.resolveNativeFileSystemPath(fullPath) | filesystem.resolve(path) | Shim with deprecation warning | 4 |
NativeFileSystem.requestNativeFileSystem(fullPath)... fs.root | filesystem.resolve(fullPath) | Shim with deprecation warning | 6 |
entry.fullPath, entry.isFile, entry.isDirectory | (unchanged) | Properties are now immutable | fullPath: many isFile/Directory: 9 |
Concatenation: folderPath + "/" + filename | (unchanged) | Paths are normalized on ingest, eliminating doubled "/"es | |
Concatenation: folderPath + filename | (unchanged) | Directory.fullPath will always end in "/", so this remains safe | Unclear, but at least several |
Substrings: relpath = fullPath.slice(dirFullPath.length) | (unchanged) | Directory.fullPath will always end in "/", so this remains safe | |
NativeFileSystem.isRelativePath() | ??? | ??? | None |
NativeFileSystem.showOpenDialog() NativeFileSystem.showSaveDialog() |
filesystem.showOpenDialog() filesystem.showSaveDialog() |
Shim with deprecation warning | 4 |
fileEntry.getMetadata() | file.stat() _TODO: document change in data structure too_ |
Do not shim (callers will break right away) | 1 |
fileEntry.createWriter()... writer.write(text) | file.write(text) | Do not shim (callers will break right away) | 5, but only used in 2 |
fileEntry.file()... new NativeFileSystem.FileReader().readAsText(fileObj) | file.readAsText() | Do not shim (callers will break right away) | None |
directoryEntry.createReader().readEntries() | directory.getContents() ??? | Do not shim (callers will break right away) | 5 |
DirectoryEntry.getFile(relpath, {create:true}) | filesystem.getFileForPath(fullPath).write("") Note: as a result, this can fold in writeText() or createWriter()/write() calls that used to immediately follow the getFile() call. |
Do not shim (callers will break right away) TODO: add a cleaner create() API? |
2 |
DirectoryEntry.getDirectory(relpath, {create:true}) | filesystem.getDirectoryForPath(fullPath).create() | Do not shim (callers will break right away) | 2 |
instanceof NativeFileSystem.InaccessibleFileEntry | instanceof InMemoryFile | Do not shim (callers will break right away) | 1 |
entry.remove() | entry.moveToTrash() | Do not shim (callers will break right away) | None |
NativeFileError.* | ??? | Do not shim (callers will break right away) | 1 |
entry.filesystem (not a very useful API) |
n/a | Do not shim (callers will break right away) | None |
NativeFileSystem.Encodings.* | ??? | Do not shim (callers will break right away) | None |
ProjectManager "projectFilesChange" event | FileSystem "change" event | Do not shim | 2 |
brackets.fs.readFile() brackets.fs.writeFile() |
file.readAsText() file.write(text) |
Low-level API continues to exist | 2 |
brackets.fs.stat() | file.stat() | Low-level API continues to exist | 1 |
brackets.fs.readdir() | directory.getContents() ??? | Low-level API continues to exist | 1 |
brackets.fs.makedir(fullPath, mode) | filesystem.getDirectoryForPath(fullPath).create() | Low-level API continues to exist | 1 |
brackets.fs.unlink(fullPath) | entry.unlink() | Low-level API continues to exist | None |
brackets.fs.rename(oldFullPath, newFullPath) | entry.rename(newFullPath) (NOTE: Exact semantics of this call are still a bit TBD). |
Low-level API continues to exist | None |
brackets.fs.moveToTrash() | entry.moveToTrash() | Low-level API continues to exist | None |
brackets.fs.copyFile() | ??? | Low-level API continues to exist | 1 |
brackets.fs.isNetworkDrive() | ??? | Low-level API continues to exist TODO: will it be unused now though? |
None |
brackets.fs.chmod() | ??? | Low-level API continues to exist | None |
brackets.fs.showOpenDialog() brackets.fs.showSaveDialog() |
filesystem.showOpenDialog() filesystem.showSaveDialog() |
Low-level API continues to exist | None |
new NativeFileSystem.InaccessibleFileEntry(fakePath) | filesystem.getInMemoryFile(fakePath) | Low-level API continues to exist | None |
brackets.fs.ERR_* brackets.fs.PATH_EXISTS_ERR brackets.fs.NO_ERROR |
??? | Low-level API continues to exist | 1 |
"Usage" = how many extensions currently use the API
The following 14 extensions use at least one API on the "Do not shim" list:
- themes -- (DirectoryEntry.createReader())
- themesforbrackets -- (DirectoryEntry.createReader())
- interactive-linter -- (DirectoryEntry.getFile(), DirectoryEntry.createReader(), FileEntry.createWriter(), NativeFileError (only minor bug))
- angularui.angularjs -- (FileEntry.getMetadata())
- timburgess.pagesuck -- (DirectoryEntry.getFile())
- ternific -- (DirectoryEntry.getFile(), DirectoryEntry.createReader(), FileEntry.createWriter())
- tomcat-manager -- (DirectoryEntry.getFile(), FileEntry.createWriter())
- simple-js-code-hints -- (DirectoryEntry.createReader())
- bsirlinger.github-access -- (DirectoryEntry.getFile({create}), DirectoryEntry.getDirectory({create}), FileEntry.createWriter())
- xunit -- (DirectoryEntry.getFile({create}), DirectoryEntry.getDirectory({create})
- workspaces -- (FileEntry.createWriter())
- zaggino.brackets-git -- (won't crash, notable bug) ("projectFilesChange" event)
- variousimprovements -- (won't crash, minor bug) ("projectFilesChange" event)
- pflynn.brackets.editor.nav -- (won't crash, very minor bug) (InaccessibleFileEntry)
We will file bugs with all extensions that are using removed APIs to make sure authors are aware of the change.