* <babeltrace/assert-pre-internal.h>, you also need to use logging
* explicitly.
*/
+
#ifndef BABELTRACE_LIB_LOGGING_INTERNAL_H
# error Include <babeltrace/lib-logging-internal.h> before this header.
#endif
# define BT_ASSERT_PRE(_cond, _fmt, ...) \
do { \
if (!(_cond)) { \
- BT_LOGF_STR("Library precondition not satisfied:"); \
+ BT_LOGF_STR("Library precondition not satisfied; error is:"); \
BT_LIB_LOGF((_fmt), ##__VA_ARGS__); \
BT_LOGF_STR("Aborting..."); \
abort(); \
BT_ASSERT_PRE(!(_obj)->frozen, "%s is frozen" _fmt, _obj_name, \
##__VA_ARGS__)
+/*
+ * Developer mode: asserts that a given index is less than a given size.
+ */
+#define BT_ASSERT_PRE_VALID_INDEX(_index, _length) \
+ BT_ASSERT_PRE((_index) < (_length), \
+ "Index is out of bounds: index=%" PRIu64 ", " \
+ "count=%" PRIu64, (uint64_t) (_index), (uint64_t) (_length))
+
#endif /* BABELTRACE_ASSERT_PRE_INTERNAL_H */