On Thu, Aug 18, 2011 at 11:07:03PM +1000, Allan McRae wrote:
> If any of pkgver, pkgrel or epoch contained a variable substitution,
> then it needed to be evaluated before checking its value conformed
> to the rules.
> 
> Signed-off-by: Allan McRae <[email protected]>
> ---
>  scripts/makepkg.sh.in |    3 +++
>  1 files changed, 3 insertions(+), 0 deletions(-)
> 
> diff --git a/scripts/makepkg.sh.in b/scripts/makepkg.sh.in
> index e73fdfa..966caed 100644
> --- a/scripts/makepkg.sh.in
> +++ b/scripts/makepkg.sh.in
> @@ -1451,6 +1451,7 @@ check_sanity() {
>  
>       awk -F'=' '/^[[:space:]]*pkgver=/ { $1=""; print $0 }' "$BUILDFILE" |
>       while read i _; do
> +             eval i=$i

Quotes, please. This breaks on any whitespace in the value.

  eval i='$i'

>               if [[ $i =~ [[:space:]:-] ]]; then
>                       error "$(gettext "%s is not allowed to contain colons, 
> hyphens or whitespace.")" "pkgver"
>                       return 1
> @@ -1459,6 +1460,7 @@ check_sanity() {
>  
>       awk -F'=' '/^[[:space:]]*pkgrel=/ { $1=""; print $0 }' "$BUILDFILE" |
>       while read i _; do
> +             eval i=$i
>               if [[ $i =~ [[:space:]-] ]]; then
>                       error "$(gettext "%s is not allowed to contain hyphens 
> or whitespace.")" "pkgrel"
>                       return 1
> @@ -1467,6 +1469,7 @@ check_sanity() {
>  
>       awk -F'=' '/^[[:space:]]*epoch=/ { $1=""; print $0 }' "$BUILDFILE" |
>       while read i _; do
> +             eval i=$i
>               if [[ ! $i =~ ^[0-9]*$ ]]; then
>                       error "$(gettext "%s must be an integer.")" "epoch"
>                       return 1
> -- 
> 1.7.6
> 
> 

Reply via email to