diff options
author | knu <knu@FreeBSD.org> | 2001-11-09 23:48:40 +0800 |
---|---|---|
committer | knu <knu@FreeBSD.org> | 2001-11-09 23:48:40 +0800 |
commit | 61ad897ad8bb0fb14dfb0777701e6a639cad7b1f (patch) | |
tree | d50844d388c06b74d5e7384c0eff14bb89d82f11 /Mk/bsd.port.mk | |
parent | a481281c5e56253f24a57cbdc0ca7e2b0f406944 (diff) | |
download | freebsd-ports-gnome-61ad897ad8bb0fb14dfb0777701e6a639cad7b1f.tar.gz freebsd-ports-gnome-61ad897ad8bb0fb14dfb0777701e6a639cad7b1f.tar.zst freebsd-ports-gnome-61ad897ad8bb0fb14dfb0777701e6a639cad7b1f.zip |
Fix a quoting bug in `make describe'.
- Do not shrink series of spaces.
- Do not expand shell wildcards in pkg-comment.
I made the code cleaner and (3-4%) faster while I was at it.
Tested by: diff(1) and its option -b
(Maintainer timeout)
Diffstat (limited to 'Mk/bsd.port.mk')
-rw-r--r-- | Mk/bsd.port.mk | 94 |
1 files changed, 36 insertions, 58 deletions
diff --git a/Mk/bsd.port.mk b/Mk/bsd.port.mk index 606abd56ccb0..d2cfced2a6b8 100644 --- a/Mk/bsd.port.mk +++ b/Mk/bsd.port.mk @@ -2747,77 +2747,55 @@ package-depends: .if !target(describe) describe: - @${ECHO} `perl -e ' \ - print "${PKGNAME}|${.CURDIR}|${PREFIX}|"; \ - if (open (COMMENT, "${COMMENT}")) { \ + @${ECHO} "`perl -e ' \ + print q{${PKGNAME}|${.CURDIR}|${PREFIX}|}; \ + if (open(COMMENT, q{${COMMENT}})) { \ $$_ = <COMMENT>; \ chomp; \ print; \ } else { \ - print "** No Description"; \ + print q{** No Description}; \ } \ - if ( -f "${DESCR}" ) { \ - print "|${DESCR}"; \ + if ( -f q{${DESCR}} ) { \ + print q{|${DESCR}}; \ } else { \ - print "|/dev/null"; \ + print q{|/dev/null}; \ } \ - print q#|${MAINTAINER}|${CATEGORIES}|#; \ - for (split /\s+/, "${FETCH_DEPENDS} ${BUILD_DEPENDS} ${LIB_DEPENDS}") { \ - next if /^$$/; \ - s/^[^:]*\://; \ - s/\:.*//; \ - if ( ! -d $$_ ) { \ - print STDERR "${PKGNAME}: \"$$_\" non-existent -- dependency list incomplete"; \ - } else { \ - push @bdirs, $$_; \ + print q{|${MAINTAINER}|${CATEGORIES}|}; \ + @bdirs = map((split /:/)[1], split(q{ }, q{${FETCH_DEPENDS} ${BUILD_DEPENDS}})); \ + @rdirs = map((split /:/)[1], split(q{ }, q{${RUN_DEPENDS}})); \ + @mdirs = ( \ + map((split /:/)[0], split(q{ }, q{${DEPENDS}})), \ + map((split /:/)[1], split(q{ }, q{${LIB_DEPENDS}})) \ + ); \ + for my $$i (\@bdirs, \@rdirs, \@mdirs) { \ + my @dirs = @$$i; \ + @$$i = (); \ + for (@dirs) { \ + if (-d $$_) { \ + push @$$i, $$_; \ + } else { \ + print STDERR qq{${PKGNAME}: \"$$_\" non-existent -- dependency list incomplete\n}; \ + } \ } \ } \ - for (split /\s+/, "${LIB_DEPENDS} ${RUN_DEPENDS}") { \ - next if /^$$/; \ - s/^[^:]*\://; \ - s/\:.*//; \ - if ( ! -d $$_ ) { \ - print STDERR "${PKGNAME}: \"$$_\" non-existent -- dependency list incomplete"; \ - } else { \ - push @rdirs, $$_; \ - } \ - } \ - for (split /\s+/, "${DEPENDS}") { \ - next if /^$$/; \ - s/\:.*//; \ - if ( ! -d $$_ ) { \ - print STDERR "${PKGNAME}: \"$$_\" non-existent -- dependency list incomplete"; \ - } else { \ - push @mdirs, $$_; \ - } \ + for (@bdirs, @mdirs) { \ + $$x{$$_} = 1; \ } \ - for (sort (@bdirs, @mdirs)) { \ - if ($$_ ne $$l) { \ - $$a .= $$_ . " "; \ - $$l = $$_; \ - } \ + print join(q{ }, sort keys %x), q{|}; \ + for (@rdirs, @mdirs) { \ + $$y{$$_} = 1; \ } \ - chop $$a; \ - print "$$a|"; \ - for (sort (@rdirs, @mdirs)) { \ - if ($$_ ne $$m) { \ - $$b .= $$_ . " "; \ - $$m = $$_; \ - } \ - } \ - chop $$b; \ - print "$$b|"; \ - if (open (DESCR, "${DESCR}")) { \ - until (/^WWW\:\s/ or eof DESCR) { \ - $$_ = <DESCR>; \ - } \ - if (/^WWW\:\s/) { \ - chomp; \ - split /\s+/; \ - print $$_[1]; \ + print join(q{ }, sort keys %y), q{|}; \ + if (open(DESCR, q{${DESCR}})) { \ + while (<DESCR>) { \ + if (/^WWW:\s+(\S+)/) { \ + print $$1; \ + last; \ + } \ } \ } \ - print "\n";'` + print qq{\n};'`" .endif www-site: |