diff options
Diffstat (limited to 'cli/src/cli-xml-output.c')
| -rw-r--r-- | cli/src/cli-xml-output.c | 30 | 
1 files changed, 21 insertions, 9 deletions
| diff --git a/cli/src/cli-xml-output.c b/cli/src/cli-xml-output.c index 004ded765..34b046cc9 100644 --- a/cli/src/cli-xml-output.c +++ b/cli/src/cli-xml-output.c @@ -230,15 +230,6 @@ cli_xml_output_vol_status_common (xmlTextWriterPtr writer, dict_t *dict,          XML_RET_CHECK_AND_GOTO (ret, out);          memset (key, 0, sizeof (key)); -        snprintf (key, sizeof (key), "brick%d.port", brick_index); -        ret = dict_get_int32 (dict, key, &port); -        if (ret) -                goto out; -        ret = xmlTextWriterWriteFormatElement (writer, (xmlChar *)"port", -                                               "%d", port); -        XML_RET_CHECK_AND_GOTO (ret, out); - -        memset (key, 0, sizeof (key));          snprintf (key, sizeof (key), "brick%d.status", brick_index);          ret = dict_get_int32 (dict, key, &status);          if (ret) @@ -249,6 +240,27 @@ cli_xml_output_vol_status_common (xmlTextWriterPtr writer, dict_t *dict,          *online = status;          memset (key, 0, sizeof (key)); +        snprintf (key, sizeof (key), "brick%d.port", brick_index); +        ret = dict_get_int32 (dict, key, &port); +        if (ret) +                goto out; + +        /* If the process is either offline or doesn't provide a port (shd) +         * port = "N/A" +         * else print the port number of the process. +         */ + +        if (*online == 1 && port != 0) +                ret = xmlTextWriterWriteFormatElement (writer, +                                                       (xmlChar *)"port", +                                                       "%d", port); +        else +                ret = xmlTextWriterWriteFormatElement (writer, +                                                       (xmlChar *)"port", +                                                       "%s", "N/A"); +        XML_RET_CHECK_AND_GOTO (ret, out); + +        memset (key, 0, sizeof (key));          snprintf (key, sizeof (key), "brick%d.pid", brick_index);          ret = dict_get_int32 (dict, key, &pid);          if (ret) | 
