[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL 40/48] glib-compat: add 2.38/2.40/2.46 asserts
From: |
marcandre . lureau |
Subject: |
[Qemu-devel] [PULL 40/48] glib-compat: add 2.38/2.40/2.46 asserts |
Date: |
Tue, 6 Oct 2015 21:19:36 +0200 |
From: Marc-André Lureau <address@hidden>
Those are mostly useful for writing tests.
Signed-off-by: Marc-André Lureau <address@hidden>
Reviewed-by: Claudio Fontana <address@hidden>
---
include/glib-compat.h | 61 +++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 61 insertions(+)
diff --git a/include/glib-compat.h b/include/glib-compat.h
index 318e000..fb25f43 100644
--- a/include/glib-compat.h
+++ b/include/glib-compat.h
@@ -165,4 +165,65 @@ static inline GThread *g_thread_new(const char *name,
#define CompatGCond GCond
#endif /* glib 2.31 */
+#ifndef g_assert_true
+#define g_assert_true(expr)
\
+ do {
\
+ if (G_LIKELY(expr)) {
\
+ } else {
\
+ g_assertion_message(G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC,
\
+ "'" #expr "' should be TRUE");
\
+ }
\
+ } while (0)
+#endif
+
+#ifndef g_assert_false
+#define g_assert_false(expr)
\
+ do {
\
+ if (G_LIKELY(!(expr))) {
\
+ } else {
\
+ g_assertion_message(G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC,
\
+ "'" #expr "' should be FALSE");
\
+ }
\
+ } while (0)
+#endif
+
+#ifndef g_assert_null
+#define g_assert_null(expr)
\
+ do {
\
+ if (G_LIKELY((expr) == NULL)) {
\
+ } else {
\
+ g_assertion_message(G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC,
\
+ "'" #expr "' should be NULL");
\
+ }
\
+ } while (0)
+#endif
+
+#ifndef g_assert_nonnull
+#define g_assert_nonnull(expr)
\
+ do {
\
+ if (G_LIKELY((expr) != NULL)) {
\
+ } else {
\
+ g_assertion_message(G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC,
\
+ "'" #expr "' should not be NULL");
\
+ }
\
+ } while (0)
+#endif
+
+#ifndef g_assert_cmpmem
+#define g_assert_cmpmem(m1, l1, m2, l2)
\
+ do {
\
+ gconstpointer __m1 = m1, __m2 = m2;
\
+ int __l1 = l1, __l2 = l2;
\
+ if (__l1 != __l2) {
\
+ g_assertion_message_cmpnum(
\
+ G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC,
\
+ #l1 " (len(" #m1 ")) == " #l2 " (len(" #m2 "))", __l1, "==",
\
+ __l2, 'i');
\
+ } else if (memcmp(__m1, __m2, __l1) != 0) {
\
+ g_assertion_message(G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC,
\
+ "assertion failed (" #m1 " == " #m2 ")");
\
+ }
\
+ } while (0)
+#endif
+
#endif
--
2.4.3
- Re: [Qemu-devel] [PATCH 2/2] ivshmem-test: Implement tests, (continued)
- Re: [Qemu-devel] [PATCH 2/2] ivshmem-test: Implement tests, Andreas Färber, 2015/10/11
- Re: [Qemu-devel] [PULL 00/48] ivshmem series, Paolo Bonzini, 2015/10/08
- Re: [Qemu-devel] [PULL 00/48] ivshmem series, Andrew Jones, 2015/10/08
- Re: [Qemu-devel] [PULL 00/48] ivshmem series, Andreas Färber, 2015/10/08
- Re: [Qemu-devel] [PULL 00/48] ivshmem series, Peter Maydell, 2015/10/08
- Re: [Qemu-devel] [PULL 00/48] ivshmem series, Marc-André Lureau, 2015/10/08
[Qemu-devel] [PULL 01/48] char: add qemu_chr_free(), marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 03/48] ivhsmem: read do not accept more than sizeof(long), marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 04/48] ivshmem: fix number of bytes to push to fifo, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 26/48] ivshmem: add device description, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 40/48] glib-compat: add 2.38/2.40/2.46 asserts,
marcandre . lureau <=
[Qemu-devel] [PULL 46/48] ivshmem: rename MSI eventfd_table, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 27/48] ivshmem: fix pci_ivshmem_exit(), marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 44/48] ivshmem: add hostmem backend, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 41/48] tests: add ivshmem qtest, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 35/48] docs: update ivshmem device spec, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 30/48] ivshmem: reset mask on device reset, marcandre . lureau, 2015/10/08
[Qemu-devel] [PULL 10/48] ivshmem: remove last exit(1), marcandre . lureau, 2015/10/08
Re: [Qemu-devel] [PULL 00/48] ivshmem series, Pavel Fedin, 2015/10/09