Robby Russell
14 years ago
40 changed files with 1031 additions and 75 deletions
@ -1,21 +1,29 @@
@@ -1,21 +1,29 @@
|
||||
case "$TERM" in |
||||
xterm*|rxvt*) |
||||
preexec () { |
||||
print -Pn "\e]0;%n@%m: $1\a" # xterm |
||||
} |
||||
precmd () { |
||||
print -Pn "\e]0;%n@%m: %~\a" # xterm |
||||
} |
||||
;; |
||||
screen*) |
||||
preexec () { |
||||
local CMD=${1[(wr)^(*=*|sudo|ssh|-*)]} |
||||
echo -ne "\ek$CMD\e\\" |
||||
print -Pn "\e]0;%n@%m: $1\a" # xterm |
||||
} |
||||
precmd () { |
||||
echo -ne "\ekzsh\e\\" |
||||
print -Pn "\e]0;%n@%m: %~\a" # xterm |
||||
} |
||||
;; |
||||
esac |
||||
#usage: title short_tab_title looooooooooooooooooooooggggggg_windows_title |
||||
#http://www.faqs.org/docs/Linux-mini/Xterm-Title.html#ss3.1 |
||||
#Fully support screen, iterm, and probably most modern xterm and rxvt |
||||
#Limited support for Apple Terminal (Terminal can't set window or tab separately) |
||||
function title { |
||||
[ "$DISABLE_AUTO_TITLE" != "true" ] || return |
||||
if [[ $TERM =~ "^screen" ]]; then |
||||
print -Pn "\ek$1:q\e\\" #set screen hardstatus, usually truncated at 20 chars |
||||
elif [[ ($TERM =~ "^xterm") ]] || [[ ($TERM == "rxvt") ]] || [[ "$TERM_PROGRAM" == "iTerm.app" ]]; then |
||||
print -Pn "\e]2;$2:q\a" #set window name |
||||
print -Pn "\e]1;$1:q\a" #set icon (=tab) name (will override window name on broken terminal) |
||||
fi |
||||
} |
||||
|
||||
ZSH_THEME_TERM_TAB_TITLE_IDLE="%15<..<%~%<<" #15 char left truncated PWD |
||||
ZSH_THEME_TERM_TITLE_IDLE="%n@%m: %~" |
||||
|
||||
#Appears when you have the prompt |
||||
function precmd { |
||||
title $ZSH_THEME_TERM_TAB_TITLE_IDLE $ZSH_THEME_TERM_TITLE_IDLE |
||||
} |
||||
|
||||
#Appears at the beginning of (and during) of command execution |
||||
function preexec { |
||||
emulate -L zsh |
||||
setopt extended_glob |
||||
local CMD=${1[(wr)^(*=*|sudo|ssh|-*)]} #cmd name only, or if this is sudo or ssh, the next cmd |
||||
title "$CMD" "%100>...>$2%<<" |
||||
} |
||||
|
@ -0,0 +1,3 @@
@@ -0,0 +1,3 @@
|
||||
alias be="bundle exec" |
||||
alias bi="bundle install" |
||||
alias bu="bundle update" |
@ -0,0 +1,67 @@
@@ -0,0 +1,67 @@
|
||||
#compdef cpanm |
||||
|
||||
## |
||||
# cpanminus Z Shell completion script |
||||
## |
||||
# |
||||
# Current supported cpanm version: 1.4000 (Tue Mar 8 01:00:49 PST 2011) |
||||
# |
||||
# The latest code is always located at: |
||||
# https://github.com/rshhh/cpanminus/blob/master/etc/_cpanm |
||||
# |
||||
|
||||
local arguments curcontext="$curcontext" |
||||
typeset -A opt_args |
||||
|
||||
|
||||
arguments=( |
||||
|
||||
# Commands |
||||
# '(--install -i)'{--install,-i}'[Installs the modules]' |
||||
'(- :)--self-upgrade[Upgrades itself]' |
||||
'(- :)--info[Displays distribution info on CPAN]' |
||||
'(--installdeps)--installdeps[Only install dependencies]' |
||||
'(--look)--look[Download/unpack the distribution and then open the directory with your shell]' |
||||
'(- :)'{--help,-h}'[Displays help information]' |
||||
'(- :)'{--version,-V}'[Displays software version]' |
||||
|
||||
# Options |
||||
{--force,-f}'[Force install]' |
||||
{--notest,-n}'[Do not run unit tests]' |
||||
{--sudo,-S}'[sudo to run install commands]' |
||||
'(-v --verbose --quiet -q)'{--verbose,-v}'[Turns on chatty output]' |
||||
'(-q --quiet --verbose -v)'{--quiet,-q}'[Turns off all output]' |
||||
{--local-lib,-l}'[Specify the install base to install modules]' |
||||
{--local-lib-contained,-L}'[Specify the install base to install all non-core modules]' |
||||
'--mirror[Specify the base URL for the mirror (e.g. http://cpan.cpantesters.org/)]:URLs:_urls' |
||||
'--mirror-only[Use the mirror\''s index file instead of the CPAN Meta DB]' |
||||
'--prompt[Prompt when configure/build/test fails]' |
||||
'--reinstall[Reinstall the distribution even if you already have the latest version installed]' |
||||
'--interactive[Turn on interactive configure]' |
||||
|
||||
'--scandeps[Scan the depencencies of given modules and output the tree in a text format]' |
||||
'--format[Specify what format to display the scanned dependency tree]:scandeps format:(tree json yaml dists)' |
||||
|
||||
'--save-dists[Specify the optional directory path to copy downloaded tarballs]' |
||||
# '--uninst-shadows[Uninstalls the shadow files of the distribution that you\''re installing]' |
||||
|
||||
'--auto-cleanup[Number of days that cpanm\''s work directories expire in. Defaults to 7]' |
||||
'(--no-man-pages)--man-pages[Generates man pages for executables (man1) and libraries (man3)]' |
||||
'(--man-pages)--no-man-pages[Do not generate man pages]' |
||||
|
||||
|
||||
# Note: Normally with "--lwp", "--wget" and "--curl" options set to true (which is the default) cpanm tries LWP, |
||||
# Wget, cURL and HTTP::Tiny (in that order) and uses the first one available. |
||||
# (So that the exclusions are not enabled here for the completion) |
||||
'(--lwp)--lwp[Use LWP module to download stuff]' |
||||
'(--wget)--wget[Use GNU Wget (if available) to download stuff]' |
||||
'(--curl)--curl[Use cURL (if available) to download stuff]' |
||||
|
||||
# Other completions |
||||
'*:Local directory or archive:_files -/ -g "*.(tar.gz|tgz|tar.bz2|zip)(-.)"' |
||||
# '*::args: _normal' # this looks for default files (any files) |
||||
) |
||||
_arguments -s $arguments \ |
||||
&& return 0 |
||||
|
||||
return 1 |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
# add cpanm completion function to path |
||||
fpath=($ZSH/plugins/cpanm $fpath) |
||||
autoload -U compinit |
||||
compinit -i |
@ -0,0 +1,12 @@
@@ -0,0 +1,12 @@
|
||||
# Aliases |
||||
alias as="aptitude -F \"* %p -> %d \n(%v/%V)\" \ |
||||
--no-gui --disable-columns search" # search package |
||||
alias ad="sudo apt-get update" # update packages lists |
||||
alias au="sudo apt-get update && \ |
||||
sudo apt-get dselect-upgrade" # upgrade packages |
||||
alias ai="sudo apt-get install" # install package |
||||
alias ar="sudo apt-get remove --purge && \ |
||||
sudo apt-get autoremove --purge" # remove package |
||||
alias ap="apt-cache policy" # apt policy |
||||
alias av="apt-cache show" # show package info |
||||
alias ac="sudo apt-get clean && sudo apt-get autoclean" # clean apt cache |
@ -0,0 +1,60 @@
@@ -0,0 +1,60 @@
|
||||
# https://github.com/dbbolton/ |
||||
# |
||||
# Debian-related zsh aliases and functions for zsh |
||||
|
||||
|
||||
# Aliases ################################################################### |
||||
|
||||
# Some self-explanatory aliases |
||||
alias afs='apt-file search --regexp' |
||||
alias aps='aptitude search' |
||||
alias apsrc='apt-get source' |
||||
alias apv='apt-cache policy' |
||||
|
||||
alias apdg='su -c "aptitude update && aptitude safe-upgrade"' |
||||
alias apud='su -c "aptitude update"' |
||||
alias apug='su -c "aptitude safe-upgrade"' |
||||
|
||||
# print all installed packages |
||||
alias allpkgs='aptitude search -F "%p" --disable-columns ~i' |
||||
|
||||
# Install all .deb files in the current directory. |
||||
# Warning: you will need to put the glob in single quotes if you use: |
||||
# glob_subst |
||||
alias di='su -c "dpkg -i ./*.deb"' |
||||
|
||||
# Create a basic .deb package |
||||
alias mydeb='time dpkg-buildpackage -rfakeroot -us -uc' |
||||
|
||||
# Remove ALL kernel images and headers EXCEPT the one in use |
||||
alias kclean='su -c '\''aptitude remove -P ?and(~i~nlinux-(ima|hea) ?not(~n`uname -r`))'\'' root' |
||||
|
||||
|
||||
|
||||
# Functions ################################################################# |
||||
|
||||
# create a simple script that can be used to 'duplicate' a system |
||||
apt-copy() { |
||||
print '#!/bin/sh'"\n" > apt-copy.sh |
||||
|
||||
list=$(perl -m'AptPkg::Cache' -e '$c=AptPkg::Cache->new; for (keys %$c){ push @a, $_ if $c->{$_}->{'CurrentState'} eq 'Installed';} print "$_ " for sort @a;') |
||||
|
||||
print 'aptitude install '"$list\n" >> apt-copy.sh |
||||
|
||||
chmod +x apt-copy.sh |
||||
} |
||||
|
||||
|
||||
# Kernel-package building shortcut |
||||
dbb-build () { |
||||
MAKEFLAGS='' # temporarily unset MAKEFLAGS ( '-j3' will fail ) |
||||
appendage='-custom' # this shows up in $ (uname -r ) |
||||
revision=$(date +"%Y%m%d") # this shows up in the .deb file name |
||||
|
||||
make-kpkg clean |
||||
|
||||
time fakeroot make-kpkg --append-to-version "$appendage" --revision \ |
||||
"$revision" kernel_image kernel_headers |
||||
} |
||||
|
||||
|
@ -0,0 +1,26 @@
@@ -0,0 +1,26 @@
|
||||
# LOL!!1 |
||||
# Source: http://aur.archlinux.org/packages/lolbash/lolbash/lolbash.sh |
||||
|
||||
alias wtf='dmesg' |
||||
alias onoz='cat /var/log/errors.log' |
||||
alias rtfm='man' |
||||
|
||||
alias visible='echo' |
||||
alias invisible='cat' |
||||
alias moar='more' |
||||
|
||||
alias icanhas='mkdir' |
||||
alias donotwant='rm' |
||||
alias dowant='cp' |
||||
alias gtfo='mv' |
||||
|
||||
alias hai='cd' |
||||
alias plz='pwd' |
||||
|
||||
alias inur='locate' |
||||
|
||||
alias nomz='ps -aux' |
||||
alias nomnom='killall' |
||||
|
||||
alias cya='reboot' |
||||
alias kthxbai='halt' |
@ -0,0 +1,89 @@
@@ -0,0 +1,89 @@
|
||||
#compdef port |
||||
|
||||
local subcmds |
||||
|
||||
# we cache the list of ports |
||||
# we shall use some cache policy to avoid problems with new ports |
||||
if (( ! $+portlist )); then |
||||
portlist=($(port echo all; echo "all current active inactive installed uninstalled outdated")) |
||||
fi |
||||
|
||||
subcmds=( |
||||
'activate' |
||||
'archive' |
||||
'build' |
||||
'cat' |
||||
'clean' |
||||
'configure' |
||||
'contents' |
||||
'deactivate' |
||||
'dependents' |
||||
'deps' |
||||
'destroot' |
||||
'dir' |
||||
'distcheck' |
||||
'distclean' |
||||
'dmg' |
||||
'echo' |
||||
'edit' |
||||
'extract' |
||||
'fetch' |
||||
'file' |
||||
'help' |
||||
'info' |
||||
'install' |
||||
'installed' |
||||
'list' |
||||
'livecheck' |
||||
'location' |
||||
'mpkg' |
||||
'outdated' |
||||
'patch' |
||||
'pkg' |
||||
'provides' |
||||
'rpmpackage' |
||||
'search' |
||||
'selfupdate' |
||||
'sync' |
||||
'test' |
||||
'unarchive' |
||||
'uninstall' |
||||
'upgrade' |
||||
'variants' |
||||
'version' |
||||
) |
||||
|
||||
_arguments -C \ |
||||
'-v[verbose mode (generate verbose messages)]' \ |
||||
'-d[debug mode (generate debugging messages)]' \ |
||||
'-q[quiet mode (suppress messages)]' \ |
||||
'-D[specify portdir]' \ |
||||
'-k[keep mode (do not autoclean after install)]' \ |
||||
'-n[dont follow dependencies in upgrade (only for upgrading)]' \ |
||||
'-a[upgrade all installed ports (only for upgrading)]' \ |
||||
'-u[uninstall non-active ports when upgrading and uninstalling]' \ |
||||
'-f[force mode (ignore state file)]' \ |
||||
'-s[source-only mode]' \ |
||||
'-b[binary-only mode]' \ |
||||
'-o[honor state files older than Portfile]' \ |
||||
'*::command:->command' \ |
||||
&& return 0 |
||||
|
||||
case $state in |
||||
command) |
||||
if ((CURRENT == 1)); then |
||||
state=subcommands |
||||
else |
||||
state=portname |
||||
fi |
||||
;; |
||||
esac |
||||
|
||||
case $state in |
||||
subcommands) |
||||
_describe -t commands 'port commands' subcmds |
||||
;; |
||||
portname) |
||||
_describe -t commands 'available ports' portlist |
||||
;; |
||||
esac |
@ -0,0 +1,8 @@
@@ -0,0 +1,8 @@
|
||||
# commands to control local mysql-server installation |
||||
# paths are for osx installation via macports |
||||
|
||||
alias mysqlstart='sudo /opt/local/share/mysql5/mysql/mysql.server start' |
||||
alias mysqlstop='sudo /opt/local/share/mysql5/mysql/mysql.server stop' |
||||
alias mysqlrestart='sudo /opt/local/share/mysql5/mysql/mysql.server restart' |
||||
|
||||
alias mysqlstatus='mysqladmin5 -u root -p ping' |
@ -1,6 +0,0 @@
@@ -1,6 +0,0 @@
|
||||
# commands to control local mysql-server installation |
||||
# paths are for osx installtion via macports |
||||
|
||||
alias mysqlstart='sudo /opt/local/bin/mysqld_safe5' |
||||
alias mysqlstop='/opt/local/bin/mysqladmin5 -u root -p shutdown' |
||||
alias mysqlstatus='mysqladmin5 -u root -p ping' |
@ -0,0 +1,19 @@
@@ -0,0 +1,19 @@
|
||||
#compdef npm |
||||
|
||||
# Node Package Manager 0.3.15 completion, letting npm do all the completion work |
||||
|
||||
_npm() { |
||||
compadd -- $(_npm_complete $words) |
||||
} |
||||
|
||||
# We want to show all errors of any substance, but never the "npm (not )ok" one. |
||||
# (Also doesn't consider "ERR! no match found" worth breaking the terminal for.) |
||||
_npm_complete() { |
||||
local ask_npm |
||||
ask_npm=(npm completion --color false --loglevel error -- $@) |
||||
{ _call_program npm $ask_npm 2>&1 >&3 \ |
||||
| egrep -v '^(npm (not |)ok|ERR! no match found)$' >&2; \ |
||||
} 3>&1 |
||||
} |
||||
|
||||
_npm "$@" |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
# add npm completion function to path |
||||
fpath=($ZSH/plugins/npm $fpath) |
||||
autoload -U compinit |
||||
compinit -i |
@ -1,11 +1,57 @@
@@ -1,11 +1,57 @@
|
||||
function savepath() { |
||||
pwd > ~/.current_path~ |
||||
} |
||||
|
||||
function tab() { |
||||
osascript 2>/dev/null <<EOF |
||||
savepath |
||||
osascript >/dev/null <<EOF |
||||
on do_submenu(app_name, menu_name, menu_item, submenu_item) |
||||
-- bring the target application to the front |
||||
tell application app_name |
||||
activate |
||||
end tell |
||||
tell application "System Events" |
||||
tell process "Terminal" to keystroke "t" using command down |
||||
end |
||||
tell application "Terminal" |
||||
tell process app_name |
||||
tell menu bar 1 |
||||
tell menu bar item menu_name |
||||
tell menu menu_name |
||||
tell menu item menu_item |
||||
tell menu menu_item |
||||
click menu item submenu_item |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end do_submenu |
||||
|
||||
do_submenu("Terminal", "Shell", "New Tab", 1) |
||||
EOF |
||||
} |
||||
|
||||
function itab() { |
||||
savepath |
||||
osascript >/dev/null <<EOF |
||||
on do_submenu(app_name, menu_name, menu_item) |
||||
-- bring the target application to the front |
||||
tell application app_name |
||||
activate |
||||
do script with command "cd \"$PWD\"; $*" in window 1 |
||||
end tell |
||||
tell application "System Events" |
||||
tell process app_name |
||||
tell menu bar 1 |
||||
tell menu bar item menu_name |
||||
tell menu menu_name |
||||
click menu item menu_item |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end tell |
||||
end do_submenu |
||||
|
||||
do_submenu("iTerm", "Shell", "New Tab") |
||||
EOF |
||||
} |
||||
} |
||||
|
@ -0,0 +1,62 @@
@@ -0,0 +1,62 @@
|
||||
# https://github.com/dbbolton |
||||
# |
||||
# Below are some useful Perl-related aliases/functions that I use with zsh. |
||||
|
||||
|
||||
# Aliases ################################################################### |
||||
|
||||
# perlbrew ######## |
||||
alias pbi='perlbrew install' |
||||
alias pbl='perlbrew list' |
||||
alias pbo='perlbrew off' |
||||
alias pbs='perlbrew switch' |
||||
alias pbu='perlbrew use' |
||||
|
||||
# Perl ############ |
||||
|
||||
# perldoc` |
||||
alias pd='perldoc' |
||||
|
||||
# use perl like awk/sed |
||||
alias ple='perl -wlne' |
||||
|
||||
# show the latest stable release of Perl |
||||
alias latest-perl='curl -s http://www.perl.org/get.html | perl -wlne '\''if (/perl\-([\d\.]+)\.tar\.gz/) { print $1; exit;}'\' |
||||
|
||||
|
||||
|
||||
# Functions ################################################################# |
||||
|
||||
# newpl - creates a basic Perl script file and opens it with $EDITOR |
||||
newpl () { |
||||
# set $EDITOR to 'vim' if it is undefined |
||||
[[ -z $EDITOR ]] && EDITOR=vim |
||||
|
||||
# if the file exists, just open it |
||||
[[ -e $1 ]] && print "$1 exists; not modifying.\n" && $EDITOR $1 |
||||
|
||||
# if it doesn't, make it, and open it |
||||
[[ ! -e $1 ]] && print '#!/usr/bin/perl'"\n"'use strict;'"\n"'use warnings;'\ |
||||
"\n\n" > $1 && $EDITOR $1 |
||||
} |
||||
|
||||
|
||||
# pgs - Perl Global Substitution |
||||
# find pattern = 1st arg |
||||
# replace pattern = 2nd arg |
||||
# filename = 3rd arg |
||||
pgs() { # [find] [replace] [filename] |
||||
perl -i.orig -pe 's/'"$1"'/'"$2"'/g' "$3" |
||||
} |
||||
|
||||
|
||||
# Perl grep, because 'grep -P' is terrible. Lets you work with pipes or files. |
||||
prep() { # [pattern] [filename unless STDOUT] |
||||
perl -nle 'print if /'"$1"'/;' $2 |
||||
} |
||||
|
||||
# say - append a newline to 'print' |
||||
say() { |
||||
print "$1\n" |
||||
} |
||||
|
@ -0,0 +1,142 @@
@@ -0,0 +1,142 @@
|
||||
#compdef redis-cli rec |
||||
#autoload |
||||
|
||||
#redis cli completion, based off homebrew completion (ref. 2011-04-14) |
||||
|
||||
local -a _1st_arguments |
||||
_1st_arguments=( |
||||
'append:append a value to a key' |
||||
'auth:authenticate to the server' |
||||
'bgrewriteeaof:asynchronously rewrite the append-only file' |
||||
'bgsave:asynchornously save the dataset to disk' |
||||
'blpop:remove and get the first element in a list, or block until one is available' |
||||
'brpop:remove and get the last element in a list, or block until one is available' |
||||
'brpoplpush:pop a value from a list, push it to another list and return it; or block until one is available' |
||||
# 'config get:get the value of a configuration parameter' |
||||
# 'config set:set a configuration parameter to the given value' |
||||
# 'config resetstat: reset the stats returned by INFO' |
||||
'dbsize:return the number of keys in the selected database' |
||||
# 'debug object:get debugging information about a key' |
||||
# 'debug setgfault:make the server crash' |
||||
'decr:decrement the integer value of a key by one' |
||||
'decrby:decrement the integet value of a key by the given number' |
||||
'del:delete a key' |
||||
'discard:discard all commands issued after MULTI' |
||||
'echo:echo the given string' |
||||
'exec:execute all commands issued after a MULTI' |
||||
'exists:determine if a key exists' |
||||
'expire:set the time to live for a key, in seconds' |
||||
'expireat:set the expiration for a key as a UNIX timestamp' |
||||
'flushall:remove all keys from all databases' |
||||
'flushdb:remove all keys from the current database' |
||||
'get:get the value of a key' |
||||
'getbit:returns the bit value at offset in the string value stored at key' |
||||
'getrange:get a substring of the string stored at a key' |
||||
'getset:set the string value of a key and return its old value' |
||||
'hdel:delete a hash field' |
||||
'hexists:determine if a hash field exists' |
||||
'hget:get the value of a hash field' |
||||
'hgetall:get all the fields and values in a hash' |
||||
'hincrby:increment the integer value of a hash field by the given number' |
||||
'hkeys:get all the fields in a hash' |
||||
'hlen:get the number of fields in a hash' |
||||
'hmget:get the values of all the given hash fields' |
||||
'hmset:set multiple hash fields to multiple values' |
||||
'hset:set the string value of a hash field' |
||||
'hsetnx:set the value of a hash field, only if the field does not exist' |
||||
'hvals:get all the values in a hash' |
||||
'incr:increment the integer value of a key by one' |
||||
'incrby:increment the integer value of a key by the given number' |
||||
'info:get information and statistics about the server' |
||||
'keys:find all keys matching the given pattern' |
||||
'lastsave:get the UNIX timestamp of the last successful save to disk' |
||||
'lindex:get an element from a list by its index' |
||||
'linset:insert an element before or after another element in a list' |
||||
'llen:get the length of a list' |
||||
'lpop:remove and get the first element in a list' |
||||
'lpush:prepend a value to a list' |
||||
'lpushx:prepend a value to a list, only if the list exists' |
||||
'lrange:get a range of elements from a list' |
||||
'lrem:remove elements from a list' |
||||
'lset:set the value of an element in a list by its index' |
||||
'ltrim:trim a list to the specified range' |
||||
'mget:get the values of all the given keys' |
||||
'monitor:listen for all requests received by the server in real time' |
||||
'move:move a key to another database' |
||||
'mset:set multiple keys to muliple values' |
||||
'msetnx:set multiple keys tom ultiple values, only if none of the keys exist' |
||||
'multi:mark the start of a transaction block' |
||||
'object:inspect the internals of Redis objects' |
||||
'persist:remove the expiration from a key' |
||||
'ping:ping the server' |
||||
'psubscribe:listen for messages published to channels matching the given patterns' |
||||
'publish:post a message to a channel' |
||||
'punsubscribe:stop listening for messages posted to channels matching the given patterns' |
||||
'quit:close the connection' |
||||
'randomkey:return a random key from the keyspace' |
||||
'rename:rename a key' |
||||
'renamenx:rename a key, only if the new key does not exist' |
||||
'rpop:remove and get the last element in a list' |
||||
'rpoplpush:remove the last element in a list, append it to another list and return it' |
||||
'rpush:append a value to a list' |
||||
'rpushx:append a value to a list, only if the list exists' |
||||
'sadd:add a member to a set' |
||||
'save:synchronously save the dataset to disk' |
||||
'scard:get the number of members in a set' |
||||
'sdiff:subtract multiple sets' |
||||
'sdiffstore:subtract multiple sets and store the resulting set in a key' |
||||
'select:change the selected database for the current connection' |
||||
'set:set the string value of a key' |
||||
'setbit:sets or clears the bit at offset in the string value stored at key' |
||||
'setex:set the value and expiration of a key' |
||||
'setnx:set the value of a key, only if the key does not exist' |
||||
'setrange:overwrite part of a string at key starting at the specified offset' |
||||
'shutdown:synchronously save the dataset to disk and then shut down the server' |
||||
'sinter:intersect multiple sets' |
||||
'sinterstore:intersect multiple sets and store the resulting set in a key' |
||||
'sismember:determine if a given value is a member of a set' |
||||
'slaveof:make the server a slave of another instance, or promote it as master' |
||||
'smembers:get all the members in a set' |
||||
'smove:move a member from one set to another' |
||||
'sort:sort the elements in a list, set or sorted set' |
||||
'spop:remove and return a random member from a set' |
||||
'srandmember:get a random member from a set' |
||||
'srem:remove a member from a set' |
||||
'strlen:get the length of the value stored in a key' |
||||
'subscribe:listen for messages published to the given channels' |
||||
'sunion:add multiple sets' |
||||
'sunionstore:add multiple sets and store the resulting set in a key' |
||||
'ttl:get the time to live for a key' |
||||
'type:determine the type stored at key' |
||||
'unsubscribe:stop listening for messages posted to the given channels' |
||||
'unwatch:forget about all watched keys' |
||||
'watch:watch the given keys to determine execution of the MULTI/EXEC block' |
||||
'zadd:add a member to a sorted set, or update its score if it already exists' |
||||
'zcard:get the number of members in a sorted set' |
||||
'zcount:count the members in a sorted set with scores within the given values' |
||||
'zincrby:increment the score of a member in a sorted set' |
||||
'zinterstore:intersect multiple sorted sets and store the resulting sorted set in a new key' |
||||
'zrange:return a range of members in a sorted set, by index' |
||||
'zrangebyscore:return a range of members in a sorted set, by score' |
||||
'zrank:determine the index of a member in a sorted set' |
||||
'zrem:remove a member from a sorted set' |
||||
'zremrangebyrank:remove all members in a sorted set within the given indexes' |
||||
'zremrangebyscore:remove all members in a sorted set within the given scores' |
||||
'zrevrange:return a range of membrs in a sorted set, by index, with scores ordered from high to low' |
||||
'zrevrangebyscore:return a range of members in a sorted set, by score, with scores ordered from high to low' |
||||
'zrevrank:determine the index of a member in a sorted set, with scores ordered from high to low' |
||||
'zscore:get the score associated with the given member in a sorted set' |
||||
'zunionstore:add multiple sorted sets and store te resulting sorted set in a new key' |
||||
) |
||||
|
||||
local expl |
||||
|
||||
_arguments \ |
||||
'(-v --version)'{-v,--version}'[show version]' \ |
||||
'(-h --help)'{-h,--help}'[show help]' \ |
||||
'*:: :->subcmds' && return 0 |
||||
|
||||
if (( CURRENT == 1 )); then |
||||
_describe -t commands "redis-cli subcommand" _1st_arguments |
||||
return |
||||
fi |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
# add redis completion function to path |
||||
fpath=($ZSH/plugins/redis-cli $fpath) |
||||
autoload -U compinit |
||||
compinit -i |
@ -0,0 +1,12 @@
@@ -0,0 +1,12 @@
|
||||
## Aliases |
||||
|
||||
alias ys="yum search" # search package |
||||
alias yp="yum info" # show package info |
||||
alias yl="yum list" # list packages |
||||
alias yli="yum list installed" # print all installed packages |
||||
|
||||
alias yu="sudo yum update" # upgrate packages |
||||
alias yi="sudo yum install" # install package |
||||
alias yr="sudo yum remove" # remove package |
||||
alias yrl="sudo yum remove --remove-leaves" # remove package and leaves |
||||
alias yc="sudo yum clean all" # clean cache |
@ -1,6 +1,86 @@
@@ -1,6 +1,86 @@
|
||||
PROMPT='%{$fg[blue]%}%B%20~%b%{$reset_color%}%{$(git_prompt_info)%} $ ' |
||||
PROMPT='%{$fg[blue]%}%n%{$reset_color%} on %{$fg[red]%}%M%{$reset_color%} in %{$fg[blue]%}%~%b%{$reset_color%}$(git_time_since_commit)$(check_git_prompt_info) |
||||
$ ' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX="(%{$fg[green]%}" |
||||
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[white]%}" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%})" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="*%{$reset_color%}" |
||||
|
||||
# Text to display if the branch is dirty |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}" |
||||
|
||||
# Text to display if the branch is clean |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
# Colors vary depending on time lapsed. |
||||
ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT="%{$fg[green]%}" |
||||
ZSH_THEME_GIT_TIME_SHORT_COMMIT_MEDIUM="%{$fg[yellow]%}" |
||||
ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG="%{$fg[red]%}" |
||||
ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL="%{$fg[cyan]%}" |
||||
|
||||
|
||||
# Git sometimes goes into a detached head state. git_prompt_info doesn't |
||||
# return anything in this case. So wrap it in another function and check |
||||
# for an empty string. |
||||
function check_git_prompt_info() { |
||||
if git rev-parse --git-dir > /dev/null 2>&1; then |
||||
if [[ -z $(git_prompt_info) ]]; then |
||||
echo "%{$fg[magenta]%}detached-head%{$reset_color%})" |
||||
else |
||||
echo "$(git_prompt_info)" |
||||
fi |
||||
fi |
||||
} |
||||
|
||||
# Determine if we are using a gemset. |
||||
function rvm_gemset() { |
||||
GEMSET=`rvm gemset list | grep '=>' | cut -b4-` |
||||
if [[ -n $GEMSET ]]; then |
||||
echo "%{$fg[yellow]%}$GEMSET%{$reset_color%}|" |
||||
fi |
||||
|
||||
} |
||||
|
||||
# Determine the time since last commit. If branch is clean, |
||||
# use a neutral color, otherwise colors will vary according to time. |
||||
function git_time_since_commit() { |
||||
if git rev-parse --git-dir > /dev/null 2>&1; then |
||||
# Only proceed if there is actually a commit. |
||||
if [[ $(git log 2>&1 > /dev/null | grep -c "^fatal: bad default revision") == 0 ]]; then |
||||
# Get the last commit. |
||||
last_commit=`git log --pretty=format:'%at' -1 2> /dev/null` |
||||
now=`date +%s` |
||||
seconds_since_last_commit=$((now-last_commit)) |
||||
|
||||
# Totals |
||||
MINUTES=$((seconds_since_last_commit / 60)) |
||||
HOURS=$((seconds_since_last_commit/3600)) |
||||
|
||||
# Sub-hours and sub-minutes |
||||
DAYS=$((seconds_since_last_commit / 86400)) |
||||
SUB_HOURS=$((HOURS % 24)) |
||||
SUB_MINUTES=$((MINUTES % 60)) |
||||
|
||||
if [[ -n $(git status -s 2> /dev/null) ]]; then |
||||
if [ "$MINUTES" -gt 30 ]; then |
||||
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG" |
||||
elif [ "$MINUTES" -gt 10 ]; then |
||||
COLOR="$ZSH_THEME_GIT_TIME_SHORT_COMMIT_MEDIUM" |
||||
else |
||||
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT" |
||||
fi |
||||
else |
||||
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL" |
||||
fi |
||||
|
||||
if [ "$HOURS" -gt 24 ]; then |
||||
echo "($(rvm_gemset)$COLOR${DAYS}d${SUB_HOURS}h${SUB_MINUTES}m%{$reset_color%}|" |
||||
elif [ "$MINUTES" -gt 60 ]; then |
||||
echo "($(rvm_gemset)$COLOR${HOURS}h${SUB_MINUTES}m%{$reset_color%}|" |
||||
else |
||||
echo "($(rvm_gemset)$COLOR${MINUTES}m%{$reset_color%}|" |
||||
fi |
||||
else |
||||
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL" |
||||
echo "($(rvm_gemset)$COLOR~|" |
||||
fi |
||||
fi |
||||
} |
||||
|
@ -0,0 +1,10 @@
@@ -0,0 +1,10 @@
|
||||
PROMPT=$' |
||||
%{$fg[blue]%}%/%{$reset_color%} $(git_prompt_info)%{$fg[white]%}[%n@%m]%{$reset_color%} %{$fg[white]%}[%T]%{$reset_color%} |
||||
%{$fg_bold[black]%}>%{$reset_color%} ' |
||||
|
||||
PROMPT2="%{$fg_blod[black]%}%_> %{$reset_color%}" |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[green]%}[" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="]%{$reset_color%} " |
||||
ZSH_THEME_GIT_PROMPT_DIRTY=" %{$fg[red]%}*%{$fg[green]%}" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
@ -0,0 +1,19 @@
@@ -0,0 +1,19 @@
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[green]%}[" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="]%{$reset_color%}" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
#Customized git status, oh-my-zsh currently does not allow render dirty status before branch |
||||
git_custom_status() { |
||||
local cb=$(current_branch) |
||||
if [ -n "$cb" ]; then |
||||
echo "$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_PREFIX$(current_branch)$ZSH_THEME_GIT_PROMPT_SUFFIX" |
||||
fi |
||||
} |
||||
|
||||
#RVM and git settings |
||||
if [[ -s ~/.rvm/scripts/rvm ]] ; then |
||||
RPS1='$(git_custom_status)%{$fg[red]%}[`~/.rvm/bin/rvm-prompt`]%{$reset_color%} $EPS1' |
||||
fi |
||||
|
||||
PROMPT='%{$fg[cyan]%}[%~% ]%(?.%{$fg[green]%}.%{$fg[red]%})%B$%b ' |
@ -0,0 +1,21 @@
@@ -0,0 +1,21 @@
|
||||
autoload -U colors && colors |
||||
|
||||
autoload -Uz vcs_info |
||||
|
||||
zstyle ':vcs_info:*' stagedstr '%F{green}●' |
||||
zstyle ':vcs_info:*' unstagedstr '%F{yellow}●' |
||||
zstyle ':vcs_info:*' check-for-changes true |
||||
zstyle ':vcs_info:(sv[nk]|bzr):*' branchformat '%b%F{1}:%F{11}%r' |
||||
zstyle ':vcs_info:*' enable git svn |
||||
precmd () { |
||||
if [[ -z $(git ls-files --other --exclude-standard 2> /dev/null) ]] { |
||||
zstyle ':vcs_info:*' formats ' [%b%c%u%B%F{green}]' |
||||
} else { |
||||
zstyle ':vcs_info:*' formats ' [%b%c%u%B%F{red}●%F{green}]' |
||||
} |
||||
|
||||
vcs_info |
||||
} |
||||
|
||||
setopt prompt_subst |
||||
PROMPT='%B%F{magenta}%c%B%F{green}${vcs_info_msg_0_}%B%F{magenta} %{$reset_color%}%% ' |
@ -0,0 +1,50 @@
@@ -0,0 +1,50 @@
|
||||
# ------------------------------------------------------------------------------ |
||||
# FILE: kphoen.zsh-theme |
||||
# DESCRIPTION: oh-my-zsh theme file. |
||||
# AUTHOR: Kévin Gomez (geek63@gmail.com) |
||||
# VERSION: 1.0.0 |
||||
# SCREENSHOT: |
||||
# ------------------------------------------------------------------------------ |
||||
|
||||
|
||||
if [[ "$TERM" != "dumb" ]] && [[ "$DISABLE_LS_COLORS" != "true" ]]; then |
||||
PROMPT='[%{$fg[red]%}%n%{$reset_color%}@%{$fg[magenta]%}%m%{$reset_color%}:%{$fg[blue]%}%~%{$reset_color%}$(git_prompt_info)] |
||||
%# ' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX=" on %{$fg[green]%}" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
# display exitcode on the right when >0 |
||||
return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})" |
||||
|
||||
RPROMPT='${return_code}$(git_prompt_status)%{$reset_color%}' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%} ✚" |
||||
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[blue]%} ✹" |
||||
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖" |
||||
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[magenta]%} ➜" |
||||
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[yellow]%} ═" |
||||
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭" |
||||
else |
||||
PROMPT='[%n@%m:%~$(git_prompt_info)] |
||||
%# ' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX=" on" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
# display exitcode on the right when >0 |
||||
return_code="%(?..%? ↵)" |
||||
|
||||
RPROMPT='${return_code}$(git_prompt_status)' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_ADDED=" ✚" |
||||
ZSH_THEME_GIT_PROMPT_MODIFIED=" ✹" |
||||
ZSH_THEME_GIT_PROMPT_DELETED=" ✖" |
||||
ZSH_THEME_GIT_PROMPT_RENAMED=" ➜" |
||||
ZSH_THEME_GIT_PROMPT_UNMERGED=" ═" |
||||
ZSH_THEME_GIT_PROMPT_UNTRACKED=" ✭" |
||||
fi |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
PROMPT='%F{green}%2c%F{blue} [%f ' |
||||
RPROMPT='$(git_prompt_info) %F{blue}] %F{green}%D{%L:%M} %F{yellow}%D{%p}%f' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX="%F{yellow}" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%f" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY=" %F{red}*%f" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
@ -0,0 +1,43 @@
@@ -0,0 +1,43 @@
|
||||
#!/usr/bin/env zsh |
||||
# ------------------------------------------------------------------------------ |
||||
# Prompt for the Zsh shell: |
||||
# * One line. |
||||
# * VCS info on the right prompt. |
||||
# * Only shows the path on the left prompt by default. |
||||
# * Crops the path to a defined length and only shows the path relative to |
||||
# the current VCS repository root. |
||||
# * Wears a different color wether the last command succeeded/failed. |
||||
# * Shows user@hostname if connected through SSH. |
||||
# * Shows if logged in as root or not. |
||||
# ------------------------------------------------------------------------------ |
||||
|
||||
# Customizable parameters. |
||||
PROMPT_PATH_MAX_LENGTH=30 |
||||
PROMPT_DEFAULT_END=❯ |
||||
PROMPT_ROOT_END=❯❯❯ |
||||
PROMPT_SUCCESS_COLOR=$FG[071] |
||||
PROMPT_FAILURE_COLOR=$FG[124] |
||||
PROMPT_VCS_INFO_COLOR=$FG[242] |
||||
|
||||
# Set required options. |
||||
setopt promptsubst |
||||
|
||||
# Load required modules. |
||||
autoload -U add-zsh-hook |
||||
autoload -Uz vcs_info |
||||
|
||||
# Add hook for calling vcs_info before each command. |
||||
add-zsh-hook precmd vcs_info |
||||
|
||||
# Set vcs_info parameters. |
||||
zstyle ':vcs_info:*' enable hg bzr git |
||||
zstyle ':vcs_info:*:*' check-for-changes true # Can be slow on big repos. |
||||
zstyle ':vcs_info:*:*' unstagedstr '!' |
||||
zstyle ':vcs_info:*:*' stagedstr '+' |
||||
zstyle ':vcs_info:*:*' actionformats "%S" "%r/%s/%b %u%c (%a)" |
||||
zstyle ':vcs_info:*:*' formats "%S" "%r/%s/%b %u%c" |
||||
zstyle ':vcs_info:*:*' nvcsformats "%~" "" |
||||
|
||||
# Define prompts. |
||||
PROMPT="%(0?.%{$PROMPT_SUCCESS_COLOR%}.%{$PROMPT_FAILURE_COLOR%})${SSH_TTY:+[%n@%m]}%{$FX[bold]%}%$PROMPT_PATH_MAX_LENGTH<..<"'${vcs_info_msg_0_%%.}'"%<<%(!.$PROMPT_ROOT_END.$PROMPT_DEFAULT_END)%{$FX[no-bold]%}%{$FX[reset]%} " |
||||
RPROMPT="%{$PROMPT_VCS_INFO_COLOR%}"'$vcs_info_msg_1_'"%{$FX[reset]%}" |
@ -0,0 +1,48 @@
@@ -0,0 +1,48 @@
|
||||
# ------------------------------------------------------------------------------ |
||||
# FILE: sorin.zsh-theme |
||||
# DESCRIPTION: oh-my-zsh theme file. |
||||
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com) |
||||
# VERSION: 1.0.2 |
||||
# SCREENSHOT: http://i.imgur.com/aipDQ.png |
||||
# ------------------------------------------------------------------------------ |
||||
|
||||
|
||||
if [[ "$TERM" != "dumb" ]] && [[ "$DISABLE_LS_COLORS" != "true" ]]; then |
||||
MODE_INDICATOR="%{$fg_bold[red]%}❮%{$reset_color%}%{$fg[red]%}❮❮%{$reset_color%}" |
||||
local return_status="%{$fg[red]%}%(?..⏎)%{$reset_color%}" |
||||
|
||||
PROMPT='%{$fg[cyan]%}%c$(git_prompt_info) %(!.%{$fg_bold[red]%}#.%{$fg_bold[green]%}❯)%{$reset_color%} ' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX=" %{$fg[blue]%}git%{$reset_color%}:%{$fg[red]%}" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
RPROMPT='${return_status}$(git_prompt_status)%{$reset_color%}' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%} ✚" |
||||
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[blue]%} ✹" |
||||
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖" |
||||
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[magenta]%} ➜" |
||||
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[yellow]%} ═" |
||||
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭" |
||||
else |
||||
MODE_INDICATOR="❮❮❮" |
||||
local return_status="%(?::⏎)" |
||||
|
||||
PROMPT='%c$(git_prompt_info) %(!.#.❯) ' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX=" git:" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY="" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
RPROMPT='${return_status}$(git_prompt_status)' |
||||
|
||||
ZSH_THEME_GIT_PROMPT_ADDED=" ✚" |
||||
ZSH_THEME_GIT_PROMPT_MODIFIED=" ✹" |
||||
ZSH_THEME_GIT_PROMPT_DELETED=" ✖" |
||||
ZSH_THEME_GIT_PROMPT_RENAMED=" ➜" |
||||
ZSH_THEME_GIT_PROMPT_UNMERGED=" ═" |
||||
ZSH_THEME_GIT_PROMPT_UNTRACKED=" ✭" |
||||
fi |
@ -0,0 +1,15 @@
@@ -0,0 +1,15 @@
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX=" %{$fg[green]%}" |
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}" |
||||
ZSH_THEME_GIT_PROMPT_DIRTY=" %{$fg[red]%}⚡" |
||||
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||
|
||||
function prompt_char { |
||||
if [ $UID -eq 0 ]; then echo "%{$fg[red]%}#%{$reset_color%}"; else echo $; fi |
||||
} |
||||
|
||||
PROMPT='%(?, ,%{$fg[red]%}FAIL: $?%{$reset_color%} |
||||
) |
||||
%{$fg[magenta]%}%n%{$reset_color%}@%{$fg[yellow]%}%m%{$reset_color%}: %{$fg_bold[blue]%}%~%{$reset_color%}$(git_prompt_info) |
||||
%_$(prompt_char) ' |
||||
|
||||
RPROMPT='%{$fg[green]%}[%*]%{$reset_color%}' |
Loading…
Reference in new issue