]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
bridge: add oneline option
authorStephen Hemminger <stephen@networkplumber.org>
Sat, 16 Mar 2013 17:18:50 +0000 (10:18 -0700)
committerStephen Hemminger <stephen@networkplumber.org>
Sat, 16 Mar 2013 17:18:50 +0000 (10:18 -0700)
Split output of 'bridge link' across multiple lines,
only show the flags if -d is set, and add --oneline option
like ip command.

bridge/bridge.c
bridge/link.c

index 77e260f7960e8024b8c95d345d6f93240dee6daf..ee08f90af987fab659f5685fc096172189310aa4 100644 (file)
 struct rtnl_handle rth = { .fd = -1 };
 int preferred_family = AF_UNSPEC;
 int resolve_hosts;
+int oneline = 0;
 int show_stats;
 int show_details;
 int timestamp;
+char * _SL_ = NULL;
 
 static void usage(void) __attribute__((noreturn));
 
@@ -28,7 +30,8 @@ static void usage(void)
        fprintf(stderr,
 "Usage: bridge [ OPTIONS ] OBJECT { COMMAND | help }\n"
 "where  OBJECT := { link | fdb | mdb | vlan | monitor }\n"
-"       OPTIONS := { -V[ersion] | -s[tatistics] | -d[etails]\n" );
+"       OPTIONS := { -V[ersion] | -s[tatistics] | -d[etails] |\n"
+"                    -o[neline] | -t[imestamp] \n");
        exit(-1);
 }
 
@@ -88,6 +91,8 @@ main(int argc, char **argv)
                        ++show_stats;
                } else if (matches(opt, "-details") == 0) {
                        ++show_details;
+               } else if (matches(opt, "-oneline") == 0) {
+                       ++oneline;
                } else if (matches(opt, "-timestamp") == 0) {
                        ++timestamp;
                 } else if (matches(opt, "-family") == 0) {
@@ -114,6 +119,8 @@ main(int argc, char **argv)
                argc--; argv++;
        }
 
+       _SL_ = oneline ? "\\" : "\n" ;
+
        if (rtnl_open(&rth, 0) < 0)
                exit(1);
 
index 6b5383362673038eb9034c3e7d6443af851a9c12..3188b854f20169c5a10ae944cf6bc47b1000dcbf 100644 (file)
@@ -169,18 +169,23 @@ int print_linkinfo(const struct sockaddr_nl *who,
                        if (prtb[IFLA_BRPORT_COST])
                                fprintf(fp, "cost %u ",
                                        rta_getattr_u32(prtb[IFLA_BRPORT_COST]));
-                       if (prtb[IFLA_BRPORT_MODE])
-                               print_onoff(fp, "hairpin",
-                                           rta_getattr_u8(prtb[IFLA_BRPORT_MODE]));
-                       if (prtb[IFLA_BRPORT_GUARD])
-                               print_onoff(fp, "guard",
-                                           rta_getattr_u8(prtb[IFLA_BRPORT_GUARD]));
-                       if (prtb[IFLA_BRPORT_PROTECT])
-                               print_onoff(fp, "root_block",
-                                           rta_getattr_u8(prtb[IFLA_BRPORT_PROTECT]));
-                       if (prtb[IFLA_BRPORT_FAST_LEAVE])
-                               print_onoff(fp, "fastleave",
-                                           rta_getattr_u8(prtb[IFLA_BRPORT_FAST_LEAVE]));
+
+                       if (show_details) {
+                               fprintf(fp, "%s    ", _SL_);
+
+                               if (prtb[IFLA_BRPORT_MODE])
+                                       print_onoff(fp, "hairpin",
+                                                   rta_getattr_u8(prtb[IFLA_BRPORT_MODE]));
+                               if (prtb[IFLA_BRPORT_GUARD])
+                                       print_onoff(fp, "guard",
+                                                   rta_getattr_u8(prtb[IFLA_BRPORT_GUARD]));
+                               if (prtb[IFLA_BRPORT_PROTECT])
+                                       print_onoff(fp, "root_block",
+                                                   rta_getattr_u8(prtb[IFLA_BRPORT_PROTECT]));
+                               if (prtb[IFLA_BRPORT_FAST_LEAVE])
+                                       print_onoff(fp, "fastleave",
+                                                   rta_getattr_u8(prtb[IFLA_BRPORT_FAST_LEAVE]));
+                       }
                } else
                        print_portstate(fp, rta_getattr_u8(tb[IFLA_PROTINFO]));
        }