On Mon, Jun 17, 2024 at 02:03:17PM +0200, Stefano Brivio wrote: > In many places, we have direct perror() calls, which completely bypass > logging functions and log files. > > They are definitely convenient: offer similar convenience with > _perror() logging variants, so that we can drop those direct perror() > calls. > > Signed-off-by: Stefano Brivio Hm, for anything bigger than like a screenful of code, I generally find an explicit message with strerror(errno) more useful than perror() or equivalents, but I guess if you think these are useful. > --- > log.c | 21 +++++++++++++++++++++ > log.h | 21 +++++++++++++++++---- > 2 files changed, 38 insertions(+), 4 deletions(-) > > diff --git a/log.c b/log.c > index 939bb93..6764b2b 100644 > --- a/log.c > +++ b/log.c > @@ -80,6 +80,11 @@ void vlogmsg(int pri, const char *format, va_list ap) > } > } > > +/** > + * logmsg() - vlogmsg() wrapper for variable argument lists > + * @pri: Facility and level map, same as priority for vsyslog() > + * @format: Message > + */ > void logmsg(int pri, const char *format, ...) > { > va_list ap; > @@ -89,6 +94,22 @@ void logmsg(int pri, const char *format, ...) > va_end(ap); > } > > +/** > + * logmsg_perror() - vlogmsg() wrapper with perror()-like functionality > + * @pri: Facility and level map, same as priority for vsyslog() > + * @format: Message > + */ > +void logmsg_perror(int pri, const char *format, ...) > +{ > + va_list ap; > + > + logmsg(pri, "%s: ", strerror(errno)); > + > + va_start(ap, format); > + vlogmsg(pri, format, ap); > + va_end(ap); > +} > + > /* Prefixes for log file messages, indexed by priority */ > const char *logfile_prefix[] = { > NULL, NULL, NULL, /* Unused: LOG_EMERG, LOG_ALERT, LOG_CRIT */ > diff --git a/log.h b/log.h > index 680baab..5be0be9 100644 > --- a/log.h > +++ b/log.h > @@ -19,11 +19,18 @@ > void vlogmsg(int pri, const char *format, va_list ap); > void logmsg(int pri, const char *format, ...) > __attribute__((format(printf, 2, 3))); > +void logmsg_perror(int pri, const char *format, ...) > + __attribute__((format(printf, 2, 3))); > + > +#define err(...) logmsg( LOG_ERR, __VA_ARGS__) > +#define warn(...) logmsg( LOG_WARNING, __VA_ARGS__) > +#define info(...) logmsg( LOG_INFO, __VA_ARGS__) > +#define debug(...) logmsg( LOG_DEBUG, __VA_ARGS__) > > -#define err(...) logmsg(LOG_ERR, __VA_ARGS__) > -#define warn(...) logmsg(LOG_WARNING, __VA_ARGS__) > -#define info(...) logmsg(LOG_INFO, __VA_ARGS__) > -#define debug(...) logmsg(LOG_DEBUG, __VA_ARGS__) > +#define err_perror(...) logmsg_perror( LOG_ERR, __VA_ARGS__) > +#define warn_perror(...) logmsg_perror( LOG_WARNING, __VA_ARGS__) > +#define info_perror(...) logmsg_perror( LOG_INFO, __VA_ARGS__) > +#define debug_perror(...) logmsg_perror( LOG_DEBUG, __VA_ARGS__) > > #define die(...) \ > do { \ > @@ -31,6 +38,12 @@ void logmsg(int pri, const char *format, ...) > exit(EXIT_FAILURE); \ > } while (0) > > +#define die_perror(...) \ > + do { \ > + err_perror(__VA_ARGS__); \ > + exit(EXIT_FAILURE); \ > + } while (0) > + > extern int log_trace; > void trace_init(int enable); > #define trace(...) \ -- David Gibson (he or they) | I'll have my music baroque, and my code david AT gibson.dropbear.id.au | minimalist, thank you, not the other way | around. http://www.ozlabs.org/~dgibson