On 2018-07-09 15:44:36 -0400, Alvaro Herrera wrote:
> > +                           ereport(errlevel,
> >                                             (errcode(ERRCODE_TOO_MANY_ROWS),
> >                                              errmsg("query returned more 
> > than one row"),
> > -                                            errdetail ? 
> > errdetail_internal("parameters: %s", errdetail) : 0));
> > +                                            errdetail ? 
> > errdetail_internal("parameters: %s", errdetail) : 0,
> > +                                            use_errhint ? 
> > errhint("too_many_rows check of extra_%s is active.",
> > +                                                                     
> > too_many_rows_level == ERROR ? "errors" : "warnings") : 0));
> 
> Please write this in a way that results in less translatable messages,
> and don't build setting names at runtime.  Concretely I suggest this:
> 
> errhint(too_many_rows_level == ERROR ? 
>       gettext_noop("%s check of extra_errors is active.") : 
>       gettext_noop("%s check of extra_warnings is active."),
>       "too_many_rows");

Why not put extra_errors/extra_warnings into a variable as well?

Greetings,

Andres Freund

Reply via email to