TAGS: reformat to fix when PRINTF_FMT() used.

I was wondering why TAGS was missing some functions, and finally
tracked it down: PRINTF_FMT() confuses etags if it's at the start
of a function, and it ignores the rest of the file.

So we put PRINTF_FMT at the end, but that doesn't work for
*definitions*, only *declarations*.  So we remove it from definitions
and add gratuitous declarations in the few static places.1

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
Rusty Russell 2019-11-01 10:08:00 +10:30 committed by neil saitug
parent 7374134dab
commit fe17acf07b
11 changed files with 52 additions and 30 deletions

View File

@ -87,11 +87,11 @@ bool json_out_end(struct json_out *jout, char type);
* If the resulting string requires escaping, and @quote is true, we * If the resulting string requires escaping, and @quote is true, we
* call json_escape(). * call json_escape().
*/ */
PRINTF_FMT(4,5)
bool json_out_add(struct json_out *jout, bool json_out_add(struct json_out *jout,
const char *fieldname, const char *fieldname,
bool quote, bool quote,
const char *fmt, ...); const char *fmt, ...)
PRINTF_FMT(4,5);
/** /**
* json_out_addv - add a formatted member (vararg variant) * json_out_addv - add a formatted member (vararg variant)

View File

@ -558,13 +558,25 @@ struct io_plan *connection_out(struct io_conn *conn, struct connecting *connect)
handshake_out_success, connect); handshake_out_success, connect);
} }
/*~ When we've exhausted all addresses without success, we come here. */ /*~ When we've exhausted all addresses without success, we come here.
static void PRINTF_FMT(5,6) *
connect_failed(struct daemon *daemon, * Note that gcc gets upset if we put the PRINTF_FMT at the end like this if
const struct node_id *id, * it's an actual function definition, but etags gets confused and ignores the
u32 seconds_waited, * rest of the file if we put PRINTF_FMT at the front. So we put it at the
const struct wireaddr_internal *addrhint, * end, in a gratuitous declaration.
const char *errfmt, ...) */
static void connect_failed(struct daemon *daemon,
const struct node_id *id,
u32 seconds_waited,
const struct wireaddr_internal *addrhint,
const char *errfmt, ...)
PRINTF_FMT(5,6);
static void connect_failed(struct daemon *daemon,
const struct node_id *id,
u32 seconds_waited,
const struct wireaddr_internal *addrhint,
const char *errfmt, ...)
{ {
u8 *msg; u8 *msg;
va_list ap; va_list ap;

View File

@ -115,10 +115,14 @@ static bool selected_peer(struct seeker *seeker, struct peer *peer)
#define set_state(seeker, state, peer, ...) \ #define set_state(seeker, state, peer, ...) \
set_state_((seeker), (state), (peer), stringify(state), __VA_ARGS__) set_state_((seeker), (state), (peer), stringify(state), __VA_ARGS__)
static void PRINTF_FMT(5,6) static void set_state_(struct seeker *seeker, enum seeker_state state,
set_state_(struct seeker *seeker, enum seeker_state state, struct peer *peer,
struct peer *peer, const char *statename, const char *fmt, ...)
const char *statename, const char *fmt, ...) PRINTF_FMT(5,6);
static void set_state_(struct seeker *seeker, enum seeker_state state,
struct peer *peer,
const char *statename, const char *fmt, ...)
{ {
va_list ap; va_list ap;
va_start(ap, fmt); va_start(ap, fmt);

View File

@ -142,11 +142,16 @@ static struct io_plan *handle_client(struct io_conn *conn, struct client *c);
* and closes the client connection. This should never happen, of course, but * and closes the client connection. This should never happen, of course, but
* we definitely want to log if it does. * we definitely want to log if it does.
*/ */
static PRINTF_FMT(4,5) static struct io_plan *bad_req_fmt(struct io_conn *conn,
struct io_plan *bad_req_fmt(struct io_conn *conn, struct client *c,
struct client *c, const u8 *msg_in,
const u8 *msg_in, const char *fmt, ...)
const char *fmt, ...) PRINTF_FMT(4,5);
static struct io_plan *bad_req_fmt(struct io_conn *conn,
struct client *c,
const u8 *msg_in,
const char *fmt, ...)
{ {
va_list ap; va_list ap;
char *str; char *str;

View File

@ -183,11 +183,11 @@ const char *channel_state_str(enum channel_state state);
void channel_set_owner(struct channel *channel, struct subd *owner); void channel_set_owner(struct channel *channel, struct subd *owner);
/* Channel has failed, but can try again. */ /* Channel has failed, but can try again. */
PRINTF_FMT(2,3) void channel_fail_reconnect(struct channel *channel, void channel_fail_reconnect(struct channel *channel,
const char *fmt, ...); const char *fmt, ...) PRINTF_FMT(2,3);
/* Channel has failed, but can try again after a minute. */ /* Channel has failed, but can try again after a minute. */
PRINTF_FMT(2,3) void channel_fail_reconnect_later(struct channel *channel, void channel_fail_reconnect_later(struct channel *channel,
const char *fmt,...); const char *fmt,...) PRINTF_FMT(2,3);
/* Channel has failed, give up on it. */ /* Channel has failed, give up on it. */
void channel_fail_permanent(struct channel *channel, const char *fmt, ...); void channel_fail_permanent(struct channel *channel, const char *fmt, ...);

View File

@ -58,8 +58,10 @@ void connect_htlc_out(struct htlc_out_map *map, struct htlc_out *hend)
htlc_out_map_add(map, hend); htlc_out_map_add(map, hend);
} }
static void *PRINTF_FMT(2,3) static void *corrupt(const char *abortstr, const char *fmt, ...)
corrupt(const char *abortstr, const char *fmt, ...) PRINTF_FMT(2,3);
static void *corrupt(const char *abortstr, const char *fmt, ...)
{ {
if (abortstr) { if (abortstr) {
char *p; char *p;

View File

@ -90,11 +90,10 @@ void json_stream_append(struct json_stream *js, const char *str, size_t len);
* The resulting string from @fmt is escaped if quote is true: * The resulting string from @fmt is escaped if quote is true:
* see json_member_direct to avoid quoting. * see json_member_direct to avoid quoting.
*/ */
PRINTF_FMT(4,5)
void json_add_member(struct json_stream *js, void json_add_member(struct json_stream *js,
const char *fieldname, const char *fieldname,
bool quote, bool quote,
const char *fmt, ...); const char *fmt, ...) PRINTF_FMT(4,5);
/** /**
* json_member_direct - start a generic member. * json_member_direct - start a generic member.

View File

@ -140,7 +140,7 @@ struct log_book *new_log_book(struct lightningd *ld, size_t max_mem,
} }
/* With different entry points */ /* With different entry points */
struct log *PRINTF_FMT(3,4) struct log *
new_log(const tal_t *ctx, struct log_book *record, const char *fmt, ...) new_log(const tal_t *ctx, struct log_book *record, const char *fmt, ...)
{ {
struct log *log = tal(ctx, struct log); struct log *log = tal(ctx, struct log);

View File

@ -135,7 +135,7 @@ bool plugin_remove(struct plugins *plugins, const char *name)
return removed; return removed;
} }
void PRINTF_FMT(2,3) plugin_kill(struct plugin *plugin, char *fmt, ...) void plugin_kill(struct plugin *plugin, char *fmt, ...)
{ {
char *msg; char *msg;
va_list ap; va_list ap;

View File

@ -157,7 +157,7 @@ bool plugin_remove(struct plugins *plugins, const char *name);
/** /**
* Kill a plugin process, with an error message. * Kill a plugin process, with an error message.
*/ */
void PRINTF_FMT(2,3) plugin_kill(struct plugin *plugin, char *fmt, ...); void plugin_kill(struct plugin *plugin, char *fmt, ...) PRINTF_FMT(2,3);
/** /**
* Send the configure message to all plugins. * Send the configure message to all plugins.

View File

@ -142,7 +142,7 @@ struct plugin_timer *plugin_timer(struct plugin_conn *rpc,
struct command_result *(*cb)(void)); struct command_result *(*cb)(void));
/* Log something */ /* Log something */
void PRINTF_FMT(2, 3) plugin_log(enum log_level l, const char *fmt, ...); void plugin_log(enum log_level l, const char *fmt, ...) PRINTF_FMT(2, 3);
/* Macro to define arguments */ /* Macro to define arguments */
#define plugin_option(name, type, description, set, arg) \ #define plugin_option(name, type, description, set, arg) \