sublime: refactor plugin and fix documentation (#7715)

* convert to 2-space indentation
* standardize sublime function name (subl)
* simplify subl function definition into a single loop
* convert functions into aliases
* simplify alias creation
* search for Sublime Text command only if not found
* reorganize and clean up plugin
* fix README
* simplify cygwin path lookup
* support path lookup for msys (Windows)
* support path lookup for WSL (Windows)
* fix for spaces in sublime path alias
pull/7771/head
Marc Cornellà 2019-04-15 16:55:18 +02:00 committed by GitHub
parent 4b9c4e973e
commit fc9e427ef9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 113 additions and 104 deletions

View File

@ -1,25 +1,37 @@
## sublime # sublime
Plugin for Sublime Text, a cross platform text and code editor, available for Linux, Mac OS X, and Windows. Plugin for [Sublime Text](https://www.sublimetext.com/), a cross platform text and code editor,
available for Linux, macOS, and Windows.
### Requirements To use the plugin, add `sublime` to the plugins array of your zshrc file:
* [Sublime Text](https://www.sublimetext.com/) ```zsh
plugins=(... sublime)
```
### Usage Sublime Text has to be installed to use the plugin.
* If `st` command is called without an argument, launch Sublime Text ## Usage
* If `st` is passed a directory, `cd` to it and open it in Sublime Text The plugin defines several aliases, such as:
* If `st` is passed a file, open it in Sublime Text - `st`: opens Sublime Text. If passed a file or directory, Sublime Text will open it.
* If `stt` command is called, it is equivalent to `st .`, opening the current folder in Sublime Text - `stt`: open Sublime Text on the current directory.
* If `sst` command is called, it is like `sudo st`, opening the file or folder in Sublime Text. Useful for editing system protected files. - `sst`: if `sudo` is available, `sst` will open Sublime Text with root permissions, so that
you can modify any file or directory that you pass it. Useful to edit system files.
* If `stp` command is called, it find a `.sublime-project` file by traversing up the directory structure. If there is no `.sublime-project` file, but if the current folder is a Git repo, opens up the root directory of the repo. If the current folder is not a Git repo, then opens up the current directory. There are also a few functions available:
* If `stn` command is called without an argument, create a stub `.sublime-project` file in the current working directory if one does not already exist - `find_project` (or `stp` alias): if called, the function will search for a `.sublime-project` file
on the current directory or its parents, until it finds none.
* If `stn` is passed a directory, create a stub `.sublime-project` file in it If there is no `.sublime-project` file but the current folder is in a Git repository, it will open
Sublime Text on the root directory of the repository.
If there is no Git repository, it will then open Sublime Text on the current directory.
- `create_project` (or `stn` alias): if called without an argument, create a stub `.sublime-project`
file in the current working directory, if one does not already exist. If passed a directory, create
a stub `.sublime-project` file in it.

View File

@ -1,31 +1,38 @@
# Sublime Text Aliases # Sublime Text aliases
() { alias st=subl
alias stt='subl .'
# Define sst only if sudo exists
(( $+commands[sudo] )) && alias sst='sudo subl'
alias stp=find_project
alias stn=create_project
# Search for the Sublime Text command if not found
(( $+commands[subl] )) || {
declare -a _sublime_paths
if [[ "$OSTYPE" == linux* ]]; then if [[ "$OSTYPE" == linux* ]]; then
local _sublime_linux_paths if [[ "$(uname -r)" = *Microsoft* ]]; then
_sublime_linux_paths=( _sublime_paths=(
"$(wslpath -u 'C:\Program Files\Sublime Text 3\subl.exe')"
"$(wslpath -u 'C:\Program Files\Sublime Text 2\subl.exe')"
)
else
_sublime_paths=(
"$HOME/bin/sublime_text" "$HOME/bin/sublime_text"
"/opt/sublime_text/sublime_text" "/opt/sublime_text/sublime_text"
"/opt/sublime_text_3/sublime_text" "/opt/sublime_text_3/sublime_text"
"/usr/bin/sublime_text" "/usr/bin/sublime_text"
"/usr/local/bin/sublime_text" "/usr/local/bin/sublime_text"
"/usr/bin/subl" "/usr/bin/subl"
"/opt/sublime_text_3/sublime_text"
"/usr/bin/subl3" "/usr/bin/subl3"
) )
for _sublime_path in $_sublime_linux_paths; do
if [[ -a $_sublime_path ]]; then
st_run() { $_sublime_path $@ >/dev/null 2>&1 &| }
st_run_sudo() {sudo $_sublime_path $@ >/dev/null 2>&1}
alias sst=st_run_sudo
alias st=st_run
break
fi fi
done
elif [[ "$OSTYPE" = darwin* ]]; then elif [[ "$OSTYPE" = darwin* ]]; then
local _sublime_darwin_paths _sublime_paths=(
_sublime_darwin_paths=(
"/usr/local/bin/subl" "/usr/local/bin/subl"
"/Applications/Sublime Text.app/Contents/SharedSupport/bin/subl" "/Applications/Sublime Text.app/Contents/SharedSupport/bin/subl"
"/Applications/Sublime Text 3.app/Contents/SharedSupport/bin/subl" "/Applications/Sublime Text 3.app/Contents/SharedSupport/bin/subl"
@ -34,34 +41,30 @@ elif [[ "$OSTYPE" = darwin* ]]; then
"$HOME/Applications/Sublime Text 3.app/Contents/SharedSupport/bin/subl" "$HOME/Applications/Sublime Text 3.app/Contents/SharedSupport/bin/subl"
"$HOME/Applications/Sublime Text 2.app/Contents/SharedSupport/bin/subl" "$HOME/Applications/Sublime Text 2.app/Contents/SharedSupport/bin/subl"
) )
for _sublime_path in $_sublime_darwin_paths; do elif [[ "$OSTYPE" = cygwin ]]; then
if [[ -a $_sublime_path ]]; then _sublime_paths=(
subl () { "$_sublime_path" $* } "$(cygpath "$ProgramW6432/Sublime Text 2")/subl.exe"
alias st=subl "$(cygpath "$ProgramW6432/Sublime Text 3")/subl.exe"
break )
fi elif [[ "$OSTYPE" = msys ]]; then
done _sublime_paths=(
elif [[ "$OSTYPE" = 'cygwin' ]]; then "/c/Program Files/Sublime Text 2/subl.exe"
local _sublime_cygwin_paths "/c/Program Files/Sublime Text 3/subl.exe"
_sublime_cygwin_paths=(
"$(cygpath $ProgramW6432/Sublime\ Text\ 2)/sublime_text.exe"
"$(cygpath $ProgramW6432/Sublime\ Text\ 3)/sublime_text.exe"
) )
for _sublime_path in $_sublime_cygwin_paths; do
if [[ -a $_sublime_path ]]; then
subl () { "$_sublime_path" $* }
alias st=subl
break
fi
done
fi fi
for _sublime_path in $_sublime_paths; do
if [[ -a $_sublime_path ]]; then
alias subl="'$_sublime_path'"
(( $+commands[sudo] )) && alias sst="sudo '$_sublime_path'"
break
fi
done
unset _sublime_paths _sublime_path
} }
alias stt='st .' function find_project() {
find_project()
{
local PROJECT_ROOT="${PWD}" local PROJECT_ROOT="${PWD}"
local FINAL_DEST="." local FINAL_DEST="."
@ -84,11 +87,10 @@ find_project()
fi fi
fi fi
st $FINAL_DEST subl $FINAL_DEST
} }
function create_project() { function create_project() {
local _target=$1 local _target=$1
if [[ "${_target}" == "" ]]; then if [[ "${_target}" == "" ]]; then
@ -101,7 +103,6 @@ function create_project() {
local _sublime_project_file=$_target/$(basename $_target).sublime-project local _sublime_project_file=$_target/$(basename $_target).sublime-project
if [[ ! -f $_sublime_project_file ]]; then if [[ ! -f $_sublime_project_file ]]; then
touch $_sublime_project_file touch $_sublime_project_file
echo -e "{" >> $_sublime_project_file echo -e "{" >> $_sublime_project_file
@ -113,9 +114,5 @@ function create_project() {
echo -e "}" >> $_sublime_project_file echo -e "}" >> $_sublime_project_file
echo -e "New Sublime Text project created:\n\t${_sublime_project_file}" echo -e "New Sublime Text project created:\n\t${_sublime_project_file}"
fi fi
} }
alias stp=find_project
alias stn=create_project