[Code study]should we remove if (motd && *motd) section?

Daniel.Li daniel_li at usish.com
Mon Apr 27 11:27:38 GMT 2009


On Mon, 2009-04-27 at 19:21 +0800, Daniel.Li wrote:
> On Mon, 2009-04-27 at 12:41 +0200, Paul Slootman wrote:
> > On Mon 27 Apr 2009, Daniel.Li wrote:
> > > 
> > > I'm confused when we will run into "if (motd && *motd)"? 
> > > 
> > > As I have found that Globals is set 0 during initialization, and I
> > > didn't find anywhere else assign the value.
> > 
> > > clientserver.c #line 147~160
> > > > 	if (!am_client) {
> > > > 		motd = lp_motd_file();
> >                 ^^^^^^^^^^^^^^^^^^^^^^
> > > > 		if (motd && *motd) {
> > 
> > It's being assigned the line above the (motd && *motd) part!
> 
> Sorry, I forgot to paste below macros. Yes, it's assigned, but this
> function just returns default("") or global values. But it seems never
> assigned.

What I mean is "Globals.motd_file is NEVER assigned". When we use
default "". Then we still will NOT go into "if (motd && *motd)", as
*motd == 0.

What do u think?
> 
> loadparam.c #line 394
> 
> > FN_GLOBAL_STRING(lp_motd_file, &Globals.motd_file)
> 
> loadparam.c #line 374~375
> 
> 
> > #define FN_GLOBAL_STRING(fn_name,ptr) \
> >  char *fn_name(void) {return(*(char **)(ptr) ? *(char **)(ptr) : "");}
> 
> So the function will return "" or it's assigned value.
> char *lp_motd_file(void)
> {
> return(*(char **)(&Globals.motd_file) ? *(char **)(&Globals.motd_file) :
> "");
> }
> > 
> > 
> > Paul
> -- 
> Daniel
> 
Daniel




More information about the rsync mailing list