source: rtems/cpukit/sapi/src/sapirbtreeinsert.c

Last change on this file was e7cb79c, checked in by Kinsey Moore <kinsey.moore@…>, on 10/12/23 at 19:18:39

cpukit: Remove unused includes

  • Property mode set to 100644
File size: 2.7 KB
Line 
1/* SPDX-License-Identifier: BSD-2-Clause */
2
3/**
4 * @file
5 *
6 * @ingroup RTEMSAPIClassicRBTrees
7 *
8 * @brief This source file contains the implementation of
9 *   rtems_rbtree_insert().
10 */
11
12/*
13 *  Copyright (c) 2010-2012 Gedare Bloom.
14 *
15 * Redistribution and use in source and binary forms, with or without
16 * modification, are permitted provided that the following conditions
17 * are met:
18 * 1. Redistributions of source code must retain the above copyright
19 *    notice, this list of conditions and the following disclaimer.
20 * 2. Redistributions in binary form must reproduce the above copyright
21 *    notice, this list of conditions and the following disclaimer in the
22 *    documentation and/or other materials provided with the distribution.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
28 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34 * POSSIBILITY OF SUCH DAMAGE.
35 */
36
37#ifdef HAVE_CONFIG_H
38#include "config.h"
39#endif
40
41#include <rtems/rbtree.h>
42
43RTEMS_STATIC_ASSERT(
44  sizeof( rtems_rbtree_compare_result ) >= sizeof( intptr_t ),
45  rtems_rbtree_compare_result_intptr_t
46);
47
48RTEMS_STATIC_ASSERT(
49  sizeof( rtems_rbtree_compare_result ) >= sizeof( int32_t ),
50  rtems_rbtree_compare_result_int32_t
51);
52
53rtems_rbtree_node *rtems_rbtree_insert(
54  rtems_rbtree_control *the_rbtree,
55  rtems_rbtree_node    *the_node,
56  rtems_rbtree_compare  compare,
57  bool                  is_unique
58)
59{
60  rtems_rbtree_node **which = _RBTree_Root_reference( the_rbtree );
61  rtems_rbtree_node  *parent = NULL;
62
63  while ( *which != NULL ) {
64    rtems_rbtree_compare_result compare_result;
65
66    parent = *which;
67    compare_result = ( *compare )( the_node, parent );
68
69    if ( is_unique && rtems_rbtree_is_equal( compare_result ) ) {
70      return parent;
71    }
72
73    if ( rtems_rbtree_is_lesser( compare_result ) ) {
74      which = _RBTree_Left_reference( parent );
75    } else {
76      which = _RBTree_Right_reference( parent );
77    }
78  }
79
80  _RBTree_Initialize_node( the_node );
81  _RBTree_Add_child( the_node, parent, which );
82  _RBTree_Insert_color( the_rbtree, the_node );
83
84  return NULL;
85}
Note: See TracBrowser for help on using the repository browser.