Re: [PATCH 1/2] mountpoint: refactor exit path

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, Oct 09, 2011 at 11:12:04AM -0400, Dave Reisner wrote:
> There's only one condition for which we declare success, but many for
> failure. Initialize rc as failure and set to success on this single
> condition. In all cases, jump to a label to exit instead of exiting
> immediately. This will be used later on to ease cleanup of any heap
> allocations.
> 
> Signed-off-by: Dave Reisner <dreisner@xxxxxxxxxxxxx>
> ---

Noticing that this could be done better -- the return/goto calls here
don't do anything because err/errx are exiting after throwing the error
message. They should be replaced with equivalent warn/warnx calls so we
hit the goto on error and cleanup before exiting.

@Karel: I can resend this if you like.

Regards,
dave

>  sys-utils/mountpoint.c |   15 +++++++++------
>  1 files changed, 9 insertions(+), 6 deletions(-)
> 
> diff --git a/sys-utils/mountpoint.c b/sys-utils/mountpoint.c
> index 1297d82..e021c70 100644
> --- a/sys-utils/mountpoint.c
> +++ b/sys-utils/mountpoint.c
> @@ -105,7 +105,7 @@ static void __attribute__((__noreturn__)) usage(FILE *out)
>  
>  int main(int argc, char **argv)
>  {
> -	int c, fs_devno = 0, dev_devno = 0, rc = 0;
> +	int c, fs_devno = 0, dev_devno = 0, rc = EXIT_FAILURE;
>  	char *spec;
>  	struct stat st;
>  
> @@ -152,7 +152,7 @@ int main(int argc, char **argv)
>  	if (stat(spec, &st)) {
>  		if (!quiet)
>  			err(EXIT_FAILURE, "%s", spec);
> -		return EXIT_FAILURE;
> +		goto finish;
>  	}
>  	if (dev_devno)
>  		rc = print_devno(spec, &st);
> @@ -162,19 +162,22 @@ int main(int argc, char **argv)
>  		if (!S_ISDIR(st.st_mode)) {
>  			if (!quiet)
>  				errx(EXIT_FAILURE, _("%s: not a directory"), spec);
> -			return EXIT_FAILURE;
> +			goto finish;
>  		}
>  		src = dir_to_device(spec);
>  		if (src == (dev_t)-1) {
>  			if (!quiet)
>  				printf(_("%s is not a mountpoint\n"), spec);
> -			return EXIT_FAILURE;
> +			goto finish;
>  		}
>  		if (fs_devno)
>  			printf("%u:%u\n", major(src), minor(src));
> -		else if (!quiet)
> +		else if (!quiet) {
>  			printf(_("%s is a mountpoint\n"), spec);
> +			rc = EXIT_SUCCESS;
> +		}
>  	}
>  
> -	return rc ? EXIT_FAILURE : EXIT_SUCCESS;
> +finish:
> +	return rc;
>  }
> -- 
> 1.7.7
> 
--
To unsubscribe from this list: send the line "unsubscribe util-linux" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux