bug-hurd
[Top][All Lists]
Advanced

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

Re: [PATCH 1/4] term: improve the demuxer


From: Samuel Thibault
Subject: Re: [PATCH 1/4] term: improve the demuxer
Date: Wed, 11 Jun 2014 13:44:21 +0200
User-agent: Mutt/1.5.21+34 (58baf7c9f32f) (2010-12-30)

Justus Winter, le Wed 11 Jun 2014 13:41:07 +0200, a écrit :
> Handle multiple request types as recommended by the Mach Server
> Writer's Guide section 4, subsection "Handling Multiple Request
> Types".  This avoids initializing the reply message in every X_server
> function.
> 
> * term/main.c (demuxer): Improve the demuxer function.

Ack.

> ---
>  term/main.c | 24 ++++++++++++++++--------
>  1 file changed, 16 insertions(+), 8 deletions(-)
> 
> diff --git a/term/main.c b/term/main.c
> index 9cc32d4..be014e1 100644
> --- a/term/main.c
> +++ b/term/main.c
> @@ -32,6 +32,10 @@
>  
>  #include <version.h>
>  
> +#include "term_S.h"
> +#include "tioctl_S.h"
> +#include "device_reply_S.h"
> +
>  const char *argp_program_version = STANDARD_HURD_VERSION (term);
>  
>  int trivfs_fstype = FSTYPE_TERM;
> @@ -61,14 +65,18 @@ dev_t rdev;
>  int
>  demuxer (mach_msg_header_t *inp, mach_msg_header_t *outp)
>  {
> -  extern int term_server (mach_msg_header_t *, mach_msg_header_t *);
> -  extern int tioctl_server (mach_msg_header_t *, mach_msg_header_t *);
> -  extern int device_reply_server (mach_msg_header_t *, mach_msg_header_t *);
> -
> -  return (trivfs_demuxer (inp, outp)
> -       || term_server (inp, outp)
> -       || tioctl_server (inp, outp)
> -       || device_reply_server (inp, outp));
> +  mig_routine_t routine;
> +  if ((routine = NULL, trivfs_demuxer (inp, outp)) ||
> +      (routine = term_server_routine (inp)) ||
> +      (routine = tioctl_server_routine (inp)) ||
> +      (routine = device_reply_server_routine (inp)))
> +    {
> +      if (routine)
> +        (*routine) (inp, outp);
> +      return TRUE;
> +    }
> +  else
> +    return FALSE;
>  }
>  
>  static struct argp_option options[] =
> -- 
> 2.0.0
> 

-- 
Samuel
<r> make
<r> oops
<m> make clean



reply via email to

[Prev in Thread] Current Thread [Next in Thread]