Description
openedon Mar 27, 2024
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 directoryloadBookmark( name )
: set current working directory to the path associated withname
deleteBookmark( name )
: delete the bookmark associated withname
renameBookmark( prev, name )
: renames a bookmark specified byprev
to 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 sessionbookmarks()
: 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
- I have read and understood the Code of Conduct.
- Searched for existing issues and pull requests.
- The issue name begins with
RFC:
.