examples: fix 64-bit integer formatting on Windows

The Windows printf functions don't support %llu/%lld for printing 64-bit
integers. For most of libvirt this doesn't matter as we rely on gnulib
which provides a replacement printf that is sane.

The example code is designed to compile against the normal OS headers,
with no use of gnulib and thus has to use the platform specific printf.
To deal with this we must use the macros PRI* macros from inttypes.h
to get the platform specific format string.

Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
Daniel P. Berrangé 2019-04-02 09:45:47 +01:00
parent 86cc922e31
commit 11ea62665c
3 changed files with 12 additions and 6 deletions

View File

@ -3,6 +3,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <time.h> #include <time.h>
#include <string.h> #include <string.h>
#include <inttypes.h>
#include <libvirt/libvirt-admin.h> #include <libvirt/libvirt-admin.h>
static const char * static const char *
@ -66,11 +67,11 @@ exampleGetTypedParamValue(virTypedParameterPtr item)
break; break;
case VIR_TYPED_PARAM_LLONG: case VIR_TYPED_PARAM_LLONG:
ret = asprintf(&str, "%lld", item->value.l); ret = asprintf(&str, "%" PRId64, (int64_t)item->value.l);
break; break;
case VIR_TYPED_PARAM_ULLONG: case VIR_TYPED_PARAM_ULLONG:
ret = asprintf(&str, "%llu", item->value.ul); ret = asprintf(&str, "%" PRIu64, (uint64_t)item->value.ul);
break; break;
case VIR_TYPED_PARAM_DOUBLE: case VIR_TYPED_PARAM_DOUBLE:
@ -143,7 +144,7 @@ int main(int argc, char **argv)
if (!(timestr = exampleGetTimeStr(virAdmClientGetTimestamp(clnt)))) if (!(timestr = exampleGetTimeStr(virAdmClientGetTimestamp(clnt))))
goto cleanup; goto cleanup;
printf("%-15s: %llu\n", "id", virAdmClientGetID(clnt)); printf("%-15s: %" PRIu64 "\n", "id", (uint64_t)virAdmClientGetID(clnt));
printf("%-15s: %s\n", "connection_time", timestr); printf("%-15s: %s\n", "connection_time", timestr);
printf("%-15s: %s\n", "transport", printf("%-15s: %s\n", "transport",
exampleTransportToString(virAdmClientGetTransport(clnt))); exampleTransportToString(virAdmClientGetTransport(clnt)));

View File

@ -1,6 +1,7 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <time.h> #include <time.h>
#include <inttypes.h>
#include <libvirt/libvirt-admin.h> #include <libvirt/libvirt-admin.h>
static const char * static const char *
@ -96,7 +97,7 @@ int main(int argc, char **argv)
exampleGetTimeStr(virAdmClientGetTimestamp(client)))) exampleGetTimeStr(virAdmClientGetTimestamp(client))))
goto cleanup; goto cleanup;
printf(" %-5llu %-15s %-15s\n", id, printf(" %-5" PRIu64 " %-15s %-15s\n", (uint64_t)id,
exampleTransportToString(transport), timestr); exampleTransportToString(transport), timestr);
free(timestr); free(timestr);
} }

View File

@ -29,6 +29,7 @@
#include <string.h> #include <string.h>
#include <sys/time.h> #include <sys/time.h>
#include <unistd.h> #include <unistd.h>
#include <inttypes.h>
static bool debug; static bool debug;
static bool run_top; static bool run_top;
@ -226,8 +227,11 @@ print_cpu_usage(const char *dom_name,
return; return;
} }
DEBUG("now_params=%llu then_params=%llu now=%llu then=%llu", DEBUG("now_params=%" PRIu64 " then_params=%" PRIu64
now_params[pos].value.ul, then_params[pos].value.ul, now, then); " now=%" PRIu64 " then=%" PRIu64,
(uint64_t)now_params[pos].value.ul,
(uint64_t)then_params[pos].value.ul,
(uint64_t)now, (uint64_t)then);
/* @now_params and @then_params are in nanoseconds, @now and @then are /* @now_params and @then_params are in nanoseconds, @now and @then are
* in microseconds. In ideal world, we would translate them both into * in microseconds. In ideal world, we would translate them both into