[PATCH xserver 4/4] xfree86/parser: simplify #ifdef ladder
Alex Deucher
alexdeucher at gmail.com
Mon Apr 18 15:01:48 UTC 2016
On Sun, Apr 17, 2016 at 3:30 PM, Emil Velikov <emil.l.velikov at gmail.com> wrote:
> Rather than 'hacking' around symbol names and providing macros such as
> 'Local' just fold things and make the code more readable.
>
> Signed-off-by: Emil Velikov <emil.l.velikov at gmail.com>
Series is:
Reviewed-by: Alex Deucher <alexander.deucher at amd.com>
> ---
>
> If people prefer we can split out the different implementations
> (HAS_SAVED_IDS_AND_SETEUID vs not) to separate functions and call if
> from xf86writeConfigFile(). I don't mind either way.
>
> -Emil
>
> hw/xfree86/parser/write.c | 31 +++++++++----------------------
> 1 file changed, 9 insertions(+), 22 deletions(-)
>
> diff --git a/hw/xfree86/parser/write.c b/hw/xfree86/parser/write.c
> index 8792783..9a24dd6 100644
> --- a/hw/xfree86/parser/write.c
> +++ b/hw/xfree86/parser/write.c
> @@ -73,14 +73,7 @@
> #define HAS_NO_UIDS
> #endif
>
> -#ifdef HAS_NO_UIDS
> -#define doWriteConfigFile xf86writeConfigFile
> -#define Local /**/
> -#else
> -#define Local static
> -#endif
> -
> -Local int
> +static int
> doWriteConfigFile(const char *filename, XF86ConfigPtr cptr)
> {
> FILE *cf;
> @@ -134,24 +127,19 @@ doWriteConfigFile(const char *filename, XF86ConfigPtr cptr)
> return 1;
> }
>
> -#ifndef HAS_NO_UIDS
> -
> int
> xf86writeConfigFile(const char *filename, XF86ConfigPtr cptr)
> {
> +#ifndef HAS_NO_UIDS
> int ret;
>
> -#if !defined(HAS_SAVED_IDS_AND_SETEUID)
> - int pid, p;
> - int status;
> - void (*csig) (int);
> -#else
> - int ruid, euid;
> -#endif
> -
> if (getuid() != geteuid()) {
>
> #if !defined(HAS_SAVED_IDS_AND_SETEUID)
> + int pid, p;
> + int status;
> + void (*csig) (int);
> +
> /* Need to fork to change ruid without loosing euid */
> csig = signal(SIGCHLD, SIG_DFL);
> switch ((pid = fork())) {
> @@ -178,6 +166,7 @@ xf86writeConfigFile(const char *filename, XF86ConfigPtr cptr)
> return 0;
>
> #else /* HAS_SAVED_IDS_AND_SETEUID */
> + int ruid, euid;
>
> ruid = getuid();
> euid = geteuid();
> @@ -198,9 +187,7 @@ xf86writeConfigFile(const char *filename, XF86ConfigPtr cptr)
> #endif /* HAS_SAVED_IDS_AND_SETEUID */
>
> }
> - else {
> + else
> +#endif /* !HAS_NO_UIDS */
> return doWriteConfigFile(filename, cptr);
> - }
> }
> -
> -#endif /* !HAS_NO_UIDS */
> --
> 2.8.0
>
> _______________________________________________
> xorg-devel at lists.x.org: X.Org development
> Archives: http://lists.x.org/archives/xorg-devel
> Info: https://lists.x.org/mailman/listinfo/xorg-devel
More information about the xorg-devel
mailing list