-
Notifications
You must be signed in to change notification settings - Fork 14
/
README
141 lines (96 loc) · 4.79 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
S(1) User Commands S(1)
NAME
s - jump around
SYNOPSIS
s [-hlrt] [regex1 regex2 ... regexn]
AVAILABILITY
bash, zsh
DESCRIPTION
Tracks your most used hosts, based on 'frecency'(http://en.wikipedia.org/wiki/Frecency).
After a short learning phase, s will take you to the most 'frecent'
host that matches ALL of the regexes given on the command line, in
order.
For example, s foo bar would match foobar but not barfoo.
INSTALL
OS X
brew tap haosdent/s && brew install s
Linux
wget https://raw.githubusercontent.com/haosdent/s/master/s.sh
add source path/to/s.sh to $HOME/.bashrc or $HOME/.zshrc
OPTIONS
-h show a brief help message
-l list only
-r match by rank only
-t match by recent access only
EXAMPLES
s foo ssh to most frecent host matching foo
s foo bar ssh to most frecent host matching foo, then bar
s -r foo ssh to highest ranked host matching foo
s -t foo ssh to most recently accessed host matching foo
s -l foo list all hosts matching foo (by frecency)
NOTES
Installation:
Put something like this in your $HOME/.bashrc or $HOME/.zshrc:
. /path/to/s.sh
ssh around for a while to build up the db.
PROFIT!!
Optionally:
Set $_S_CMD to change the command name (default s).
Set $_S_DATA to change the datafile (default $HOME/.s).
Set $_S_NO_PROMPT_COMMAND to handle PROMPT_COMMAND/precmd your-
self.fc
Set $_S_EXCLUDE_HOSTS to an array of directory trees to exclude.
Set $_S_OWNER to allow usage when in 'sudo -s' mode.
(These settings should go in .bashrc/.zshrc before the line
added above.)
Install the provided man page z.1 somewhere like
/usr/local/man/man1.
Aging:
The rank of directories maintained by s undergoes aging based on a sim-
ple formula. The rank of each entry is incremented every time it is
accessed. When the sum of ranks is over 9000, all ranks are multiplied
by 0.99. Entries with a rank lower than 1 are forgotten.
Frecency:
Frecency is a portmanteau of 'recent' and 'frequency'. It is a weighted
rank that depends on how often and how recently something occurred. As
far as I know, Mozilla came up with the term.
To s, a host that has low ranking but has been accessed recently
will quickly have higher rank than a host accessed frequently a
long time ago.
Frecency is determined at runtime.
Common:
When multiple hosts match all queries, and they all have a common
prefix, s will ssh to the shortest matching directory, without regard to
priority. This has been in effect, if undocumented, for quite some
time, but should probably be configurable or reconsidered.
Tab Completion:
s supports tab completion. After any number of arguments, press TAB to
complete on directories that match each argument. Due to limitations of
the completion implementations, only the last argument will be com-
pleted in the shell.
Internally, s decides you've requested a completion if the last argu-
ment passed is an absolute path to an host.
ENVIRONMENT
A function _s() is defined.
The contents of the variable $_S_CMD is aliased to _s 2>&1. If not set,
$_S_CMD defaults to s.
The environment variable $_S_DATA can be used to control the datafile
location. If it is not defined, the location defaults to $HOME/.s.
In bash, s appends a command to the PROMPT_COMMAND environment variable
to maintain its database. In zsh, s appends a function _s_preexec to the
preexec_functions array.
The environment variable $_S_NO_PROMPT_COMMAND can be set if you want
to handle PROMPT_COMMAND or preexec yourself.
The environment variable $_S_EXCLUDE_HOSTS can be set to an array of
host to exclude from tracking.
The environment variable $_S_OWNER can be set to your username, to
allow usage of s when your sudo enviroment keeps $HOME set.
FILES
Data is stored in $HOME/.s. This can be overridden by setting the
$_S_DATA environment variable. When initialized, s will raise an error
if this path is a directory, and not function correctly.
A man page (s.1) is provided.
SEE ALSO
regex(7), ssh
Please file bugs at https://github.com/haosdent/s/
s January 2015 S(1)