Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/msgc Introduce _fmt_ flavors of the menu functions t...
details: https://anonhg.NetBSD.org/src/rev/2799e6bc645e
branches: trunk
changeset: 999825:2799e6bc645e
user: christos <christos%NetBSD.org@localhost>
date: Thu Jun 20 00:45:18 2019 +0000
description:
Introduce _fmt_ flavors of the menu functions that take a formatting string
so we can use fmtcheck(3) to check the formats of the messages strings.
diffstat:
usr.bin/msgc/msg_sys.def | 109 ++++++++++++++++++++++++++++++++++------------
usr.bin/msgc/msgdb.c | 52 ++++++++++++++++-----
2 files changed, 120 insertions(+), 41 deletions(-)
diffs (285 lines):
diff -r b3d2712ea7bf -r 2799e6bc645e usr.bin/msgc/msg_sys.def
--- a/usr.bin/msgc/msg_sys.def Thu Jun 20 00:43:55 2019 +0000
+++ b/usr.bin/msgc/msg_sys.def Thu Jun 20 00:45:18 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: msg_sys.def,v 1.44 2019/03/01 17:02:21 martin Exp $ */
+/* $NetBSD: msg_sys.def,v 1.45 2019/06/20 00:45:18 christos Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -158,7 +158,7 @@
wstandend(msg_win);
}
-static int
+static int __printflike(2, 0)
_msg_vprintf(int auto_fill, const char *fmt, va_list ap)
{
const char *wstart, *afterw;
@@ -285,28 +285,42 @@
}
void
-msg_display(msg msg_no, ...)
+msg_display(msg msg_no)
+{
+
+ msg_printf("%s", msg_string(msg_no));
+}
+
+void __printflike(2, 3)
+msg_fmt_display(msg msg_no, const char *fmt, ...)
{
va_list ap;
msg_clear();
- va_start(ap, msg_no);
- (void)_msg_vprintf(1, msg_string(msg_no), ap);
+ va_start(ap, fmt);
+ (void)_msg_vprintf(1, fmtcheck(msg_string(msg_no), fmt), ap);
va_end(ap);
}
void
-msg_display_add(msg msg_no, ...)
+msg_display_add(msg msg_no)
+{
+
+ msg_printf("%s", msg_string(msg_no));
+}
+
+void __printflike(2, 3)
+msg_fmt_display_add(msg msg_no, const char *fmt, ...)
{
va_list ap;
- va_start(ap, msg_no);
- (void)_msg_vprintf(1, msg_string(msg_no), ap);
+ va_start(ap, fmt);
+ (void)_msg_vprintf(1, fmtcheck(msg_string(msg_no), fmt), ap);
va_end(ap);
}
-void
+void __printflike(1, 2)
msg_printf(const char *fmt, ...)
{
va_list ap;
@@ -316,7 +330,7 @@
va_end(ap);
}
-static void
+static void __printflike(1, 0)
_msg_vprompt(const char *fmt, int flags, const char *def, char *val,
size_t val_buf_len, va_list ap)
{
@@ -469,21 +483,36 @@
}
void
-msg_prompt(msg msg_no, const char *def, char *val, size_t val_buf_len, ...)
+msg_prompt(msg msg_no, const char *def, char *val, size_t val_buf_len)
+{
+
+ msg_fmt_prompt(msg_no, def, val, val_buf_len, "");
+}
+
+void __printflike(5, 6)
+msg_fmt_prompt(msg msg_no, const char *def, char *val, size_t val_buf_len,
+ const char *fmt, ...)
{
va_list ap;
msg_clear();
- va_start(ap, val_buf_len);
- _msg_vprompt(msg_string(msg_no), MSG_PROMPT_ECHO,
+ va_start(ap, fmt);
+ _msg_vprompt(fmtcheck(msg_string(msg_no), fmt), MSG_PROMPT_ECHO,
def, val, val_buf_len, ap);
va_end(ap);
}
void
msg_prompt_win(msg msg_no, int x, int y, int w, int h,
- const char *def, char *val, size_t val_buf_len, ...)
+ const char *def, char *val, size_t val_buf_len)
+{
+ msg_fmt_prompt_win(msg_no, x, y, w, h, def, val, val_buf_len, "");
+}
+
+void __printflike(9, 10)
+msg_fmt_prompt_win(msg msg_no, int x, int y, int w, int h,
+ const char *def, char *val, size_t val_buf_len, const char *fmt, ...)
{
va_list ap;
WINDOW *win;
@@ -495,10 +524,10 @@
maxx = getmaxx(msg_win);
maxy = getmaxy(msg_win);
if (w == 0) {
- va_start(ap, val_buf_len);
- w = vsnprintf(NULL, 0, msg_string(msg_no), ap);
+ va_start(ap, fmt);
+ w = vsnprintf(NULL, 0, fmtcheck(msg_string(msg_no), fmt), ap);
va_end(ap);
- if (def != NULL && *def != 0 && w + (int)val_buf_len * 2 < maxx) {
+ if (def != NULL && *def != 0 && w + (int)val_buf_len * 2 < maxx) {
w += 2 + strlen(def) + 1;
msg_flags &= ~MSG_PROMPT_HIDE_DFLT;
}
@@ -561,7 +590,7 @@
msg_clear();
}
- va_start(ap, val_buf_len);
+ va_start(ap, fmt);
_msg_vprompt(msg_string(msg_no), msg_flags, def, val, val_buf_len, ap);
va_end(ap);
@@ -579,35 +608,59 @@
}
}
-void
-msg_prompt_add(msg msg_no, const char *def, char *val, size_t val_buf_len, ...)
+void
+msg_prompt_add(msg msg_no, const char *def, char *val, size_t val_buf_len)
+{
+
+ msg_fmt_prompt_add(msg_no, def, val, val_buf_len, "");
+}
+
+void __printflike(5, 6)
+msg_fmt_prompt_add(msg msg_no, const char *def, char *val, size_t val_buf_len,
+ const char *fmt, ...)
{
va_list ap;
- va_start(ap, val_buf_len);
- _msg_vprompt(msg_string(msg_no), MSG_PROMPT_ECHO, def, val, val_buf_len, ap);
+ va_start(ap, fmt);
+ _msg_vprompt(fmtcheck(msg_string(msg_no), fmt), MSG_PROMPT_ECHO, def,
+ val, val_buf_len, ap);
va_end(ap);
}
void
-msg_prompt_noecho(msg msg_no, const char *def, char *val, size_t val_buf_len, ...)
+msg_prompt_noecho(msg msg_no, const char *def, char *val, size_t val_buf_len)
+{
+ msg_fmt_prompt_noecho(msg_no, def, val, val_buf_len, "");
+}
+
+void __printflike(5, 6)
+msg_fmt_prompt_noecho(msg msg_no, const char *def, char *val,
+ size_t val_buf_len, const char *fmt, ...)
{
va_list ap;
msg_clear();
- va_start(ap, val_buf_len);
- _msg_vprompt(msg_string(msg_no), 0, def, val, val_buf_len, ap);
+ va_start(ap, fmt);
+ _msg_vprompt(fmtcheck(msg_string(msg_no), fmt), 0, def, val,
+ val_buf_len, ap);
va_end(ap);
}
void
-msg_table_add(msg msg_no, ...)
+msg_table_add(msg msg_no)
+{
+
+ msg_printf("%s", msg_string(msg_no));
+}
+
+void __printflike(2, 3)
+msg_fmt_table_add(msg msg_no, const char *fmt, ...)
{
va_list ap;
- va_start(ap, msg_no);
- (void)_msg_vprintf(0, msg_string(msg_no), ap);
+ va_start(ap, fmt);
+ (void)_msg_vprintf(0, fmtcheck(msg_string(msg_no), fmt), ap);
va_end(ap);
}
diff -r b3d2712ea7bf -r 2799e6bc645e usr.bin/msgc/msgdb.c
--- a/usr.bin/msgc/msgdb.c Thu Jun 20 00:43:55 2019 +0000
+++ b/usr.bin/msgc/msgdb.c Thu Jun 20 00:45:18 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: msgdb.c,v 1.23 2012/03/06 16:26:01 mbalmer Exp $ */
+/* $NetBSD: msgdb.c,v 1.24 2019/06/20 00:45:18 christos Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -41,7 +41,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: msgdb.c,v 1.23 2012/03/06 16:26:01 mbalmer Exp $");
+__RCSID("$NetBSD: msgdb.c,v 1.24 2019/06/20 00:45:18 christos Exp $");
#endif
@@ -162,18 +162,44 @@
"void msg_clear(void);\n"
"void msg_standout(void);\n"
"void msg_standend(void);\n"
- "void msg_display(msg msg_no,...);\n"
- "void msg_display_add(msg msg_no,...);\n"
"void msg_printf(const char *fmt, ...) __printflike(1, 2);\n"
- "void msg_prompt (msg msg_no, const char *def,"
- " char *val, size_t max_chars, ...);\n"
- "void msg_prompt_add (msg msg_no, const char *def,"
- " char *val, size_t max_chars, ...);\n"
- "void msg_prompt_noecho (msg msg_no, const char *def,"
- " char *val, size_t max_chars, ...);\n"
- "void msg_prompt_win (msg, int, int, int, int,"
- " const char *, char *, size_t, ...);\n"
- "void msg_table_add(msg msg_no,...);\n"
+ "void msg_display(msg msg_no);\n"
+ "void msg_fmt_display(msg msg_no, const char *fmt, ...)"
+ " __printflike(2, 3);\n"
+
+ "void msg_display_add(msg msg_no);\n"
+ "void msg_fmt_display_add(msg msg_no, const char *fmt, ...);\n"
+
+ "void msg_prompt(msg msg_no, const char *def,"
+ " char *val, size_t max_chars);\n"
+ "void msg_fmt_prompt(msg msg_no, const char *def,"
+ " char *val, size_t max_chars, const char *fmt, ...)"
+ " __printflike(5, 6);\n"
+
+ "void msg_prompt_add(msg msg_no, const char *def,"
+ " char *val, size_t max_chars);\n"
+ "void msg_fmt_prompt_add(msg msg_no, const char *def,"
+ " char *val, size_t max_chars, const char *fmt, ...)"
+ " __printflike(5, 6);\n"
+
+ "void msg_prompt_noecho(msg msg_no, const char *def,"
+ " char *val, size_t max_chars);\n"
+ "void msg_fmt_prompt_noecho(msg msg_no, const char *def,"
+ " char *val, size_t max_chars, const char *fmt, ...)"
+ " __printflike(5, 6);\n"
+
+ "void msg_prompt_win(msg msg_no, int x, int y, int w,"
+ " int h, const char *def, char *val,"
+ " size_t max_chars);\n"
+ "void msg_fmt_prompt_win(msg msg_no, int x, int y, int w,"
+ " int h, const char *def, char *val, size_t max_chars,"
+ " const char *fmt, ...)"
+ " __printflike(9, 10);\n"
+
+ "void msg_table_add(msg msg_no);"
+ "void msg_fmt_table_add(msg msg_no, const char *fmt, ...)"
+ " __printflike(2, 3);\n"
+
"int msg_row(void);\n"
"\n"
"/* Message names */\n"
Home |
Main Index |
Thread Index |
Old Index