Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
adam.huang
Oh My Zsh
Commits
de35b551
Commit
de35b551
authored
Dec 02, 2013
by
Robby Russell
Browse files
Merge pull request #1136 from koraa/pull_req_fastfile
On-the-fly creation and usage for file/dir shortcuts
parents
4bb8bd80
8c18f007
Changes
1
Show whitespace changes
Inline
Side-by-side
plugins/fastfile/fastfile.plugin.zsh
0 → 100644
View file @
de35b551
################################################################################
# FILE: fastfile.plugin.zsh
# DESCRIPTION: oh-my-zsh plugin file.
# AUTHOR: Michael Varner (musikmichael@web.de)
# VERSION: 1.0.0
#
# This plugin adds the ability to on the fly generate and access file shortcuts.
#
################################################################################
###########################
# Settings
# These can be overwritten any time.
# If they are not set yet, they will be
# overwritten with their default values
default fastfile_dir
"
${
HOME
}
/.fastfile/"
default fastfile_var_prefix
"§"
###########################
# Impl
#
# Generate a shortcut
#
# Arguments:
# 1. name - The name of the shortcut (default: name of the file)
# 2. file - The file or directory to make the shortcut for
# STDOUT:
# => fastfle_print
#
function
fastfile
()
{
test
"
$2
"
||
2
=
"."
file
=
$(
readlink
-f
"
$2
"
)
test
"
$1
"
||
1
=
"
$(
basename
"
$file
"
)
"
name
=
$(
echo
"
$1
"
|
tr
" "
"_"
)
mkdir
-p
"
${
fastfile_dir
}
"
echo
"
$file
"
>
"
$(
fastfile_resolv
"
$name
"
)
"
fastfile_sync
fastfile_print
"
$name
"
}
#
# Resolve the location of a shortcut file (the database file, where the value is written!)
#
# Arguments:
# 1. name - The name of the shortcut
# STDOUT:
# The path
#
function
fastfile_resolv
()
{
echo
"
${
fastfile_dir
}${
1
}
"
}
#
# Get the real path of a shortcut
#
# Arguments:
# 1. name - The name of the shortcut
# STDOUT:
# The path
#
function
fastfile_get
()
{
cat
"
$(
fastfile_resolv
"
$1
"
)
"
}
#
# Print a shortcut
#
# Arguments:
# 1. name - The name of the shortcut
# STDOUT:
# Name and value of the shortcut
#
function
fastfile_print
()
{
echo
"
${
fastfile_var_prefix
}${
1
}
->
$(
fastfile_get
"
$1
"
)
"
}
#
# List all shortcuts
#
# STDOUT:
# (=> fastfle_print) for each shortcut
#
function
fastfile_ls
()
{
for
f
in
"
${
fastfile_dir
}
"
/
*
;
do
file
=
`
basename
"
$f
"
`
# To enable simpler handeling of spaces in file names
varkey
=
`
echo
"
$file
"
|
tr
" "
"_"
`
# Special format for colums
echo
"
${
fastfile_var_prefix
}${
varkey
}
|->|
$(
fastfile_get
"
$file
"
)
"
done
| column
-t
-s
"|"
}
#
# Remove a shortcut
#
# Arguments:
# 1. name - The name of the shortcut (default: name of the file)
# 2. file - The file or directory to make the shortcut for
# STDOUT:
# => fastfle_print
#
function
fastfile_rm
()
{
fastfile_print
"
$1
"
rm
"
$(
fastfile_resolv
"
$1
"
)
"
}
#
# Generate the aliases for the shortcuts
#
function
fastfile_sync
()
{
for
f
in
"
${
fastfile_dir
}
"
/
*
;
do
file
=
`
basename
"
$f
"
`
# To enable simpler handeling of spaces in file names
varkey
=
`
echo
"
$file
"
|
tr
" "
"_"
`
alias
-g
"
${
fastfile_var_prefix
}${
varkey
}
"
=
"'
$(
fastfile_get
"
$file
"
)
'"
done
}
##################################
# Shortcuts
alias
ff
=
fastfile
alias
ffp
=
fastfile_print
alias
ffrm
=
fastfile_rm
alias
ffls
=
fastfile_ls
alias
ffsync
=
fastfile_sync
##################################
# Init
fastfile_sync
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment