mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 15:27:47 +00:00
util: refactor function to simplify and remove label
Once the DIR* in virPCIGetName() was made g_autoptr, the cleanup: label just had a "return ret;", but the rest of the function was more compilcated than it needed to be, doing funky things with the value of ret inside multi-level conditionals and a while loop that might exit early via a break with ret == 0 or exit early via a goto cleanup with ret == -1. It really didn't need to be nearly as complicated. After doing the trivial replacements of "goto cleanup" with appropriate direct returns, it became obvious that: 1) the outermost level of the nested conditional at the end of the function ("if (ret < 0)") was now redundant, since ret is now *always* < 0 by that point (otherwise the function has returned). 2) by switching the sense of the next level of the conditional (making it "if (!physPortID)", the "else" (which is now just "return 0;" becomes the "if", and the new "else" no longer needs to be inside the conditional. 3) the value of firstEntryName can be moved into *netname with g_steal_pointer() Once that is all done, ret is no longer used and can be removed. Signed-off-by: Laine Stump <laine@redhat.com> Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
This commit is contained in:
parent
d4f071d39b
commit
77401d549c
@ -2384,7 +2384,6 @@ virPCIGetNetName(const char *device_link_sysfs_path,
|
|||||||
{
|
{
|
||||||
g_autofree char *pcidev_sysfs_net_path = NULL;
|
g_autofree char *pcidev_sysfs_net_path = NULL;
|
||||||
g_autofree char *firstEntryName = NULL;
|
g_autofree char *firstEntryName = NULL;
|
||||||
int ret = -1;
|
|
||||||
g_autoptr(DIR) dir = NULL;
|
g_autoptr(DIR) dir = NULL;
|
||||||
struct dirent *entry = NULL;
|
struct dirent *entry = NULL;
|
||||||
size_t i = 0;
|
size_t i = 0;
|
||||||
@ -2399,8 +2398,7 @@ virPCIGetNetName(const char *device_link_sysfs_path,
|
|||||||
|
|
||||||
if (virDirOpenQuiet(&dir, pcidev_sysfs_net_path) < 0) {
|
if (virDirOpenQuiet(&dir, pcidev_sysfs_net_path) < 0) {
|
||||||
/* this *isn't* an error - caller needs to check for netname == NULL */
|
/* this *isn't* an error - caller needs to check for netname == NULL */
|
||||||
ret = 0;
|
return 0;
|
||||||
goto cleanup;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
while (virDirRead(dir, &entry, pcidev_sysfs_net_path) > 0) {
|
while (virDirRead(dir, &entry, pcidev_sysfs_net_path) > 0) {
|
||||||
@ -2411,7 +2409,7 @@ virPCIGetNetName(const char *device_link_sysfs_path,
|
|||||||
g_autofree char *thisPhysPortID = NULL;
|
g_autofree char *thisPhysPortID = NULL;
|
||||||
|
|
||||||
if (virNetDevGetPhysPortID(entry->d_name, &thisPhysPortID) < 0)
|
if (virNetDevGetPhysPortID(entry->d_name, &thisPhysPortID) < 0)
|
||||||
goto cleanup;
|
return -1;
|
||||||
|
|
||||||
/* if this one doesn't match, keep looking */
|
/* if this one doesn't match, keep looking */
|
||||||
if (STRNEQ_NULLABLE(physPortID, thisPhysPortID)) {
|
if (STRNEQ_NULLABLE(physPortID, thisPhysPortID)) {
|
||||||
@ -2431,34 +2429,27 @@ virPCIGetNetName(const char *device_link_sysfs_path,
|
|||||||
}
|
}
|
||||||
|
|
||||||
*netname = g_strdup(entry->d_name);
|
*netname = g_strdup(entry->d_name);
|
||||||
|
return 0;
|
||||||
ret = 0;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret < 0) {
|
if (!physPortID)
|
||||||
if (physPortID) {
|
return 0;
|
||||||
if (firstEntryName) {
|
|
||||||
/* we didn't match the provided phys_port_id, but this
|
if (firstEntryName) {
|
||||||
* is probably because phys_port_id isn't implemented
|
/* we didn't match the provided phys_port_id, but this
|
||||||
* for this NIC driver, so just return the first
|
* is probably because phys_port_id isn't implemented
|
||||||
* (probably only) netname we found.
|
* for this NIC driver, so just return the first
|
||||||
*/
|
* (probably only) netname we found.
|
||||||
*netname = firstEntryName;
|
*/
|
||||||
firstEntryName = NULL;
|
*netname = g_steal_pointer(&firstEntryName);
|
||||||
ret = 0;
|
return 0;
|
||||||
} else {
|
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
||||||
_("Could not find network device with "
|
|
||||||
"phys_port_id '%s' under PCI device at %s"),
|
|
||||||
physPortID, device_link_sysfs_path);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
ret = 0; /* no netdev at the given index is *not* an error */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
cleanup:
|
|
||||||
return ret;
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
|
_("Could not find network device with "
|
||||||
|
"phys_port_id '%s' under PCI device at %s"),
|
||||||
|
physPortID, device_link_sysfs_path);
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
Loading…
Reference in New Issue
Block a user