summaryrefslogtreecommitdiffstats
path: root/src/basic/format-util.c
diff options
context:
space:
mode:
authorYu Watanabe <watanabe.yu+github@gmail.com>2019-09-08 12:42:32 +0200
committerYu Watanabe <watanabe.yu+github@gmail.com>2019-10-24 07:20:48 +0200
commit882e21c72ff93795467cdd7e83a597a9cab1f2ea (patch)
tree4f7d792a967611ced5a13bdd226808f22e1e0b14 /src/basic/format-util.c
parentnetwork: introduce Reconfigure() bus method (diff)
downloadsystemd-882e21c72ff93795467cdd7e83a597a9cab1f2ea.tar.xz
systemd-882e21c72ff93795467cdd7e83a597a9cab1f2ea.zip
format-util: introduce format_ifname_full()
Diffstat (limited to 'src/basic/format-util.c')
-rw-r--r--src/basic/format-util.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/src/basic/format-util.c b/src/basic/format-util.c
index aec929a06a..9fea2e0690 100644
--- a/src/basic/format-util.c
+++ b/src/basic/format-util.c
@@ -4,11 +4,24 @@
#include "format-util.h"
#include "memory-util.h"
+#include "stdio-util.h"
-char *format_ifname(int ifindex, char buf[static IF_NAMESIZE + 1]) {
+assert_cc(DECIMAL_STR_MAX(int) + 1 <= IF_NAMESIZE + 1);
+char *format_ifname_full(int ifindex, char buf[static IF_NAMESIZE + 1], FormatIfnameFlag flag) {
/* Buffer is always cleared */
memzero(buf, IF_NAMESIZE + 1);
- return if_indextoname(ifindex, buf);
+ if (if_indextoname(ifindex, buf))
+ return buf;
+
+ if (!FLAGS_SET(flag, FORMAT_IFNAME_IFINDEX))
+ return NULL;
+
+ if (FLAGS_SET(flag, FORMAT_IFNAME_IFINDEX_WITH_PERCENT))
+ snprintf(buf, IF_NAMESIZE + 1, "%%%d", ifindex);
+ else
+ snprintf(buf, IF_NAMESIZE + 1, "%d", ifindex);
+
+ return buf;
}
char *format_bytes_full(char *buf, size_t l, uint64_t t, FormatBytesFlag flag) {