]> git.sesse.net Git - vlc/blob - compat/tdestroy.c
tdestroy: fix encoding.
[vlc] / compat / tdestroy.c
1 /*****************************************************************************
2  * tdestroy.c: GNU tdestroy() replacement
3  *****************************************************************************
4  * Copyright © 1998-2009 the VideoLAN project
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
19  *****************************************************************************/
20
21 #ifdef HAVE_CONFIG_H
22 # include <config.h>
23 #endif
24
25 #include <stdlib.h>
26 #include <search.h>
27
28 typedef struct node_t
29 {
30     void        *key;
31     struct node_t *left, *right;
32 } node;
33
34 static void tdestroy_recurse (node *root, __free_fn_t freefct)
35 {
36     if (root->left != NULL)
37         tdestroy_recurse (root->left, freefct);
38     if (root->right != NULL)
39         tdestroy_recurse (root->right, freefct);
40     (*freefct) ((void *) root->key);
41     /* Free the node itself.  */
42     free (root);
43 }
44
45 void tdestroy (void *vroot, __free_fn_t freefct)
46 {
47     node *root = (node *) vroot;
48     if (root != NULL) {
49         tdestroy_recurse (root, freefct);
50     }
51 }
52