On Fri, Mar 27, 2015 at 11:19:35AM -0500, Jeff Nelson wrote: > On Fri, Mar 27, 2015 at 11:01:27AM +0100, Pavel Hrdina wrote: > > Signed-off-by: Pavel Hrdina <phrdina@xxxxxxxxxx> > > --- > > tools/virsh.h | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ > > 1 file changed, 52 insertions(+) > > > > diff --git a/tools/virsh.h b/tools/virsh.h > > index df2ea7f..fde20ef 100644 > > --- a/tools/virsh.h > > +++ b/tools/virsh.h > > @@ -474,4 +474,56 @@ char *_vshStrdup(vshControl *ctl, const char *s, const char *filename, > > # define VSH_EXCLUSIVE_OPTIONS_VAR(VARNAME1, VARNAME2) \ > > VSH_EXCLUSIVE_OPTIONS_EXPR(#VARNAME1, VARNAME1, #VARNAME2, VARNAME2) > > > > +/* Macros to help dealing with required options. */ > > + > > +/* VSH_REQUIRE_OPTION_EXPR: > > + * > > + * @NAME1: String containing the name of the option. > > + * @EXPR1: Expression to validate the variable (boolean variable). > > + * @NAME2: String containing the name of required option. > > + * @EXPR2: Expression to validate the variable (boolean variable). > > + * > > + * Check if required command options in virsh was set. Use the > > + * provided expression to check the variables. > > + * > > + * This helper does an early return and therefore it has to be called > > + * before anything that would require cleanup. > > + */ > > +# define VSH_REQUIRE_OPTION_EXPR(NAME1, EXPR1, NAME2, EXPR2) \ > > + if ((EXPR1) && !(EXPR2)) { \ > > + vshError(ctl, _("Option --%s is required by option --%s"), \ > > + NAME2, NAME1); \ > > + return false; \ > > + } > > It would be better to protect this within a "do { ... } while (0)" > statement. > Thanks for the review, I'll update all the macros. Pavel > -Jeff > > > + > > +/* VSH_REQUIRE_OPTION: > > + * > > + * @NAME1: String containing the name of the option. > > + * @NAME2: String containing the name of required option. > > + * > > + * Check if required command options in virsh was set. Use the > > + * vshCommandOptBool call to request them. > > + * > > + * This helper does an early return and therefore it has to be called > > + * before anything that would require cleanup. > > + */ > > +# define VSH_REQUIRE_OPTION(NAME1, NAME2) \ > > + VSH_REQUIRE_OPTION_EXPR(NAME1, vshCommandOptBool(cmd, NAME1), \ > > + NAME2, vshCommandOptBool(cmd, NAME2)) > > + > > +/* VSH_REQUIRE_OPTION_VAR: > > + * > > + * @VARNAME1: Boolean variable containing the value of the option of same name. > > + * @VARNAME2: Boolean variable containing the value of required option of > > + * same name. > > + * > > + * Check if required command options in virsh was set. Check in variables > > + * that contain the value and have same name as the option. > > + * > > + * This helper does an early return and therefore it has to be called > > + * before anything that would require cleanup. > > + */ > > +# define VSH_REQUIRE_OPTION_VAR(VARNAME1, VARNAME2) \ > > + VSH_REQUIRE_OPTION_EXPR(#VARNAME1, VARNAME1, #VARNAME2, VARNAME2) > > + > > #endif /* VIRSH_H */ > > -- > > 2.0.5 > > > > -- > > libvir-list mailing list > > libvir-list@xxxxxxxxxx > > https://www.redhat.com/mailman/listinfo/libvir-list -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list