* SOFTWARE.
*/
+#define BT_LOG_TAG "VALUES"
+#include <babeltrace/lib-logging-internal.h>
+
#include <stdlib.h>
#include <string.h>
#include <assert.h>
#include <string.h>
-#include <babeltrace/compiler.h>
-#include <babeltrace/object-internal.h>
+#include <inttypes.h>
+#include <babeltrace/compiler-internal.h>
#include <babeltrace/ref.h>
#include <babeltrace/values.h>
-#include <babeltrace/compat/glib.h>
+#include <babeltrace/compat/glib-internal.h>
+#include <babeltrace/types.h>
+#include <babeltrace/object-internal.h>
+#include <babeltrace/values-internal.h>
#define BT_VALUE_FROM_CONCRETE(_concrete) ((struct bt_value *) (_concrete))
#define BT_VALUE_TO_BOOL(_base) ((struct bt_value_bool *) (_base))
struct bt_value {
struct bt_object base;
enum bt_value_type type;
- bool is_frozen;
+ bt_bool is_frozen;
};
static
struct bt_value bt_value_null_instance = {
+ .base = {
+ .ref_count = {
+ .count = 1,
+ .release = NULL,
+ },
+ .release = NULL,
+ .parent = NULL,
+ },
.type = BT_VALUE_TYPE_NULL,
- .is_frozen = true,
+ .is_frozen = BT_TRUE,
};
struct bt_value *bt_value_null = &bt_value_null_instance;
struct bt_value_bool {
struct bt_value base;
- bool value;
+ bt_bool value;
};
struct bt_value_integer {
struct bt_value *copy_obj;
struct bt_value_array *typed_array_obj;
+ BT_LOGD("Copying array value: addr=%p", array_obj);
typed_array_obj = BT_VALUE_TO_ARRAY(array_obj);
copy_obj = bt_value_array_create();
if (!copy_obj) {
+ BT_LOGE_STR("Cannot create empty array value.");
goto end;
}
struct bt_value *element_obj_copy;
struct bt_value *element_obj = bt_value_array_get(array_obj, i);
- if (!element_obj) {
- BT_PUT(copy_obj);
- goto end;
- }
-
+ assert(element_obj);
+ BT_LOGD("Copying array value's element: element-addr=%p, "
+ "index=%d", element_obj, i);
element_obj_copy = bt_value_copy(element_obj);
BT_PUT(element_obj);
-
if (!element_obj_copy) {
+ BT_LOGE("Cannot copy array value's element: "
+ "array-addr=%p, index=%d",
+ array_obj, i);
BT_PUT(copy_obj);
goto end;
}
ret = bt_value_array_append(copy_obj, element_obj_copy);
BT_PUT(element_obj_copy);
-
if (ret) {
+ BT_LOGE("Cannot append to array value: addr=%p",
+ array_obj);
BT_PUT(copy_obj);
goto end;
}
}
+ BT_LOGD("Copied array value: original-addr=%p, copy-addr=%p",
+ array_obj, copy_obj);
+
end:
return copy_obj;
}
struct bt_value *element_obj_copy;
struct bt_value_map *typed_map_obj;
+ BT_LOGD("Copying map value: addr=%p", map_obj);
typed_map_obj = BT_VALUE_TO_MAP(map_obj);
copy_obj = bt_value_map_create();
while (g_hash_table_iter_next(&iter, &key, &element_obj)) {
const char *key_str = g_quark_to_string(GPOINTER_TO_UINT(key));
+ assert(key_str);
+ BT_LOGD("Copying map value's element: element-addr=%p, "
+ "key=\"%s\"", element_obj, key_str);
element_obj_copy = bt_value_copy(element_obj);
-
if (!element_obj_copy) {
+ BT_LOGE("Cannot copy map value's element: "
+ "map-addr=%p, key=\"%s\"",
+ map_obj, key_str);
BT_PUT(copy_obj);
goto end;
}
ret = bt_value_map_insert(copy_obj, key_str, element_obj_copy);
BT_PUT(element_obj_copy);
-
if (ret) {
+ BT_LOGE("Cannot insert into map value: addr=%p, key=\"%s\"",
+ map_obj, key_str);
BT_PUT(copy_obj);
goto end;
}
}
+ BT_LOGD("Copied map value: addr=%p", map_obj);
+
end:
return copy_obj;
}
};
static
-bool bt_value_null_compare(const struct bt_value *object_a,
+bt_bool bt_value_null_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
/*
- * Always true since bt_value_compare() already checks if both
+ * Always BT_TRUE since bt_value_compare() already checks if both
* object_a and object_b have the same type, and in the case of
* null value objects, they're always the same if it is so.
*/
- return true;
+ return BT_TRUE;
}
static
-bool bt_value_bool_compare(const struct bt_value *object_a,
+bt_bool bt_value_bool_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
- return BT_VALUE_TO_BOOL(object_a)->value ==
- BT_VALUE_TO_BOOL(object_b)->value;
+ if (BT_VALUE_TO_BOOL(object_a)->value !=
+ BT_VALUE_TO_BOOL(object_b)->value) {
+ BT_LOGV("Boolean value objects are different: "
+ "bool-a-val=%d, bool-b-val=%d",
+ BT_VALUE_TO_BOOL(object_a)->value,
+ BT_VALUE_TO_BOOL(object_b)->value);
+ return BT_FALSE;
+ }
+
+ return BT_TRUE;
}
static
-bool bt_value_integer_compare(const struct bt_value *object_a,
+bt_bool bt_value_integer_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
- return BT_VALUE_TO_INTEGER(object_a)->value ==
- BT_VALUE_TO_INTEGER(object_b)->value;
+ if (BT_VALUE_TO_INTEGER(object_a)->value !=
+ BT_VALUE_TO_INTEGER(object_b)->value) {
+ BT_LOGV("Integer value objects are different: "
+ "int-a-val=%" PRId64 ", int-b-val=%" PRId64,
+ BT_VALUE_TO_INTEGER(object_a)->value,
+ BT_VALUE_TO_INTEGER(object_b)->value);
+ return BT_FALSE;
+ }
+
+ return BT_TRUE;
}
static
-bool bt_value_float_compare(const struct bt_value *object_a,
+bt_bool bt_value_float_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
- return BT_VALUE_TO_FLOAT(object_a)->value ==
- BT_VALUE_TO_FLOAT(object_b)->value;
+ if (BT_VALUE_TO_FLOAT(object_a)->value !=
+ BT_VALUE_TO_FLOAT(object_b)->value) {
+ BT_LOGV("Floating point number value objects are different: "
+ "float-a-val=%f, float-b-val=%f",
+ BT_VALUE_TO_FLOAT(object_a)->value,
+ BT_VALUE_TO_FLOAT(object_b)->value);
+ return BT_FALSE;
+ }
+
+ return BT_TRUE;
}
static
-bool bt_value_string_compare(const struct bt_value *object_a,
+bt_bool bt_value_string_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
- return !strcmp(BT_VALUE_TO_STRING(object_a)->gstr->str,
- BT_VALUE_TO_STRING(object_b)->gstr->str);
+ if (strcmp(BT_VALUE_TO_STRING(object_a)->gstr->str,
+ BT_VALUE_TO_STRING(object_b)->gstr->str) != 0) {
+ BT_LOGV("String value objects are different: "
+ "string-a-val=\"%s\", string-b-val=\"%s\"",
+ BT_VALUE_TO_STRING(object_a)->gstr->str,
+ BT_VALUE_TO_STRING(object_b)->gstr->str);
+ return BT_FALSE;
+ }
+
+ return BT_TRUE;
}
static
-bool bt_value_array_compare(const struct bt_value *object_a,
+bt_bool bt_value_array_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
int i;
- bool ret = true;
+ bt_bool ret = BT_TRUE;
const struct bt_value_array *array_obj_a =
BT_VALUE_TO_ARRAY(object_a);
if (bt_value_array_size(object_a) != bt_value_array_size(object_b)) {
- ret = false;
+ BT_LOGV("Array values are different: size mismatch "
+ "value-a-addr=%p, value-b-addr=%p, "
+ "value-a-size=%" PRId64 ", value-b-size=%" PRId64,
+ object_a, object_b,
+ bt_value_array_size(object_a),
+ bt_value_array_size(object_b));
+ ret = BT_FALSE;
goto end;
}
element_obj_b = bt_value_array_get(object_b, i);
if (!bt_value_compare(element_obj_a, element_obj_b)) {
+ BT_LOGV("Array values's elements are different: "
+ "value-a-addr=%p, value-b-addr=%p, index=%d",
+ element_obj_a, element_obj_b, i);
BT_PUT(element_obj_a);
BT_PUT(element_obj_b);
- ret = false;
+ ret = BT_FALSE;
goto end;
}
}
static
-bool bt_value_map_compare(const struct bt_value *object_a,
+bt_bool bt_value_map_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
- bool ret = true;
+ bt_bool ret = BT_TRUE;
GHashTableIter iter;
gpointer key, element_obj_a;
const struct bt_value_map *map_obj_a = BT_VALUE_TO_MAP(object_a);
if (bt_value_map_size(object_a) != bt_value_map_size(object_b)) {
- ret = false;
+ BT_LOGV("Map values are different: size mismatch "
+ "value-a-addr=%p, value-b-addr=%p, "
+ "value-a-size=%" PRId64 ", value-b-size=%" PRId64,
+ object_a, object_b,
+ bt_value_map_size(object_a),
+ bt_value_map_size(object_b));
+ ret = BT_FALSE;
goto end;
}
element_obj_b = bt_value_map_get(object_b, key_str);
if (!bt_value_compare(element_obj_a, element_obj_b)) {
+ BT_LOGV("Map values's elements are different: "
+ "value-a-addr=%p, value-b-addr=%p, key=\"%s\"",
+ element_obj_a, element_obj_b, key_str);
BT_PUT(element_obj_b);
- ret = false;
+ ret = BT_FALSE;
goto end;
}
}
static
-bool (* const compare_funcs[])(const struct bt_value *,
+bt_bool (* const compare_funcs[])(const struct bt_value *,
const struct bt_value *) = {
[BT_VALUE_TYPE_NULL] = bt_value_null_compare,
[BT_VALUE_TYPE_BOOL] = bt_value_bool_compare,
[BT_VALUE_TYPE_INTEGER] = bt_value_integer_compare,
- [BT_VALUE_TYPE_FLOAT] = bt_value_float_compare,
+ [BT_VALUE_TYPE_FLOAT] = bt_value_float_compare,
[BT_VALUE_TYPE_STRING] = bt_value_string_compare,
- [BT_VALUE_TYPE_ARRAY] = bt_value_array_compare,
+ [BT_VALUE_TYPE_ARRAY] = bt_value_array_compare,
[BT_VALUE_TYPE_MAP] = bt_value_map_compare,
};
void bt_value_generic_freeze(struct bt_value *object)
{
- object->is_frozen = true;
+ object->is_frozen = BT_TRUE;
}
void bt_value_array_freeze(struct bt_value *object)
value = container_of(obj, struct bt_value, base);
assert(value->type != BT_VALUE_TYPE_UNKNOWN);
+ BT_LOGD("Destroying value: addr=%p", value);
if (bt_value_is_null(value)) {
+ BT_LOGD_STR("Not destroying the null value singleton.");
return;
}
enum bt_value_status ret = BT_VALUE_STATUS_OK;
if (!object) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
+ if (object->is_frozen) {
+ goto end;
+ }
+
+ BT_LOGD("Freezing value: addr=%p", object);
freeze_funcs[object->type](object);
end:
return ret;
}
-bool bt_value_is_frozen(const struct bt_value *object)
+bt_bool bt_value_is_frozen(const struct bt_value *object)
{
return object && object->is_frozen;
}
enum bt_value_type bt_value_get_type(const struct bt_value *object)
{
if (!object) {
+ /*
+ * Not an error: user can test NULL value object with
+ * this function.
+ */
+ BT_LOGV_STR("Value object is NULL.");
return BT_VALUE_TYPE_UNKNOWN;
}
struct bt_value base;
base.type = type;
- base.is_frozen = false;
+ base.is_frozen = BT_FALSE;
bt_object_init(&base, bt_value_destroy);
-
return base;
}
-struct bt_value *bt_value_bool_create_init(bool val)
+struct bt_value *bt_value_bool_create_init(bt_bool val)
{
struct bt_value_bool *bool_obj;
+ BT_LOGD("Creating boolean value object: val=%d", val);
bool_obj = g_new0(struct bt_value_bool, 1);
if (!bool_obj) {
+ BT_LOGE_STR("Failed to allocate one boolean value object.");
goto end;
}
bool_obj->base = bt_value_create_base(BT_VALUE_TYPE_BOOL);
bool_obj->value = val;
+ BT_LOGD("Created boolean value object: addr=%p", bool_obj);
end:
return BT_VALUE_FROM_CONCRETE(bool_obj);
struct bt_value *bt_value_bool_create(void)
{
- return bt_value_bool_create_init(false);
+ return bt_value_bool_create_init(BT_FALSE);
}
struct bt_value *bt_value_integer_create_init(int64_t val)
{
struct bt_value_integer *integer_obj;
+ BT_LOGD("Creating integer value object: val=%" PRId64, val);
integer_obj = g_new0(struct bt_value_integer, 1);
if (!integer_obj) {
+ BT_LOGE_STR("Failed to allocate one integer value object.");
goto end;
}
integer_obj->base = bt_value_create_base(BT_VALUE_TYPE_INTEGER);
integer_obj->value = val;
+ BT_LOGD("Created integer value object: addr=%p",
+ integer_obj);
end:
return BT_VALUE_FROM_CONCRETE(integer_obj);
{
struct bt_value_float *float_obj;
+ BT_LOGD("Creating floating point number value object: val=%f", val);
float_obj = g_new0(struct bt_value_float, 1);
if (!float_obj) {
+ BT_LOGE_STR("Failed to allocate one floating point number value object.");
goto end;
}
float_obj->base = bt_value_create_base(BT_VALUE_TYPE_FLOAT);
float_obj->value = val;
+ BT_LOGD("Created floating point number value object: addr=%p",
+ float_obj);
end:
return BT_VALUE_FROM_CONCRETE(float_obj);
struct bt_value_string *string_obj = NULL;
if (!val) {
+ BT_LOGW_STR("Invalid parameter: value is NULL.");
goto end;
}
+ BT_LOGD("Creating string value object: val-len=%zu", strlen(val));
string_obj = g_new0(struct bt_value_string, 1);
if (!string_obj) {
+ BT_LOGE_STR("Failed to allocate one string object.");
goto end;
}
string_obj->gstr = g_string_new(val);
if (!string_obj->gstr) {
+ BT_LOGE_STR("Failed to allocate a GString.");
g_free(string_obj);
string_obj = NULL;
goto end;
}
+ BT_LOGD("Created string value object: addr=%p",
+ string_obj);
+
end:
return BT_VALUE_FROM_CONCRETE(string_obj);
}
{
struct bt_value_array *array_obj;
+ BT_LOGD_STR("Creating empty array value object.");
array_obj = g_new0(struct bt_value_array, 1);
if (!array_obj) {
+ BT_LOGE_STR("Failed to allocate one array object.");
goto end;
}
(GDestroyNotify) bt_put);
if (!array_obj->garray) {
+ BT_LOGE_STR("Failed to allocate a GPtrArray.");
g_free(array_obj);
array_obj = NULL;
goto end;
}
+ BT_LOGD("Created array value object: addr=%p",
+ array_obj);
+
end:
return BT_VALUE_FROM_CONCRETE(array_obj);
}
{
struct bt_value_map *map_obj;
+ BT_LOGD_STR("Creating empty map value object.");
map_obj = g_new0(struct bt_value_map, 1);
if (!map_obj) {
+ BT_LOGE_STR("Failed to allocate one map object.");
goto end;
}
NULL, (GDestroyNotify) bt_put);
if (!map_obj->ght) {
+ BT_LOGE_STR("Failed to allocate a GHashTable.");
g_free(map_obj);
map_obj = NULL;
goto end;
}
+ BT_LOGD("Created map value object: addr=%p",
+ map_obj);
+
end:
return BT_VALUE_FROM_CONCRETE(map_obj);
}
enum bt_value_status bt_value_bool_get(const struct bt_value *bool_obj,
- bool *val)
+ bt_bool *val)
{
enum bt_value_status ret = BT_VALUE_STATUS_OK;
struct bt_value_bool *typed_bool_obj = BT_VALUE_TO_BOOL(bool_obj);
- if (!bool_obj || !bt_value_is_bool(bool_obj) || !val) {
+ if (!bool_obj || !val) {
+ BT_LOGW("Invalid parameter: value object or value is NULL: "
+ "value-addr=%p, raw-value-addr=%p",
+ bool_obj, val);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_bool(bool_obj)) {
+ BT_LOGW("Invalid parameter: value is not a boolean value: addr=%p, "
+ "type=%s", bool_obj,
+ bt_value_type_string(bool_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
return ret;
}
-enum bt_value_status bt_value_bool_set(struct bt_value *bool_obj, bool val)
+enum bt_value_status bt_value_bool_set(struct bt_value *bool_obj, bt_bool val)
{
enum bt_value_status ret = BT_VALUE_STATUS_OK;
struct bt_value_bool *typed_bool_obj = BT_VALUE_TO_BOOL(bool_obj);
- if (!bool_obj || !bt_value_is_bool(bool_obj)) {
+ if (!bool_obj) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_bool(bool_obj)) {
+ BT_LOGW("Invalid parameter: value is not a boolean value: addr=%p, "
+ "type=%s", bool_obj,
+ bt_value_type_string(bool_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (bool_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ bool_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
typed_bool_obj->value = val;
+ BT_LOGV("Set boolean value's raw value: value-addr=%p, value=%d",
+ bool_obj, val);
end:
return ret;
struct bt_value_integer *typed_integer_obj =
BT_VALUE_TO_INTEGER(integer_obj);
- if (!integer_obj || !bt_value_is_integer(integer_obj) || !val) {
+ if (!integer_obj || !val) {
+ BT_LOGW("Invalid parameter: value object or value is NULL: "
+ "value-addr=%p, raw-value-addr=%p",
+ integer_obj, val);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_integer(integer_obj)) {
+ BT_LOGW("Invalid parameter: value is not an integer value: addr=%p, "
+ "type=%s", integer_obj,
+ bt_value_type_string(integer_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
struct bt_value_integer *typed_integer_obj =
BT_VALUE_TO_INTEGER(integer_obj);
- if (!integer_obj || !bt_value_is_integer(integer_obj)) {
+ if (!integer_obj) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_integer(integer_obj)) {
+ BT_LOGW("Invalid parameter: value is not an integer value: addr=%p, "
+ "type=%s", integer_obj,
+ bt_value_type_string(integer_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (integer_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ integer_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
typed_integer_obj->value = val;
+ BT_LOGV("Set integer value's raw value: value-addr=%p, value=%" PRId64,
+ integer_obj, val);
end:
return ret;
struct bt_value_float *typed_float_obj =
BT_VALUE_TO_FLOAT(float_obj);
- if (!float_obj || !bt_value_is_float(float_obj) || !val) {
+ if (!float_obj || !val) {
+ BT_LOGW("Invalid parameter: value object or value is NULL: "
+ "value-addr=%p, raw-value-addr=%p",
+ float_obj, val);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_float(float_obj)) {
+ BT_LOGW("Invalid parameter: value is not a floating point number value: addr=%p, "
+ "type=%s", float_obj,
+ bt_value_type_string(float_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
struct bt_value_float *typed_float_obj =
BT_VALUE_TO_FLOAT(float_obj);
- if (!float_obj || !bt_value_is_float(float_obj)) {
+ if (!float_obj) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_float(float_obj)) {
+ BT_LOGW("Invalid parameter: value is not a floating point number value: addr=%p, "
+ "type=%s", float_obj,
+ bt_value_type_string(float_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (float_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ float_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
typed_float_obj->value = val;
+ BT_LOGV("Set floating point number value's raw value: value-addr=%p, value=%f",
+ float_obj, val);
end:
return ret;
struct bt_value_string *typed_string_obj =
BT_VALUE_TO_STRING(string_obj);
- if (!string_obj || !bt_value_is_string(string_obj) || !val) {
+ if (!string_obj || !val) {
+ BT_LOGW("Invalid parameter: value object or value is NULL: "
+ "value-addr=%p, raw-value-addr=%p",
+ string_obj, val);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_string(string_obj)) {
+ BT_LOGW("Invalid parameter: value is not a string value: addr=%p, "
+ "type=%s", string_obj,
+ bt_value_type_string(string_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
struct bt_value_string *typed_string_obj =
BT_VALUE_TO_STRING(string_obj);
- if (!string_obj || !bt_value_is_string(string_obj) || !val) {
+ if (!string_obj || !val) {
+ BT_LOGW("Invalid parameter: value object or value is NULL: "
+ "value-addr=%p, raw-value-addr=%p",
+ string_obj, val);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_string(string_obj)) {
+ BT_LOGW("Invalid parameter: value is not a string value: addr=%p, "
+ "type=%s", string_obj,
+ bt_value_type_string(string_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (string_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ string_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
g_string_assign(typed_string_obj->gstr, val);
+ BT_LOGV("Set string value's raw value: value-addr=%p, raw-value-addr=%p",
+ string_obj, val);
end:
return ret;
}
-int bt_value_array_size(const struct bt_value *array_obj)
+int64_t bt_value_array_size(const struct bt_value *array_obj)
{
- int ret;
+ int64_t ret;
struct bt_value_array *typed_array_obj =
BT_VALUE_TO_ARRAY(array_obj);
- if (!array_obj || !bt_value_is_array(array_obj)) {
+ if (!array_obj) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
+ ret = (int64_t) BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_array(array_obj)) {
+ BT_LOGW("Invalid parameter: value is not an array value: addr=%p, "
+ "type=%s", array_obj,
+ bt_value_type_string(array_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
- ret = (int) typed_array_obj->garray->len;
+ ret = (int64_t) typed_array_obj->garray->len;
end:
return ret;
}
-bool bt_value_array_is_empty(const struct bt_value *array_obj)
+bt_bool bt_value_array_is_empty(const struct bt_value *array_obj)
{
return bt_value_array_size(array_obj) == 0;
}
struct bt_value *bt_value_array_get(const struct bt_value *array_obj,
- size_t index)
+ uint64_t index)
{
struct bt_value *ret;
struct bt_value_array *typed_array_obj =
BT_VALUE_TO_ARRAY(array_obj);
- if (!array_obj || !bt_value_is_array(array_obj) ||
- index >= typed_array_obj->garray->len) {
+ if (!array_obj) {
+ BT_LOGW("Invalid parameter: value object is NULL: index=%" PRIu64,
+ index);
+ ret = NULL;
+ goto end;
+ }
+
+ if (!bt_value_is_array(array_obj)) {
+ BT_LOGW("Invalid parameter: value is not an array value: addr=%p, "
+ "type=%s", array_obj,
+ bt_value_type_string(array_obj->type));
+ ret = NULL;
+ goto end;
+ }
+
+ if (index >= typed_array_obj->garray->len) {
+ BT_LOGW("Invalid parameter: index is out of bounds: "
+ "addr=%p, index=%" PRIu64 ", size=%u",
+ array_obj, index, typed_array_obj->garray->len);
ret = NULL;
goto end;
}
struct bt_value_array *typed_array_obj =
BT_VALUE_TO_ARRAY(array_obj);
- if (!array_obj || !bt_value_is_array(array_obj) || !element_obj) {
+ if (!array_obj || !element_obj) {
+ BT_LOGW("Invalid parameter: array value or element value is NULL: "
+ "array-value-addr=%p, element-value-addr=%p",
+ array_obj, element_obj);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_array(array_obj)) {
+ BT_LOGW("Invalid parameter: value is not an array value: addr=%p, "
+ "type=%s", array_obj,
+ bt_value_type_string(array_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (array_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ array_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
g_ptr_array_add(typed_array_obj->garray, element_obj);
bt_get(element_obj);
+ BT_LOGV("Appended element to array value: array-value-addr=%p, "
+ "element-value-addr=%p, new-size=%u",
+ array_obj, element_obj, typed_array_obj->garray->len);
end:
return ret;
}
enum bt_value_status bt_value_array_append_bool(struct bt_value *array_obj,
- bool val)
+ bt_bool val)
{
enum bt_value_status ret;
struct bt_value *bool_obj = NULL;
bool_obj = bt_value_bool_create_init(val);
ret = bt_value_array_append(array_obj, bool_obj);
bt_put(bool_obj);
-
return ret;
}
integer_obj = bt_value_integer_create_init(val);
ret = bt_value_array_append(array_obj, integer_obj);
bt_put(integer_obj);
-
return ret;
}
float_obj = bt_value_float_create_init(val);
ret = bt_value_array_append(array_obj, float_obj);
bt_put(float_obj);
-
return ret;
}
string_obj = bt_value_string_create_init(val);
ret = bt_value_array_append(array_obj, string_obj);
bt_put(string_obj);
-
return ret;
}
empty_array_obj = bt_value_array_create();
ret = bt_value_array_append(array_obj, empty_array_obj);
bt_put(empty_array_obj);
-
return ret;
}
map_obj = bt_value_map_create();
ret = bt_value_array_append(array_obj, map_obj);
bt_put(map_obj);
-
return ret;
}
enum bt_value_status bt_value_array_set(struct bt_value *array_obj,
- size_t index, struct bt_value *element_obj)
+ uint64_t index, struct bt_value *element_obj)
{
enum bt_value_status ret = BT_VALUE_STATUS_OK;
struct bt_value_array *typed_array_obj =
BT_VALUE_TO_ARRAY(array_obj);
- if (!array_obj || !bt_value_is_array(array_obj) || !element_obj ||
- index >= typed_array_obj->garray->len) {
+ if (!array_obj || !element_obj) {
+ BT_LOGW("Invalid parameter: array value or element value is NULL: "
+ "index=%" PRIu64 ", array-value-addr=%p, element-value-addr=%p",
+ index, array_obj, element_obj);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_array(array_obj)) {
+ BT_LOGW("Invalid parameter: value is not an array value: addr=%p, "
+ "type=%s", array_obj,
+ bt_value_type_string(array_obj->type));
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (index >= typed_array_obj->garray->len) {
+ BT_LOGW("Invalid parameter: index is out of bounds: "
+ "addr=%p, index=%" PRIu64 ", size=%u",
+ array_obj, index, typed_array_obj->garray->len);
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (array_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ array_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
bt_put(g_ptr_array_index(typed_array_obj->garray, index));
g_ptr_array_index(typed_array_obj->garray, index) = element_obj;
bt_get(element_obj);
+ BT_LOGV("Set array value's element: array-value-addr=%p, "
+ "index=%" PRIu64 ", element-value-addr=%p",
+ array_obj, index, element_obj);
end:
return ret;
}
-int bt_value_map_size(const struct bt_value *map_obj)
+int64_t bt_value_map_size(const struct bt_value *map_obj)
{
- int ret;
+ int64_t ret;
struct bt_value_map *typed_map_obj = BT_VALUE_TO_MAP(map_obj);
- if (!map_obj || !bt_value_is_map(map_obj)) {
- ret = BT_VALUE_STATUS_INVAL;
+ if (!map_obj) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
+ ret = (int64_t) BT_VALUE_STATUS_INVAL;
goto end;
}
- ret = (int) g_hash_table_size(typed_map_obj->ght);
+ if (!bt_value_is_map(map_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", map_obj,
+ bt_value_type_string(map_obj->type));
+ ret = (int64_t) BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ ret = (int64_t) g_hash_table_size(typed_map_obj->ght);
end:
return ret;
}
-bool bt_value_map_is_empty(const struct bt_value *map_obj)
+bt_bool bt_value_map_is_empty(const struct bt_value *map_obj)
{
return bt_value_map_size(map_obj) == 0;
}
struct bt_value *ret;
struct bt_value_map *typed_map_obj = BT_VALUE_TO_MAP(map_obj);
- if (!map_obj || !bt_value_is_map(map_obj) || !key) {
+ if (!map_obj || !key) {
+ BT_LOGW("Invalid parameter: value object or key is NULL: "
+ "value-addr=%p, key-addr=%p", map_obj, key);
+ ret = NULL;
+ goto end;
+ }
+
+ if (!bt_value_is_map(map_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", map_obj,
+ bt_value_type_string(map_obj->type));
ret = NULL;
goto end;
}
quark = g_quark_from_string(key);
ret = g_hash_table_lookup(typed_map_obj->ght, GUINT_TO_POINTER(quark));
-
if (ret) {
bt_get(ret);
}
return ret;
}
-bool bt_value_map_has_key(const struct bt_value *map_obj, const char *key)
+bt_bool bt_value_map_has_key(const struct bt_value *map_obj, const char *key)
{
- bool ret;
+ bt_bool ret;
GQuark quark;
struct bt_value_map *typed_map_obj = BT_VALUE_TO_MAP(map_obj);
- if (!map_obj || !bt_value_is_map(map_obj) || !key) {
- ret = false;
+ if (!map_obj || !key) {
+ BT_LOGW("Invalid parameter: value object or key is NULL: "
+ "value-addr=%p, key-addr=%p", map_obj, key);
+ ret = BT_FALSE;
+ goto end;
+ }
+
+ if (!bt_value_is_map(map_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", map_obj,
+ bt_value_type_string(map_obj->type));
+ ret = BT_FALSE;
goto end;
}
enum bt_value_status ret = BT_VALUE_STATUS_OK;
struct bt_value_map *typed_map_obj = BT_VALUE_TO_MAP(map_obj);
- if (!map_obj || !bt_value_is_map(map_obj) || !key || !element_obj) {
+ if (!map_obj || !key || !element_obj) {
+ BT_LOGW("Invalid parameter: map value, key, or element value is NULL: "
+ "map-value-addr=%p, key-addr=%p, element-value-addr=%p",
+ map_obj, key, element_obj);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_map(map_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", map_obj,
+ bt_value_type_string(map_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
if (map_obj->is_frozen) {
+ BT_LOGW("Invalid parameter: value is frozen: addr=%p",
+ map_obj);
ret = BT_VALUE_STATUS_FROZEN;
goto end;
}
g_hash_table_insert(typed_map_obj->ght,
GUINT_TO_POINTER(quark), element_obj);
bt_get(element_obj);
+ BT_LOGV("Inserted value into map value: map-value-addr=%p, "
+ "key=\"%s\", element-value-addr=%p",
+ map_obj, key, element_obj);
end:
return ret;
}
enum bt_value_status bt_value_map_insert_bool(struct bt_value *map_obj,
- const char *key, bool val)
+ const char *key, bt_bool val)
{
enum bt_value_status ret;
struct bt_value *bool_obj = NULL;
bool_obj = bt_value_bool_create_init(val);
ret = bt_value_map_insert(map_obj, key, bool_obj);
bt_put(bool_obj);
-
return ret;
}
integer_obj = bt_value_integer_create_init(val);
ret = bt_value_map_insert(map_obj, key, integer_obj);
bt_put(integer_obj);
-
return ret;
}
float_obj = bt_value_float_create_init(val);
ret = bt_value_map_insert(map_obj, key, float_obj);
bt_put(float_obj);
-
return ret;
}
string_obj = bt_value_string_create_init(val);
ret = bt_value_map_insert(map_obj, key, string_obj);
bt_put(string_obj);
-
return ret;
}
array_obj = bt_value_array_create();
ret = bt_value_map_insert(map_obj, key, array_obj);
bt_put(array_obj);
-
return ret;
}
empty_map_obj = bt_value_map_create();
ret = bt_value_map_insert(map_obj, key, empty_map_obj);
bt_put(empty_map_obj);
-
return ret;
}
GHashTableIter iter;
struct bt_value_map *typed_map_obj = BT_VALUE_TO_MAP(map_obj);
- if (!map_obj || !bt_value_is_map(map_obj) || !cb) {
+ if (!map_obj || !cb) {
+ BT_LOGW("Invalid parameter: map value or callback is NULL: "
+ "value-addr=%p, cb-addr=%p", map_obj, cb);
+ ret = BT_VALUE_STATUS_INVAL;
+ goto end;
+ }
+
+ if (!bt_value_is_map(map_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", map_obj,
+ bt_value_type_string(map_obj->type));
ret = BT_VALUE_STATUS_INVAL;
goto end;
}
const char *key_str = g_quark_to_string(GPOINTER_TO_UINT(key));
if (!cb(key_str, element_obj, data)) {
+ BT_LOGV("User cancelled the loop: key=\"%s\", "
+ "value-addr=%p, data=%p",
+ key_str, element_obj, data);
ret = BT_VALUE_STATUS_CANCELLED;
break;
}
return ret;
}
+struct extend_map_element_data {
+ struct bt_value *extended_obj;
+ bt_bool got_error;
+};
+
+static
+bt_bool extend_map_element(const char *key,
+ struct bt_value *extension_obj_elem, void *data)
+{
+ bt_bool ret = BT_TRUE;
+
+ struct extend_map_element_data *extend_data = data;
+
+ /* Copy object which is to replace the current one */
+ struct bt_value *extension_obj_elem_copy =
+ bt_value_copy(extension_obj_elem);
+
+ /* Replace in extended object */
+ if (bt_value_map_insert(extend_data->extended_obj, key,
+ extension_obj_elem_copy)) {
+ BT_LOGE("Cannot replace value in extended value: key=\"%s\", "
+ "extended-value-addr=%p, element-value-addr=%p",
+ key, extend_data->extended_obj,
+ extension_obj_elem_copy);
+ goto error;
+ }
+
+ goto end;
+
+error:
+ ret = BT_FALSE;
+ extend_data->got_error = BT_TRUE;
+
+end:
+ BT_PUT(extension_obj_elem_copy);
+ return ret;
+}
+
+struct bt_value *bt_value_map_extend(struct bt_value *base_map_obj,
+ struct bt_value *extension_obj)
+{
+ struct bt_value *extended_obj = NULL;
+ struct extend_map_element_data extend_data = { 0 };
+
+ if (!base_map_obj || !extension_obj) {
+ BT_LOGW("Invalid parameter: base value or extension value is NULL: "
+ "base-value-addr=%p, extension-value-addr=%p",
+ base_map_obj, extension_obj);
+ goto error;
+ }
+
+ if (!bt_value_is_map(base_map_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", base_map_obj,
+ bt_value_type_string(base_map_obj->type));
+ goto error;
+ }
+
+ if (!bt_value_is_map(extension_obj)) {
+ BT_LOGW("Invalid parameter: value is not a map value: addr=%p, "
+ "type=%s", extension_obj,
+ bt_value_type_string(extension_obj->type));
+ goto error;
+ }
+
+ BT_LOGD("Extending map value: base-value-addr=%p, extension-value-addr=%p",
+ base_map_obj, extension_obj);
+
+ /* Create copy of base map object to start with */
+ extended_obj = bt_value_copy(base_map_obj);
+ if (!extended_obj) {
+ BT_LOGE("Cannot copy base value: base-value-addr=%p",
+ base_map_obj);
+ goto error;
+ }
+
+ /*
+ * For each key in the extension map object, replace this key
+ * in the copied map object.
+ */
+ extend_data.extended_obj = extended_obj;
+
+ if (bt_value_map_foreach(extension_obj, extend_map_element,
+ &extend_data)) {
+ BT_LOGE("Cannot iterate on the extension object's elements: "
+ "extension-value-addr=%p", extension_obj);
+ goto error;
+ }
+
+ if (extend_data.got_error) {
+ BT_LOGE("Failed to successfully iterate on the extension object's elements: "
+ "extension-value-addr=%p", extension_obj);
+ goto error;
+ }
+
+ BT_LOGD("Extended map value: extended-value-addr=%p",
+ extended_obj);
+ goto end;
+
+error:
+ BT_PUT(extended_obj);
+
+end:
+ return extended_obj;
+}
+
struct bt_value *bt_value_copy(const struct bt_value *object)
{
struct bt_value *copy_obj = NULL;
if (!object) {
+ BT_LOGW_STR("Invalid parameter: value object is NULL.");
goto end;
}
+ BT_LOGD("Copying value object: addr=%p", object);
copy_obj = copy_funcs[object->type](object);
+ if (copy_obj) {
+ BT_LOGD("Copied value object: copy-value-addr=%p",
+ copy_obj);
+ } else {
+ BT_LOGE_STR("Failed to copy value object.");
+ }
end:
return copy_obj;
}
-bool bt_value_compare(const struct bt_value *object_a,
+bt_bool bt_value_compare(const struct bt_value *object_a,
const struct bt_value *object_b)
{
- bool ret = false;
+ bt_bool ret = BT_FALSE;
if (!object_a || !object_b) {
+ BT_LOGW("Invalid parameter: value A or value B is NULL: "
+ "value-a-addr=%p, value-b-addr=%p",
+ object_a, object_b);
goto end;
}
if (object_a->type != object_b->type) {
+ BT_LOGV("Values are different: type mismatch: "
+ "value-a-addr=%p, value-b-addr=%p, "
+ "value-a-type=%s, value-b-type=%s",
+ object_a, object_b,
+ bt_value_type_string(object_a->type),
+ bt_value_type_string(object_b->type));
goto end;
}