summaryrefslogtreecommitdiffstats
path: root/bin/pbfields
diff options
context:
space:
mode:
authorJustin Davis <jrcd83@gmail.com>2012-05-14 02:40:10 +0200
committerJustin Davis <jrcd83@gmail.com>2012-05-14 02:40:10 +0200
commitaeeb51372863bd95b5126691c16851d52082ac92 (patch)
tree7be6aef8b78fcb12e266450d1307e5a9c27c28c2 /bin/pbfields
parentce30a8af59f163bc09be80955d38b56039785735 (diff)
downloadgenpkg-aeeb51372863bd95b5126691c16851d52082ac92.tar.gz
genpkg-aeeb51372863bd95b5126691c16851d52082ac92.tar.xz
Add feature to replace ver-strings with $pkgver.
Alot of logic was added to allow changing versions in mods while still preserving the version in the $_ver custom variable.
Diffstat (limited to 'bin/pbfields')
-rwxr-xr-xbin/pbfields51
1 files changed, 30 insertions, 21 deletions
diff --git a/bin/pbfields b/bin/pbfields
index 5bbf9c6..ca65c2a 100755
--- a/bin/pbfields
+++ b/bin/pbfields
@@ -1,16 +1,22 @@
#!/usr/bin/awk -f
BEGIN {
- fieldstr = "pkgname pkgver pkgrel pkgdesc epoch" \
+ fieldstr = "pkgname _ver pkgver pkgrel pkgdesc epoch" \
" *arch *license *options" \
" install changelog" \
" *depends *makedepends *checkdepends *optdepends" \
" *conflicts *provides" \
- " url *source *noextract *md5sums *sha512sums"
+ " url *source *noextract *md5sums *sha512sums" \
+ " _dir"
max = split(fieldstr, fields)
for(i=1; i<=max; i++) {
- if(sub(/^[*]/, "", fields[i])) arrfield[fields[i]] = 1;
- else strfield[fields[i]] = 1;
+ if(sub(/^[*]/, "", fields[i])){
+ arrfield[fields[i]] = 1
+ }else if(sub(/^_/, "", fields[i])){
+ cfield[fields[i]] = 1
+ }else{
+ strfield[fields[i]] = 1
+ }
}
COLS = 78; FS = "\n"; RS = ""
@@ -22,15 +28,6 @@ $1 == "packager" { packager = $2 }
$1 == "maintainer" { maintainer = $2 }
-$1 ~ /depends$|conflicts|provides|source/ { quotevals() }
-
-$1 == "pkgdesc" {
- gsub(/[$"`]/, "\\\\&", $2)
- $2 = sprintf("\"%s\"", $2)
-}
-
-$1 == "pkgverfmt" { pkgverfmt = $2 }
-
$1 == "customvars" {
for(i = 2; i <= NF; i++){
customvars[i - 1] = $i
@@ -39,7 +36,8 @@ $1 == "customvars" {
}
{
- if(strfield[$1]){
+ quotevals()
+ if(($1 in strfield) || ($1 in cfield)){
output[$1] = $2
}else {
arrtxt = wraparray(length($1) + 2)
@@ -62,16 +60,22 @@ END {
print ""
OFS = "="; ORS = "\n";
+ for(i = 1; i <= customlen; i++){
+ v = customvars[i]
+ print "_" v, unk[v]
+ }
for(i=1; i<=max; i++){
name = fields[i]
- if(name in output){
+ if(!(name in output)){
+ continue
+ }
+
+ if(name in cfield){
+ print "_" name, output[name]
+ }else{
print name, output[name]
}
}
- for(i = 1; i <= customlen; i++){
- v = customvars[i]
- print "_" v, unk[v]
- }
}
function wraparray (indent)
@@ -112,6 +116,11 @@ function quotevals ()
function bashquote (val)
{
- if(val ~ /[$]/) return sprintf("\"%s\"", val)
- return sprintf("'%s'", val)
+
+ if(val ~ /[$'"`]/){
+ gsub(/[$"`]/, "\\\\&", $2)
+ return sprintf("\"%s\"", val)
+ }
+ if(val ~ / /) return sprintf("'%s'", val)
+ return val
}