2 * Mesa 3-D graphics library
5 * Copyright (C) 2005-2006 Brian Paul All Rights Reserved.
7 * Permission is hereby granted, free of charge, to any person obtaining a
8 * copy of this software and associated documentation files (the "Software"),
9 * to deal in the Software without restriction, including without limitation
10 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11 * and/or sell copies of the Software, and to permit persons to whom the
12 * Software is furnished to do so, subject to the following conditions:
14 * The above copyright notice and this permission notice shall be included
15 * in all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
21 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 * \file slang_utility.c
32 #include "slang_utility.h"
34 char *slang_string_concat (char *dst
, const char *src
)
36 return _mesa_strcpy (dst
+ _mesa_strlen (dst
), src
);
41 void slang_atom_pool_construct (slang_atom_pool
*pool
)
45 for (i
= 0; i
< SLANG_ATOM_POOL_SIZE
; i
++)
46 pool
->entries
[i
] = NULL
;
49 void slang_atom_pool_destruct (slang_atom_pool
*pool
)
53 for (i
= 0; i
< SLANG_ATOM_POOL_SIZE
; i
++)
55 slang_atom_entry
*entry
;
57 entry
= pool
->entries
[i
];
60 slang_atom_entry
*next
;
63 slang_alloc_free (entry
->id
);
64 slang_alloc_free (entry
);
70 slang_atom
slang_atom_pool_atom (slang_atom_pool
*pool
, const char *id
)
74 slang_atom_entry
**entry
;
81 hash
= (hash
<< 4) + (GLuint
) *p
++;
82 g
= hash
& 0xf0000000;
87 hash
%= SLANG_ATOM_POOL_SIZE
;
89 entry
= &pool
->entries
[hash
];
90 while (*entry
!= NULL
)
92 if (slang_string_compare ((**entry
).id
, id
) == 0)
93 return (slang_atom
) (**entry
).id
;
94 entry
= &(**entry
).next
;
97 *entry
= (slang_atom_entry
*) slang_alloc_malloc (sizeof (slang_atom_entry
));
99 return SLANG_ATOM_NULL
;
101 (**entry
).next
= NULL
;
102 (**entry
).id
= slang_string_duplicate (id
);
103 if ((**entry
).id
== NULL
)
104 return SLANG_ATOM_NULL
;
105 return (slang_atom
) (**entry
).id
;
108 const char *slang_atom_pool_id (slang_atom_pool
*pool
, slang_atom atom
)
110 return (const char *) atom
;