xref: /aosp_15_r20/external/llvm-libc/src/search/hsearch_r.cpp (revision 71db0c75aadcf003ffe3238005f61d7618a3fead)
1*71db0c75SAndroid Build Coastguard Worker //===-- Implementation of hsearch_r -----------------------------*- C++ -*-===//
2*71db0c75SAndroid Build Coastguard Worker //
3*71db0c75SAndroid Build Coastguard Worker // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*71db0c75SAndroid Build Coastguard Worker // See https://llvm.org/LICENSE.txt for license information.
5*71db0c75SAndroid Build Coastguard Worker // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*71db0c75SAndroid Build Coastguard Worker //
7*71db0c75SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
8*71db0c75SAndroid Build Coastguard Worker 
9*71db0c75SAndroid Build Coastguard Worker #include "src/search/hsearch_r.h"
10*71db0c75SAndroid Build Coastguard Worker #include "src/__support/HashTable/table.h"
11*71db0c75SAndroid Build Coastguard Worker #include "src/__support/macros/config.h"
12*71db0c75SAndroid Build Coastguard Worker #include "src/errno/libc_errno.h"
13*71db0c75SAndroid Build Coastguard Worker 
14*71db0c75SAndroid Build Coastguard Worker namespace LIBC_NAMESPACE_DECL {
15*71db0c75SAndroid Build Coastguard Worker LLVM_LIBC_FUNCTION(int, hsearch_r,
16*71db0c75SAndroid Build Coastguard Worker                    (ENTRY item, ACTION action, ENTRY **retval,
17*71db0c75SAndroid Build Coastguard Worker                     struct hsearch_data *htab)) {
18*71db0c75SAndroid Build Coastguard Worker   if (htab == nullptr) {
19*71db0c75SAndroid Build Coastguard Worker     libc_errno = EINVAL;
20*71db0c75SAndroid Build Coastguard Worker     return 0;
21*71db0c75SAndroid Build Coastguard Worker   }
22*71db0c75SAndroid Build Coastguard Worker   internal::HashTable *table =
23*71db0c75SAndroid Build Coastguard Worker       static_cast<internal::HashTable *>(htab->__opaque);
24*71db0c75SAndroid Build Coastguard Worker   switch (action) {
25*71db0c75SAndroid Build Coastguard Worker   case FIND:
26*71db0c75SAndroid Build Coastguard Worker     *retval = table->find(item.key);
27*71db0c75SAndroid Build Coastguard Worker     if (*retval == nullptr) {
28*71db0c75SAndroid Build Coastguard Worker       libc_errno = ESRCH;
29*71db0c75SAndroid Build Coastguard Worker       return 0;
30*71db0c75SAndroid Build Coastguard Worker     }
31*71db0c75SAndroid Build Coastguard Worker     break;
32*71db0c75SAndroid Build Coastguard Worker   case ENTER:
33*71db0c75SAndroid Build Coastguard Worker     *retval = internal::HashTable::insert(table, item);
34*71db0c75SAndroid Build Coastguard Worker     htab->__opaque = table;
35*71db0c75SAndroid Build Coastguard Worker     if (*retval == nullptr) {
36*71db0c75SAndroid Build Coastguard Worker       libc_errno = ENOMEM;
37*71db0c75SAndroid Build Coastguard Worker       return 0;
38*71db0c75SAndroid Build Coastguard Worker     }
39*71db0c75SAndroid Build Coastguard Worker     break;
40*71db0c75SAndroid Build Coastguard Worker   }
41*71db0c75SAndroid Build Coastguard Worker   return 1;
42*71db0c75SAndroid Build Coastguard Worker }
43*71db0c75SAndroid Build Coastguard Worker 
44*71db0c75SAndroid Build Coastguard Worker } // namespace LIBC_NAMESPACE_DECL
45