The up package

[Tags: bsd3, program]

[Skip to ReadMe]

Properties

Versions0.1.0.0, 0.1.0.1, 0.1.0.2, 0.1.0.3, 1.0.0, 1.0.0.1, 1.0.0.2, 1.0.0.3
Change logNone available
Dependenciesbase (==4.7.*), directory (==1.2.*), filepath (==1.3.*), lambda-options (==0.5.*), mtl (==2.2.*), split (==0.2.*) [details]
LicenseBSD3
AuthorThomas Eding
Maintainernone
CategoryUtils
Home pagehttps://github.com/thomaseding/up
Executablesup
UploadedSun May 17 05:27:39 UTC 2015 by ThomasEding
DistributionsNixOS:1.0.0.3
Downloads637 total (52 in last 30 days)
Votes
0 []
StatusDocs not available [build log]
Last success reported on 2015-05-21 [all 1 reports]

Downloads

Maintainers' corner

For package maintainers and hackage trustees

Readme for up-1.0.0.3

Homepage: https://github.com/thomaseding/up Hackage: https://hackage.haskell.org/package/up ------ Install from git repository:

$ cabal configure
$ cabal build
$ cabal install

Install from Hackage.

$ cabal update
$ cabal install up

These will install the up command. -------- Example usage:

$ cd /home/thomas/code/up/src
$ up thomas
../../..
$ up --absolute thomas
/home/thomas
$ up ....
../../..
$ up --relative --from-to /abc/def/xyz/ abc
../../..

See up --help for more info. ------------ up generates file path strings, but it (by itself) does not change your current working directory. So below is code you can add to your shell's config file (e.g. .bashrc) to use the up program to change your directory.

g () {
    local DEST
    DEST=$(up "$@")
    if [ "$?" == '0' ]
    then
        cd "$DEST"
    else
        return "$?"
    fi
}

Example usage:

$ cd /home/thomas/code/up/src
$ g thomas
$ pwd
/home/thomas

For shell autocomplete for the above g command, you can add this to your shell's config in addition:

_g () {
    if [ "$COMP_CWORD" == "1" ]
    then
        local cur=${COMP_WORDS[COMP_CWORD]}
        local parts="$(pwd | tr '/' ' ')"
        COMPREPLY=( $(compgen -W "$parts" -- $cur) )
    fi
}
complete -F _g g