Merge branch 'linux1'
[oweals/cde.git] / cde / programs / dthelp / parser / pass2 / util / trierset.c
1 /*
2  * CDE - Common Desktop Environment
3  *
4  * Copyright (c) 1993-2012, The Open Group. All rights reserved.
5  *
6  * These libraries and programs are free software; you can
7  * redistribute them and/or modify them under the terms of the GNU
8  * Lesser General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option)
10  * any later version.
11  *
12  * These libraries and programs are distributed in the hope that
13  * they will be useful, but WITHOUT ANY WARRANTY; without even the
14  * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15  * PURPOSE. See the GNU Lesser General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with these librararies and programs; if not, write
20  * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
21  * Floor, Boston, MA 02110-1301 USA
22  */
23 /* $XConsortium: trierset.c /main/3 1995/11/08 11:09:04 rswiston $ */
24 /*
25                    Copyright 1988, 1989 Hewlett-Packard Co.
26 */
27
28 #include <stdio.h>
29 #include "basic.h"
30 #include "common.h"
31 #include "trie.h"
32
33 extern M_CHARTYPE m_ctarray[M_CHARSETLEN] ;
34
35 /* Changes the value associated with an entry in a trie. */
36 void *m_resettrie(xtrie, p, value)
37   M_TRIE *xtrie ;
38   M_WCHAR *p ;
39   void *value ;
40   {
41     M_TRIE *currentnode ;
42
43     currentnode = xtrie->data ;
44     while (TRUE) {
45       if (! currentnode) return(FALSE) ;
46       if ((int) currentnode->symbol == m_ctupper(*p))
47         if (! *p) return((void *)(currentnode->data = (M_TRIE *) value)) ;
48         else {
49           p++ ;
50           currentnode = currentnode->data ;
51           continue ;
52           }
53       else if (currentnode->symbol < *p) {
54         currentnode = currentnode->next ;
55         continue ;
56         }
57       else return(NULL) ;
58       }
59     }
60
61