Add a helper script for launching the right project in vscode

This commit is contained in:
Jake Howard 2020-02-04 20:38:47 +00:00
parent b11e674cd9
commit ba21380ed2
Signed by: jake
GPG key ID: 57AFB45680EDD477
2 changed files with 49 additions and 0 deletions

48
files/bin/code-project-list Executable file
View file

@ -0,0 +1,48 @@
#!/usr/bin/env python
from pathlib import Path
import json
import itertools
import subprocess
from io import StringIO
VSCODE_CONFIG_FILE = Path.home().joinpath(".config/Code/storage.json")
SEARCH_DIRS = [
Path.home().joinpath("Projects"),
Path.home().joinpath("Repositories"),
]
def get_search_project_dirs():
for path in SEARCH_DIRS:
if not path.exists():
continue
for subdir in path.iterdir():
if subdir.is_dir():
yield subdir
def get_vscode_project_dirs():
vscode_config = json.loads(VSCODE_CONFIG_FILE.read_text())
for recent_path in itertools.chain(*vscode_config['openedPathsList'].values()):
recent_path_path = Path(recent_path.replace('file://', ''))
if recent_path_path.exists():
yield recent_path_path
def main():
project_paths = sorted(set(itertools.chain(get_search_project_dirs(), get_vscode_project_dirs())), key=lambda p: p.name.lower())
project_paths.remove(Path.home())
project_paths_display = [str(project.relative_to(Path.home())) for project in project_paths]
selected_project = subprocess.run(["rofi", "-dmenu", "-no-case-sensitive", "-format", "i"], input="\n".join(project_paths_display).encode(), stdout=subprocess.PIPE)
selected_project.check_returncode()
selected_index = int(selected_project.stdout.strip())
subprocess.run(['code', project_paths[selected_index]])
if __name__ == '__main__':
main()

View file

@ -41,6 +41,7 @@ bindsym Control+Q exec --no-startup-id /bin/false
bindsym $mod+Shift+Delete exec --no-startup-id rofi-powermenu
bindcode 124 exec --no-startup-id rofi-powermenu
bindsym $mod+P exec --no-startup-id rofi-screenlayout
bindsym $mod+Shift+c exec --no-startup-id code-project-list
# Screenshots