From: Matthew Martin <phy1729@gmail.com>
To: zsh-workers@zsh.org
Subject: Re: [patch] Add BSDs to _ldconfig
Date: Sun, 7 Jan 2018 00:59:22 -0600 [thread overview]
Message-ID: <20180107065922.GA92097@CptOrmolo.darkstar> (raw)
In-Reply-To: <20180107043536.GA58441@CptOrmolo.darkstar>
On Sat, Jan 06, 2018 at 10:35:36PM -0600, Matthew Martin wrote:
> Move _ldconfig to Unix and add [DFNO]BSD to the mix. Thanks to Dana for
> review.
>
> - Matthew Martin
Accidentally included -v twice.
diff --git a/Completion/Linux/Command/_ldconfig b/Completion/Linux/Command/_ldconfig
deleted file mode 100644
index 5f4802f91..000000000
--- a/Completion/Linux/Command/_ldconfig
+++ /dev/null
@@ -1,35 +0,0 @@
-#compdef ldconfig ldconfig.real
-
-local ret=1
-local -a context line state state_descr
-local -A opt_args
-
-_arguments -s -S : \
- '(x -v --verbose)'{-v,--verbose}'[output verbosely]' \
- '(x)*: :->files' \
- + x \
- '(: -)'{-\?,--help}'[display help information]' \
- '(: -)'{-p,--print-cache}'[display libraries in current cache]' \
- '(: -)--usage[display brief usage information]' \
- '(: -)'{-V,--version}'[display version information]' \
- + l \
- '(x o)-l[manually link individual libraries (library mode)]' \
- + o \
- '(x l -c --format)'{-c+,--format=}'[specify cache format]:cache format:(old new compat)' \
- '(x l)-C+[specify cache file to use instead of /etc/ld.so.cache]:cache file:_files' \
- '(x l)-f+[specify configuration file to use instead of /etc/ld.so.conf]:configuration file:_files' \
- '(x l -i --ignore-aux-cache)'{-i,--ignore-aux-cache}'[ignore auxiliary cache file]' \
- '(x l -N)-n[process only directories specified on command line (implies -N)]' \
- '(x l)-N[do not rebuild cache]' \
- '(x l)-r+[specify root directory]:root directory:_directories' \
- '(x l)-X[do not update symbolic links]' \
-&& ret=0
-
-[[ $state == files ]] &&
-if [[ -n ${opt_args[(I)l--l]} ]]; then
- _object_files && ret=0
-else
- _directories && ret=0
-fi
-
-return ret
diff --git a/Completion/Unix/Command/_ldconfig b/Completion/Unix/Command/_ldconfig
new file mode 100644
index 000000000..3c3fca538
--- /dev/null
+++ b/Completion/Unix/Command/_ldconfig
@@ -0,0 +1,81 @@
+#compdef ldconfig ldconfig.real
+
+local ret=1
+local -a args context line state state_descr
+local -A opt_args
+
+case $OSTYPE in
+ linux*)
+ args=(
+ '(x -v --verbose)'{-v,--verbose}'[output verbosely]' \
+ + x \
+ '(: -)'{-\?,--help}'[display help information]'
+ '(: -)'{-p,--print-cache}'[display libraries in current cache]'
+ '(: -)--usage[display brief usage information]'
+ '(: -)'{-V,--version}'[display version information]'
+ + l
+ '(x o)-l[manually link individual libraries (library mode)]'
+ + o
+ '(x l -c --format)'{-c+,--format=}'[specify cache format]:cache format:(old new compat)'
+ '(x l)-C+[specify cache file to use instead of /etc/ld.so.cache]:cache file:_files'
+ '(x l)-f+[specify configuration file to use instead of /etc/ld.so.conf]:configuration file:_files'
+ '(x l -i --ignore-aux-cache)'{-i,--ignore-aux-cache}'[ignore auxiliary cache file]'
+ '(x l -N)-n[process only directories specified on command line (implies -N)]'
+ '(x l)-N[do not rebuild cache]'
+ '(x l)-r+[specify root directory]:root directory:_directories'
+ '(x l)-X[do not update symbolic links]'
+ )
+ ;;
+ *bsd*|dragonfly*)
+ args=(
+ '(-U)-m[merge into the existing hints file]'
+ '(: -)-r[list the current contents of the hints file]'
+ );|
+ dragonfly*|freebsd*|openbsd*)
+ args+=(
+ '(-U)-R[rescan previously configured directories]'
+ );|
+ dragonfly*|freebsd*)
+ args+=(
+ '(-aout)-elf[generate hints for elf format shared libraries]'
+ '-f+[specify hints file]:hints file:_files'
+ '-i[run in insecure mode]'
+ );|
+ freebsd*|netbsd*|openbsd*)
+ args+=(
+ '-v[switch on verbose mode]'
+ );|
+ freebsd*|openbsd*)
+ args+=(
+ '-s[do not scan /usr/lib for shared libraries]'
+ );|
+ freebsd*)
+ args+=(
+ '-32[generate hints for 32-bit ABI shared libraries]'
+ '(-elf)-aout[generate hints for a.out format shared libraries]'
+ );|
+ netbsd*)
+ args+=(
+ '(-s)-c[do not scan directories in /etc/ls.so.conf]'
+ '(-s)-S[do not scan /usr/lib for shared libraries]'
+ '-s[do not scan /usr/lib or directories in /etc/ld.so.conf for shared libraries]'
+ );|
+ openbsd*)
+ args+=(
+ '(-m)-U[unconfigure specified directories or inaccessable directories if none specified]'
+ );|
+esac
+
+_arguments -s -S : \
+ '(x)*: :->files' \
+ $args \
+&& ret=0
+
+[[ $state == files ]] &&
+if [[ -n ${opt_args[(I)l--l]} ]]; then
+ _object_files && ret=0
+else
+ _directories && ret=0
+fi
+
+return ret
prev parent reply other threads:[~2018-01-07 6:59 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-01-07 4:35 Matthew Martin
2018-01-07 5:53 ` Eitan Adler
2018-01-07 6:59 ` Matthew Martin [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180107065922.GA92097@CptOrmolo.darkstar \
--to=phy1729@gmail.com \
--cc=zsh-workers@zsh.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.vuxu.org/mirror/zsh/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).