[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20200727162009.7618-1-julien@cumulusnetworks.com>
Date: Mon, 27 Jul 2020 18:20:09 +0200
From: Julien Fortin <julien@...ulusnetworks.com>
To: netdev@...r.kernel.org
Cc: roopa@...ulusnetworks.com, dsahern@...il.com,
Julien Fortin <julien@...ulusnetworks.com>
Subject: [PATCH iproute2-next master v2] bridge: fdb show: fix fdb entry state output (+ add json support)
From: Julien Fortin <julien@...ulusnetworks.com>
bridge json fdb show is printing an incorrect / non-machine readable
value, when using -j (json output) we are expecting machine readable
data that shouldn't require special handling/parsing.
$ bridge -j fdb show | \
python -c \
'import sys,json;print(json.dumps(json.loads(sys.stdin.read()),indent=4))'
[
{
"master": "br0",
"mac": "56:23:28:4f:4f:e5",
"flags": [],
"ifname": "vx0",
"state": "state=0x80" <<<<<<<<< with the patch: "state": "0x80"
}
]
This patch also fixes the non-json output, from:
state=0x42
to:
state 0x42
This will only be displayed if the FDB entry has an unknown value.
Fixes: c7c1a1ef51aea7c ("bridge: colorize output and use JSON print library")
Signed-off-by: Julien Fortin <julien@...ulusnetworks.com>
---
bridge/fdb.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bridge/fdb.c b/bridge/fdb.c
index d1f8afbe..765f4e51 100644
--- a/bridge/fdb.c
+++ b/bridge/fdb.c
@@ -62,7 +62,10 @@ static const char *state_n2a(unsigned int s)
if (s & NUD_REACHABLE)
return "";
- sprintf(buf, "state=%#x", s);
+ if (is_json_context())
+ sprintf(buf, "%#x", s);
+ else
+ sprintf(buf, "state %#x", s);
return buf;
}
--
2.27.0
Powered by blists - more mailing lists