summaryrefslogtreecommitdiff
path: root/.zsh/functions/open_ebuild
blob: dedecb36e77066cff6af1607f69481c0df6c7e39 (plain)
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
# Open the ebuild with a specified command
local ebuild sel
local -a elist

if [[ $# -lt 2 ]]; then
    echo "No package name given."
    return 4
fi

ebuild="$(equery w $2 2>&1 )"
if [[ $? -ne 0 ]]; then
    if [[ $ebuild == *"Ambiguous"* ]]; then
        elist=(${(f)ebuild})
        
        # remove the first line
        shift elist

        echo "Ambiguous package name '$2' -- choose from: "
        cat -n <<< ${(F)elist}
        read "sel?Selection: "
        
        if [[ -z $elist[$sel] ]]; then
            echo "Invalid choice."
            return 1
        else
            # the "=" is needed to strip the leading spaces and the quotes
            open_ebuild $1 ${=elist[$sel]}
            return $?
        fi
    
    elif [[ $ebuild == *"No packages matching"* ]]; then
        echo "Trying masked packages too..."
        ebuild=$(equery  w -m $2 2>&1)
    fi
fi

if [[ $? -eq 0 ]]; then
    $1 $ebuild
else
    echo "No ebuild found"
fi

# vim: ft=zsh
d=b4f9d6e0b325c71c62b19825b42758e8110ee871&follow=1'>Enhanced the open_ebuild functionRené 'Necoro' Neumann1-6/+29 2011-03-13make menc() more verboseRené 'Necoro' Neumann1-0/+5 2011-03-13Better 'cci' outputRené 'Necoro' Neumann1-0/+2 2011-03-13Add function to mount encrypted thingiesRené 'Necoro' Neumann1-0/+11 2011-03-13Make 'Y' behave correctly in vimRené 'Necoro' Neumann1-0/+3 2011-02-10backward-kill-wordRené 'Necoro' Neumann1-0/+3 2011-02-10Fix zsh versionRené 'Necoro' Neumann1-1/+1