[RFC]: add support for bookmarking directories in REPL
Description
This RFC proposes adding support in the REPL for bookmarking directories. Currently, in order to move around the file system, one needs to manually set the current working directory. This can be tedious, as one needs to manually type file paths, either relative or absolute, in order to walk to the desired directory.
This RFC proposes alleviating that tedium by adding support for "bookmarking" directories. E.g.,
In [1]: saveBookmark( 'home_dir', '/home/foo/bar/beep/boop' );
// ...
In [n]: loadBookmark( 'home_dir' );
We'd want to add a set of complementary APIs:
-
saveBookmark( name[, path ] ): path default is the current working directory -
loadBookmark( name ): set current working directory to the path associated withname -
deleteBookmark( name ): delete the bookmark associated withname -
renameBookmark( prev, name ): renames a bookmark specified byprevto the name specified byname -
isBookmark( [path] ): returns a boolean indicating if a specified path has been bookmarked (if no path provided, uses the current working directory as the path)
By default, bookmarks would only last for the REPL session. To support persisting benchmarks and loading previously persisted benchmarks, we could add the following APIs:
-
loadBookmarks( file ): loads bookmarks found in the file specified byfile -
saveBookmarks( file ): saves the current set of bookmarks to a file specified byfile -
clearBookmarks(): clears all current bookmarks in the current REPL session -
bookmarks(): list all bookmarks in the current REPL session
The ability to dynamically load and remove bookmarks would allow users to quickly switch development contexts, similar to how the REPL's concept of workspaces allows for moving being variable contexts.
Related Issues
No.
Questions
- Are there other APIs which would be useful for working with bookmarks?
Other
- It is worth ensuring that the APIs and conventions are consistent with how the REPL's concept of workspace APIs are designed (e.g., argument order, naming conventions, etc).
- We should ensure that, similar to workspaces, TAB completions support bookmark names.
Checklist
- [X] I have read and understood the Code of Conduct.
- [X] Searched for existing issues and pull requests.
- [X] The issue name begins with
RFC:.