49 lines
1.4 KiB
C
49 lines
1.4 KiB
C
|
/*
|
||
|
* Reset container
|
||
|
*
|
||
|
* Copyright (c) 2024 Linaro, Ltd
|
||
|
*
|
||
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||
|
* See the COPYING file in the top-level directory.
|
||
|
*/
|
||
|
|
||
|
#ifndef HW_RESETCONTAINER_H
|
||
|
#define HW_RESETCONTAINER_H
|
||
|
|
||
|
/*
|
||
|
* The "reset container" is an object which implements the Resettable
|
||
|
* interface. It contains a list of arbitrary other objects which also
|
||
|
* implement Resettable. Resetting the reset container resets all the
|
||
|
* objects in it.
|
||
|
*/
|
||
|
|
||
|
#include "qom/object.h"
|
||
|
|
||
|
#define TYPE_RESETTABLE_CONTAINER "resettable-container"
|
||
|
OBJECT_DECLARE_TYPE(ResettableContainer, ResettableContainerClass, RESETTABLE_CONTAINER)
|
||
|
|
||
|
/**
|
||
|
* resettable_container_add: Add a resettable object to the container
|
||
|
* @rc: container
|
||
|
* @obj: object to add to the container
|
||
|
*
|
||
|
* Add @obj to the ResettableContainer @rc. @obj must implement the
|
||
|
* Resettable interface.
|
||
|
*
|
||
|
* When @rc is reset, it will reset every object that has been added
|
||
|
* to it, in the order they were added.
|
||
|
*/
|
||
|
void resettable_container_add(ResettableContainer *rc, Object *obj);
|
||
|
|
||
|
/**
|
||
|
* resettable_container_remove: Remove an object from the container
|
||
|
* @rc: container
|
||
|
* @obj: object to remove from the container
|
||
|
*
|
||
|
* Remove @obj from the ResettableContainer @rc. @obj must have been
|
||
|
* previously added to this container.
|
||
|
*/
|
||
|
void resettable_container_remove(ResettableContainer *rc, Object *obj);
|
||
|
|
||
|
#endif
|