zsh-workers
 help / color / mirror / code / Atom feed
* New Completion for FreeBSD's portmaster
@ 2009-11-10 12:03 Baptiste Daroussin
  2009-11-12 19:41 ` Peter Stephenson
  0 siblings, 1 reply; 3+ messages in thread
From: Baptiste Daroussin @ 2009-11-10 12:03 UTC (permalink / raw)
  To: zsh-workers

[-- Attachment #1: Type: text/plain, Size: 118 bytes --]

Hi 
here comes a new completion for FreeBSD's portmaster
It goes to Completion/BSD/Command repository

regards,
Bapt


[-- Attachment #2: _portmaster --]
[-- Type: text/plain, Size: 3975 bytes --]

#compdef portmaster

_portmaster_pkgs() {
  compadd "$@" - ${PKG_DBDIR:-/var/db/pkg}/*(/:t)
}

_portmaster_ports() {
  local ret=1 _fbsd_ports _fbsd_cat
   _fbsd_cat=(${PORTSDIR:-/usr/ports}/[a-z]*(/:t))
   if [[ $PREFIX != */* ]] ; then
     _wanted cat_packages expl 'category/ports' compadd -S '/' $_fbsd_cat
   else
     compset -P '*/'
     _fbsd_ports=(${PORTSDIR:-/usr/ports}/$IPREFIX/*(/:t))
     _wanted cat_packages expl 'category/ports' compadd $_fbsd_ports
   fi
  return ret
}

_portmaster_pkgs_and_ports() {
  local ret=1
  _portmaster_pkgs && ret=0
  _portmaster_ports && ret=0

  return ret
}

_portmaster() {
  local specific_args common_args expunge_args standalone_args kid
  standalone_args=(
  '--clean-distfiles[delete distfiles not associated with an installed ports: interactive]'
  '--clean-distfiles-all[delete distfiles not associated with an installed ports]'
  '--check-depends[cross-check and update dependency information for all ports]'
  '--check-port-dbdir[check for stale entries in /var/db/ports]'
  '--list-origins[list directories from /usr/ports for root and leaf ports]'
  '-l[list all installed ports by category]'
  '-L[list all installed ports by category, and search for updates]'
  {'(-help)-h','(-h)--help'}'[display help message]:'
    '--version[display the version only]:'
    )
    specific_args=(
    '(-s -r -o)-e[expunge port using pkg_delete, and remove all distfiles]:name of port:_portmaster_pkgs'
    '(-e -r -o)-s[clean out stale ports that used to be depended on]'
    '(-e -s -o)-r[rebuild the specified port, and all ports that depend on it]:name/glob of port:_portmaster_pkgs'
    '(-e -s -r)-o[replace the installed port with a port from a different origin]:new port dir:_portmaster_ports'
    )
    expunge_args=(
    '(-b)-B[prevents creation of the backup package for the installed port]'
    '(-d)-D[no cleaning of distfiles]'
    '(-D)-d[always clean distfiles]'
    )
    common_args=(
    "(-G)--force-config[run 'make config' for all ports]" 
    "-C[prevents 'make clean' from being run before building]"
    '-H[hide details of the port build and install in a log file]'
    "-K[prevents 'make clean' from being run after building]"
    '(-B)-b[create and keep a backup package of an installed port]'
    '-g[create a package of the new port]'
    '-n[run through configure, but do not make or install any ports]'
    '-t[recurse dependencies thoroughly, using all-depends-list]'
    '-v[verbose output]'
    '-w[save old shared libraries before deinstall]'
    '-u[unattended mode]'
    '(-i)-f[always rebuild ports]'
    '(-f)-i[interactive update mode]'
    '-m[any arguments to supply to make]:arguments for make:'
    '-x[avoid building or updating ports that match this pattern]:glob pattern to exclude from building:'
    '-p[specify the full path to a port directory]:a port directory:'
    '--show-work[show what dependent ports are, and are not installed]'
    '-R[restart an update, skipping ports already up to date]' 
    '-a[check all ports, update as necessary]'
    '-F[fetch distfiles only]'
    $expunge_args
    $specific_args
    )
    if (( CURRENT == 2 ));then
      _arguments -s \
      $standalone_args \
      $common_args \
      '*:Packages and Ports:_portmaster_pkgs_and_ports'
    else 
      case "$words[2]" in
	--clean-distfiles|--clean-distfiles-all|--check-depends|--check-port-dbdir|--version|-help|-h)
	return 0
	;;
	*)
	if (( $words[(I)-(e|r)] ));then
	  _arguments -s \
	  '*:Packages:_portmaster_pkgs'
	elif (( kid=$words[(I)-o] ));then
	  if (( CURRENT == $kid + 1 ));then
	    _arguments -s \
	    '*:Ports replacing:_portmaster_ports'
	  elif (( CURRENT == $kid + 2 )); then
	    _arguments -s \
	    '*:Package to replace:_portmaster_pkgs'
	  else 
	    return 0
	  fi
	elif (( $words[(I)-s] ));then
	  return 0
	else
	  _arguments -s \
	  $common_args \
	  '*:Packages and Ports:_portmaster_pkgs_and_ports'
	fi
	;;
      esac
    fi
  }

  _portmaster "$@"

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: New Completion for FreeBSD's portmaster
  2009-11-10 12:03 New Completion for FreeBSD's portmaster Baptiste Daroussin
@ 2009-11-12 19:41 ` Peter Stephenson
  2009-11-12 23:06   ` Baptiste Daroussin
  0 siblings, 1 reply; 3+ messages in thread
From: Peter Stephenson @ 2009-11-12 19:41 UTC (permalink / raw)
  To: zsh-workers

On Tue, 10 Nov 2009 13:03:29 +0100
Baptiste Daroussin <baptiste.daroussin@gmail.com> wrote:
> here comes a new completion for FreeBSD's portmaster
> It goes to Completion/BSD/Command repository

I've committed these: in future(*), please send them in the format of "diff
/dev/null Completion/BSD/Command/whatever" (equivalent to what "cvs diff
-N ..." does) from the toplevel of the distribution, it involves much
less manipulation to add using "patch".  (I can cope with "a/" and "b/"
in front of the file names if it comes from git.)

Thanks.

(*) In managementspeak this has become "going forward".  I still
haven't worked out why.  Anybody using this phrase in bug reports gets
minimum priority.

-- 
Peter Stephenson <p.w.stephenson@ntlworld.com>
Web page now at http://homepage.ntlworld.com/p.w.stephenson/


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: New Completion for FreeBSD's portmaster
  2009-11-12 19:41 ` Peter Stephenson
@ 2009-11-12 23:06   ` Baptiste Daroussin
  0 siblings, 0 replies; 3+ messages in thread
From: Baptiste Daroussin @ 2009-11-12 23:06 UTC (permalink / raw)
  To: zsh-workers

Le Thursday 12 Nov 2009 à 19:41:11 (+0000), Peter Stephenson a écrit :
> On Tue, 10 Nov 2009 13:03:29 +0100
> Baptiste Daroussin <baptiste.daroussin@gmail.com> wrote:
> > here comes a new completion for FreeBSD's portmaster
> > It goes to Completion/BSD/Command repository
> 
> I've committed these: in future(*), please send them in the format of "diff
> /dev/null Completion/BSD/Command/whatever" (equivalent to what "cvs diff
> -N ..." does) from the toplevel of the distribution, it involves much
> less manipulation to add using "patch".  (I can cope with "a/" and "b/"
> in front of the file names if it comes from git.)
> 
> Thanks.
> 
> (*) In managementspeak this has become "going forward".  I still
> haven't worked out why.  Anybody using this phrase in bug reports gets
> minimum priority.
> 
> -- 
> Peter Stephenson <p.w.stephenson@ntlworld.com>
> Web page now at http://homepage.ntlworld.com/p.w.stephenson/
ok thanks and sorry about that I'll send only diff in futur

regards,
bapt


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2009-11-12 23:06 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-11-10 12:03 New Completion for FreeBSD's portmaster Baptiste Daroussin
2009-11-12 19:41 ` Peter Stephenson
2009-11-12 23:06   ` Baptiste Daroussin

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).