提交 ff1efc09 编写于 作者: L Laine Stump

conf: simplify Buffer Indentation in virDomainNetDefFormat

This function has several calls to increase the buffer indent by 6,
then decrease it again, then increase, then decrease. Additionally,
there were several printfs that had 6 spaces at the beginning of the
line.

virDomainActualNetDefFormat, which is called by virDomainNetDefFormat,
had similar ugliness.

This patch changes both functions to just increase the indent at the
beginning, decrease it at (well, just before*) the end, and remove all
of the occurences of 6/8 spaces at the beginning of lines.

*The indent had to be reset before the end of the function because
virDomainDeviceInfoFormat assumes a 0 indent and is called from many
other places, and I didn't want to do an overhaul of every caller of
that function. A separate patch to switch all of domain_conf.c would
be a useful exercise, but my current goal is unrelated to that, so
I'll leave it for another day.
上级 2841a0ad
...@@ -11559,21 +11559,22 @@ virDomainActualNetDefFormat(virBufferPtr buf, ...@@ -11559,21 +11559,22 @@ virDomainActualNetDefFormat(virBufferPtr buf,
return -1; return -1;
} }
virBufferAsprintf(buf, " <actual type='%s'", type); virBufferAsprintf(buf, "<actual type='%s'", type);
if (def->type == VIR_DOMAIN_NET_TYPE_HOSTDEV && if (def->type == VIR_DOMAIN_NET_TYPE_HOSTDEV &&
def->data.hostdev.def.managed) { def->data.hostdev.def.managed) {
virBufferAddLit(buf, " managed='yes'"); virBufferAddLit(buf, " managed='yes'");
} }
virBufferAddLit(buf, ">\n"); virBufferAddLit(buf, ">\n");
virBufferAdjustIndent(buf, 2);
switch (def->type) { switch (def->type) {
case VIR_DOMAIN_NET_TYPE_BRIDGE: case VIR_DOMAIN_NET_TYPE_BRIDGE:
virBufferEscapeString(buf, " <source bridge='%s'/>\n", virBufferEscapeString(buf, "<source bridge='%s'/>\n",
def->data.bridge.brname); def->data.bridge.brname);
break; break;
case VIR_DOMAIN_NET_TYPE_DIRECT: case VIR_DOMAIN_NET_TYPE_DIRECT:
virBufferAddLit(buf, " <source"); virBufferAddLit(buf, "<source");
if (def->data.direct.linkdev) if (def->data.direct.linkdev)
virBufferEscapeString(buf, " dev='%s'", virBufferEscapeString(buf, " dev='%s'",
def->data.direct.linkdev); def->data.direct.linkdev);
...@@ -11589,12 +11590,10 @@ virDomainActualNetDefFormat(virBufferPtr buf, ...@@ -11589,12 +11590,10 @@ virDomainActualNetDefFormat(virBufferPtr buf,
break; break;
case VIR_DOMAIN_NET_TYPE_HOSTDEV: case VIR_DOMAIN_NET_TYPE_HOSTDEV:
virBufferAdjustIndent(buf, 8);
if (virDomainHostdevSourceFormat(buf, &def->data.hostdev.def, if (virDomainHostdevSourceFormat(buf, &def->data.hostdev.def,
flags, true) < 0) { flags, true) < 0) {
return -1; return -1;
} }
virBufferAdjustIndent(buf, -8);
break; break;
case VIR_DOMAIN_NET_TYPE_NETWORK: case VIR_DOMAIN_NET_TYPE_NETWORK:
...@@ -11605,14 +11604,13 @@ virDomainActualNetDefFormat(virBufferPtr buf, ...@@ -11605,14 +11604,13 @@ virDomainActualNetDefFormat(virBufferPtr buf,
return -1; return -1;
} }
virBufferAdjustIndent(buf, 8);
if (virNetDevVPortProfileFormat(def->virtPortProfile, buf) < 0) if (virNetDevVPortProfileFormat(def->virtPortProfile, buf) < 0)
return -1; return -1;
if (virNetDevBandwidthFormat(def->bandwidth, buf) < 0) if (virNetDevBandwidthFormat(def->bandwidth, buf) < 0)
return -1; return -1;
virBufferAdjustIndent(buf, -8);
virBufferAddLit(buf, " </actual>\n"); virBufferAdjustIndent(buf, -2);
virBufferAddLit(buf, "</actual>\n");
return 0; return 0;
} }
...@@ -11636,14 +11634,15 @@ virDomainNetDefFormat(virBufferPtr buf, ...@@ -11636,14 +11634,15 @@ virDomainNetDefFormat(virBufferPtr buf,
} }
virBufferAddLit(buf, ">\n"); virBufferAddLit(buf, ">\n");
virBufferAdjustIndent(buf, 6);
virBufferAsprintf(buf, virBufferAsprintf(buf,
" <mac address='%02x:%02x:%02x:%02x:%02x:%02x'/>\n", "<mac address='%02x:%02x:%02x:%02x:%02x:%02x'/>\n",
def->mac.addr[0], def->mac.addr[1], def->mac.addr[2], def->mac.addr[0], def->mac.addr[1], def->mac.addr[2],
def->mac.addr[3], def->mac.addr[4], def->mac.addr[5]); def->mac.addr[3], def->mac.addr[4], def->mac.addr[5]);
switch (def->type) { switch (def->type) {
case VIR_DOMAIN_NET_TYPE_NETWORK: case VIR_DOMAIN_NET_TYPE_NETWORK:
virBufferEscapeString(buf, " <source network='%s'", virBufferEscapeString(buf, "<source network='%s'",
def->data.network.name); def->data.network.name);
virBufferEscapeString(buf, " portgroup='%s'", virBufferEscapeString(buf, " portgroup='%s'",
def->data.network.portgroup); def->data.network.portgroup);
...@@ -11654,39 +11653,41 @@ virDomainNetDefFormat(virBufferPtr buf, ...@@ -11654,39 +11653,41 @@ virDomainNetDefFormat(virBufferPtr buf,
break; break;
case VIR_DOMAIN_NET_TYPE_ETHERNET: case VIR_DOMAIN_NET_TYPE_ETHERNET:
virBufferEscapeString(buf, " <source dev='%s'/>\n", virBufferEscapeString(buf, "<source dev='%s'/>\n",
def->data.ethernet.dev); def->data.ethernet.dev);
if (def->data.ethernet.ipaddr) if (def->data.ethernet.ipaddr)
virBufferAsprintf(buf, " <ip address='%s'/>\n", virBufferAsprintf(buf, "<ip address='%s'/>\n",
def->data.ethernet.ipaddr); def->data.ethernet.ipaddr);
break; break;
case VIR_DOMAIN_NET_TYPE_BRIDGE: case VIR_DOMAIN_NET_TYPE_BRIDGE:
virBufferEscapeString(buf, " <source bridge='%s'/>\n", virBufferEscapeString(buf, "<source bridge='%s'/>\n",
def->data.bridge.brname); def->data.bridge.brname);
if (def->data.bridge.ipaddr) if (def->data.bridge.ipaddr) {
virBufferAsprintf(buf, " <ip address='%s'/>\n", virBufferAsprintf(buf, "<ip address='%s'/>\n",
def->data.bridge.ipaddr); def->data.bridge.ipaddr);
}
break; break;
case VIR_DOMAIN_NET_TYPE_SERVER: case VIR_DOMAIN_NET_TYPE_SERVER:
case VIR_DOMAIN_NET_TYPE_CLIENT: case VIR_DOMAIN_NET_TYPE_CLIENT:
case VIR_DOMAIN_NET_TYPE_MCAST: case VIR_DOMAIN_NET_TYPE_MCAST:
if (def->data.socket.address) if (def->data.socket.address) {
virBufferAsprintf(buf, " <source address='%s' port='%d'/>\n", virBufferAsprintf(buf, "<source address='%s' port='%d'/>\n",
def->data.socket.address, def->data.socket.port); def->data.socket.address, def->data.socket.port);
else } else {
virBufferAsprintf(buf, " <source port='%d'/>\n", virBufferAsprintf(buf, "<source port='%d'/>\n",
def->data.socket.port); def->data.socket.port);
}
break; break;
case VIR_DOMAIN_NET_TYPE_INTERNAL: case VIR_DOMAIN_NET_TYPE_INTERNAL:
virBufferEscapeString(buf, " <source name='%s'/>\n", virBufferEscapeString(buf, "<source name='%s'/>\n",
def->data.internal.name); def->data.internal.name);
break; break;
case VIR_DOMAIN_NET_TYPE_DIRECT: case VIR_DOMAIN_NET_TYPE_DIRECT:
virBufferEscapeString(buf, " <source dev='%s'", virBufferEscapeString(buf, "<source dev='%s'",
def->data.direct.linkdev); def->data.direct.linkdev);
virBufferAsprintf(buf, " mode='%s'", virBufferAsprintf(buf, " mode='%s'",
virNetDevMacVLanModeTypeToString(def->data.direct.mode)); virNetDevMacVLanModeTypeToString(def->data.direct.mode));
...@@ -11694,12 +11695,10 @@ virDomainNetDefFormat(virBufferPtr buf, ...@@ -11694,12 +11695,10 @@ virDomainNetDefFormat(virBufferPtr buf,
break; break;
case VIR_DOMAIN_NET_TYPE_HOSTDEV: case VIR_DOMAIN_NET_TYPE_HOSTDEV:
virBufferAdjustIndent(buf, 6);
if (virDomainHostdevSourceFormat(buf, &def->data.hostdev.def, if (virDomainHostdevSourceFormat(buf, &def->data.hostdev.def,
flags, true) < 0) { flags, true) < 0) {
return -1; return -1;
} }
virBufferAdjustIndent(buf, -6);
break; break;
case VIR_DOMAIN_NET_TYPE_USER: case VIR_DOMAIN_NET_TYPE_USER:
...@@ -11707,26 +11706,22 @@ virDomainNetDefFormat(virBufferPtr buf, ...@@ -11707,26 +11706,22 @@ virDomainNetDefFormat(virBufferPtr buf,
break; break;
} }
virBufferAdjustIndent(buf, 6);
if (virNetDevVPortProfileFormat(def->virtPortProfile, buf) < 0) if (virNetDevVPortProfileFormat(def->virtPortProfile, buf) < 0)
return -1; return -1;
virBufferAdjustIndent(buf, -6); virBufferEscapeString(buf, "<script path='%s'/>\n",
virBufferEscapeString(buf, " <script path='%s'/>\n",
def->script); def->script);
if (def->ifname && if (def->ifname &&
!((flags & VIR_DOMAIN_XML_INACTIVE) && !((flags & VIR_DOMAIN_XML_INACTIVE) &&
(STRPREFIX(def->ifname, VIR_NET_GENERATED_PREFIX)))) { (STRPREFIX(def->ifname, VIR_NET_GENERATED_PREFIX)))) {
/* Skip auto-generated target names for inactive config. */ /* Skip auto-generated target names for inactive config. */
virBufferEscapeString(buf, " <target dev='%s'/>\n", virBufferEscapeString(buf, "<target dev='%s'/>\n", def->ifname);
def->ifname);
} }
if (def->model) { if (def->model) {
virBufferEscapeString(buf, " <model type='%s'/>\n", virBufferEscapeString(buf, "<model type='%s'/>\n",
def->model); def->model);
if (STREQ(def->model, "virtio") && if (STREQ(def->model, "virtio") &&
(def->driver.virtio.name || def->driver.virtio.txmode)) { (def->driver.virtio.name || def->driver.virtio.txmode)) {
virBufferAddLit(buf, " <driver"); virBufferAddLit(buf, "<driver");
if (def->driver.virtio.name) { if (def->driver.virtio.name) {
virBufferAsprintf(buf, " name='%s'", virBufferAsprintf(buf, " name='%s'",
virDomainNetBackendTypeToString(def->driver.virtio.name)); virDomainNetBackendTypeToString(def->driver.virtio.name));
...@@ -11747,27 +11742,25 @@ virDomainNetDefFormat(virBufferPtr buf, ...@@ -11747,27 +11742,25 @@ virDomainNetDefFormat(virBufferPtr buf,
} }
} }
if (def->filter) { if (def->filter) {
virBufferAdjustIndent(buf, 6);
if (virNWFilterFormatParamAttributes(buf, def->filterparams, if (virNWFilterFormatParamAttributes(buf, def->filterparams,
def->filter) < 0) def->filter) < 0)
return -1; return -1;
virBufferAdjustIndent(buf, -6);
} }
if (def->tune.sndbuf_specified) { if (def->tune.sndbuf_specified) {
virBufferAddLit(buf, " <tune>\n"); virBufferAddLit(buf, "<tune>\n");
virBufferAsprintf(buf, " <sndbuf>%lu</sndbuf>\n", virBufferAsprintf(buf, " <sndbuf>%lu</sndbuf>\n", def->tune.sndbuf);
def->tune.sndbuf); virBufferAddLit(buf, "</tune>\n");
virBufferAddLit(buf, " </tune>\n");
} }
if (def->linkstate) if (def->linkstate) {
virBufferAsprintf(buf, " <link state='%s'/>\n", virBufferAsprintf(buf, "<link state='%s'/>\n",
virDomainNetInterfaceLinkStateTypeToString(def->linkstate)); virDomainNetInterfaceLinkStateTypeToString(def->linkstate));
}
virBufferAdjustIndent(buf, 6);
if (virNetDevBandwidthFormat(def->bandwidth, buf) < 0) if (virNetDevBandwidthFormat(def->bandwidth, buf) < 0)
return -1; return -1;
virBufferAdjustIndent(buf, -6); virBufferAdjustIndent(buf, -6);
if (virDomainDeviceInfoFormat(buf, &def->info, if (virDomainDeviceInfoFormat(buf, &def->info,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册