1570af302Sopenharmony_ci/* 2570af302Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd. 3570af302Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4570af302Sopenharmony_ci * you may not use this file except in compliance with the License. 5570af302Sopenharmony_ci * You may obtain a copy of the License at 6570af302Sopenharmony_ci * 7570af302Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8570af302Sopenharmony_ci * 9570af302Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10570af302Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11570af302Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12570af302Sopenharmony_ci * See the License for the specific language governing permissions and 13570af302Sopenharmony_ci * limitations under the License. 14570af302Sopenharmony_ci */ 15570af302Sopenharmony_ci 16570af302Sopenharmony_ci#include <stdio.h> 17570af302Sopenharmony_ci#include <stdlib.h> 18570af302Sopenharmony_ci#include <string.h> 19570af302Sopenharmony_ci#include <search.h> 20570af302Sopenharmony_ci#include <time.h> 21570af302Sopenharmony_ci#include "test.h" 22570af302Sopenharmony_ci 23570af302Sopenharmony_ci#define ARRAY_SIZE (10) 24570af302Sopenharmony_cistatic void *root = NULL; 25570af302Sopenharmony_cistatic int g_free_calls = 0; 26570af302Sopenharmony_ci 27570af302Sopenharmony_civoid *malloc_node(unsigned n) 28570af302Sopenharmony_ci{ 29570af302Sopenharmony_ci void *p; 30570af302Sopenharmony_ci p = malloc(n); 31570af302Sopenharmony_ci if (p) { 32570af302Sopenharmony_ci return p; 33570af302Sopenharmony_ci } 34570af302Sopenharmony_ci fprintf(stderr, "insufficient memory\n"); 35570af302Sopenharmony_ci exit(EXIT_FAILURE); 36570af302Sopenharmony_ci} 37570af302Sopenharmony_ci 38570af302Sopenharmony_ciint cmp_node(const void *pa, const void *pb) 39570af302Sopenharmony_ci{ 40570af302Sopenharmony_ci if (*(int *)pa < *(int *)pb) { 41570af302Sopenharmony_ci return -1; 42570af302Sopenharmony_ci } 43570af302Sopenharmony_ci if (*(int *)pa > *(int *)pb) { 44570af302Sopenharmony_ci return 1; 45570af302Sopenharmony_ci } 46570af302Sopenharmony_ci return 0; 47570af302Sopenharmony_ci} 48570af302Sopenharmony_ci 49570af302Sopenharmony_civoid node_free(void *p) 50570af302Sopenharmony_ci{ 51570af302Sopenharmony_ci free(p); 52570af302Sopenharmony_ci g_free_calls++; 53570af302Sopenharmony_ci} 54570af302Sopenharmony_ci 55570af302Sopenharmony_ci/** 56570af302Sopenharmony_ci * @tc.name : tdestroy_0100 57570af302Sopenharmony_ci * @tc.desc : Removes the whole tree pointed to by root 58570af302Sopenharmony_ci * @tc.level : Level 0 59570af302Sopenharmony_ci */ 60570af302Sopenharmony_civoid tdestroy_0100(void) 61570af302Sopenharmony_ci{ 62570af302Sopenharmony_ci int i, *ptr, *target; 63570af302Sopenharmony_ci void *val, *result; 64570af302Sopenharmony_ci int array[ARRAY_SIZE] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; 65570af302Sopenharmony_ci 66570af302Sopenharmony_ci for (i = 0; i < ARRAY_SIZE; i++) { 67570af302Sopenharmony_ci ptr = malloc_node(sizeof(int)); 68570af302Sopenharmony_ci *ptr = array[i]; 69570af302Sopenharmony_ci val = tsearch((void *)ptr, &root, cmp_node); 70570af302Sopenharmony_ci if (val == NULL) { 71570af302Sopenharmony_ci exit(EXIT_FAILURE); 72570af302Sopenharmony_ci 73570af302Sopenharmony_ci } else if ((*(int **)val) != ptr) { 74570af302Sopenharmony_ci free(ptr); 75570af302Sopenharmony_ci } 76570af302Sopenharmony_ci } 77570af302Sopenharmony_ci 78570af302Sopenharmony_ci tdestroy(root, node_free); 79570af302Sopenharmony_ci if (g_free_calls != ARRAY_SIZE) { 80570af302Sopenharmony_ci t_error("%s tdestroy failed, g_free_calls is %d\n", __func__, g_free_calls); 81570af302Sopenharmony_ci } 82570af302Sopenharmony_ci} 83570af302Sopenharmony_ci 84570af302Sopenharmony_ciint main(int argc, char *argv[]) 85570af302Sopenharmony_ci{ 86570af302Sopenharmony_ci tdestroy_0100(); 87570af302Sopenharmony_ci return t_status; 88570af302Sopenharmony_ci}