Skip to content

Terminal based utility tool to navigate between local repositories

License

Notifications You must be signed in to change notification settings

Illedan/OpenRepo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

45 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenRepo

Terminal based utility tool to navigate between local repositories. Blog about it: https://kvanli.com/stories/openrepo

badge

Nuget

Installation

  • Run dotnet tool install --global Illedan.OpenRepo
  • Use the command openrepo
  • Press Enter to edit config for your needs. For example add:
Local:
    /Users/username/Projects/
  • Save and go back to the terminal to continue usage.

Run from project

  • Clone
  • cd into src
  • Run dotnet publish
  • cd into OpenRepo/bin/Debug/netcoreapp2.1/publish/
  • dotnet run OpenRepo.dll

Usages

Write anything to filter your list of choices (only availiable at the start screen). Use arrows up/down to find your wanted choice, then press enter.

You will then get a list of possible actions, which is given by the provider returning this choice, use arrows to select and enter to use this action on the current choice. See Providers futher down.

Configuration.yaml

Example:

# Welcome to OpenRepo
# Created by https://github.com/Illedan 
# Add this path. Where C:/Repos/ is replaced with your repo location
Local:
    C:/Repos/ pt:sln pt:bat

Personal:
    nuget https://www.nuget.org
Paths with spaces are only supported if you wrap the whole path in quotes!

Providers

Local

Example:

Local:
    C:/repos prefix:repos/ pt:sln ptt:md
    /Users/Illedan/Projects/ prefix:projects/

Finds all folders inside a folder.

Possible Parameters:

  • prefix:customname Applies customname in front of all folder from this source. Needed if you have many equal names. (Recommended to add a divider like / at the end)
  • pt:programtype Adds Actions to start extensions of programtype. Example is pt:sln which finds all solutions inside the repo. Logs if there is none, starts the first if one and gives a list to select if there are multiple.
  • ptt:programtype Adds Actions to start extensions of programtype. Example is ptt:md which finds all solutions inside the repo on the root level. Logs if there is none, starts the first if one and gives a list to select if there are multiple.

Actions:

  • Open Opens the folder in explorer/finder
  • Terminal Opens the terminal at the target location
  • Web Opens a browser to the remote location of the repository. Only shows if this is a git repository.

Personal

Here you can add a key + a value to link to. As the example here:

Personal:
    nuget https://www.nuget.org
    cool_user https://www.github.com/Illedan

Nuget would send the user to nuget.org and cool_user to Illedan's github profile. This could also be folders in your file system, script, whatever you like :)

Settings

Setup configuration for open repo. For now the only possible action is to ignore folders when finding files of certain types. An example is to ignore node_modules as it is a very big folder.

Settings:
    ignore bin
    ignore node_modules

Clipboard

Copies the last phrase of the text to your clipboard.

Clipboard:
    DIS_ID 12345

Running on Windows with AutoHotkey

One approach to working with openrepo on a windows machine is to use an AutoHotkey script to fire it and if it is already running, just bring it in to view.

First, you will need to install AutoHotkey https://www.autohotkey.com/.

Go to your desktop and right click, new, AutoHotkey Script.

F1::
IfWinExist C:\Users\<USER>\.dotnet\tools\OpenRepo.exe
{
  WinActivate, C:\Users\<USER>\.dotnet\tools\OpenRepo.exe
}
else
{
    run, OpenRepo
    WinActivate, C:\Users\<USER>I\.dotnet\tools\OpenRepo.exe
}

This script will trigger when the F1 key is pressed

Finally run the AutoHotkey script by double clicking it.

Openrepo should now come in to view when pressing F1

Contribute

Anything, anywhere, anyhow, anytime. Just do it! ❤️

Thanks

Thanks to Simon for Mac OS terminal assistance.

About

Terminal based utility tool to navigate between local repositories

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages