2019-05-30 16:29:36 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
#ifndef STRUCTURED_LIST_H
|
|
|
|
#define STRUCTURED_LIST_H
|
|
|
|
|
2019-05-30 16:37:01 +00:00
|
|
|
/* Clear whole list; this works for taglist, picturelist and dive computers */
|
2019-05-30 16:29:36 +00:00
|
|
|
#define STRUCTURED_LIST_FREE(_type, _start, _free) \
|
|
|
|
{ \
|
|
|
|
_type *_ptr = _start; \
|
|
|
|
while (_ptr) { \
|
|
|
|
_type *_next = _ptr->next; \
|
|
|
|
_free(_ptr); \
|
|
|
|
_ptr = _next; \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define STRUCTURED_LIST_COPY(_type, _first, _dest, _cpy) \
|
|
|
|
{ \
|
|
|
|
_type *_sptr = _first; \
|
|
|
|
_type **_dptr = &_dest; \
|
|
|
|
while (_sptr) { \
|
|
|
|
*_dptr = malloc(sizeof(_type)); \
|
|
|
|
_cpy(_sptr, *_dptr); \
|
|
|
|
_sptr = _sptr->next; \
|
|
|
|
_dptr = &(*_dptr)->next; \
|
|
|
|
} \
|
|
|
|
*_dptr = 0; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|