}
component = container_of(obj, struct bt_component, base);
-
- assert(component->destroy);
component_class = component->class;
/*
* instance.
*/
if (component->user_destroy) {
- component->user_destroy(component->user_data);
+ component->user_destroy(component);
+ }
+
+ if (component->destroy) {
+ component->destroy(component);
}
- component->destroy(component);
g_string_free(component->name, TRUE);
bt_put(component_class);
g_free(component);
{
enum bt_component_status ret = BT_COMPONENT_STATUS_OK;
- if (!component || !destroy) {
- ret = BT_COMPONENT_STATUS_INVAL;
+ if (!component) {
+ ret = BT_COMPONENT_STATUS_INVALID;
goto end;
}
}
bt_object_init(component, bt_component_destroy);
- component->class = bt_get(component_class);
component->name = g_string_new(name);
if (!component->name) {
BT_PUT(component);
component_class->init(component, params);
ret = component_validation_funcs[type](component);
- if (ret) {
+ if (ret != BT_COMPONENT_STATUS_OK) {
BT_PUT(component);
goto end;
}
enum bt_component_status ret = BT_COMPONENT_STATUS_OK;
if (!component || !name || name[0] == '\0') {
- ret = BT_COMPONENT_STATUS_INVAL;
+ ret = BT_COMPONENT_STATUS_INVALID;
goto end;
}
enum bt_component_status ret = BT_COMPONENT_STATUS_OK;
if (!component) {
- ret = BT_COMPONENT_STATUS_INVAL;
+ ret = BT_COMPONENT_STATUS_INVALID;
goto end;
}
end:
return ret;
}
+
+enum bt_component_status bt_component_set_destroy_cb(
+ struct bt_component *component, bt_component_destroy_cb destroy)
+{
+ enum bt_component_status ret = BT_COMPONENT_STATUS_OK;
+
+ if (!component) {
+ ret = BT_COMPONENT_STATUS_INVALID;
+ goto end;
+ }
+
+ component->user_destroy = destroy;
+end:
+ return ret;
+}