Sun, 23 Feb 2014 17:45:34 +0200
- changed the PROPERTY macro to a simper version and brought some refactoring with it
88 | 1 | /* |
2 | Copyright 2012-2014 Santeri Piippo | |
3 | All rights reserved. | |
4 | ||
5 | Redistribution and use in source and binary forms, with or without | |
6 | modification, are permitted provided that the following conditions | |
7 | are met: | |
8 | ||
9 | 1. Redistributions of source code must retain the above copyright | |
10 | notice, this list of conditions and the following disclaimer. | |
11 | 2. Redistributions in binary form must reproduce the above copyright | |
12 | notice, this list of conditions and the following disclaimer in the | |
13 | documentation and/or other materials provided with the distribution. | |
14 | 3. The name of the author may not be used to endorse or promote products | |
15 | derived from this software without specific prior written permission. | |
16 | ||
17 | THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | |
18 | IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |
19 | OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | |
20 | IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | |
21 | INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | |
22 | NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | |
23 | DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | |
24 | THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
25 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | |
26 | THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
27 | */ | |
28 | ||
29 | #include <stdio.h> | |
30 | #include <stdlib.h> | |
31 | #include <string.h> | |
32 | #include "StringTable.h" | |
33 | ||
34 | static StringList gStringTable; | |
35 | ||
36 | // ============================================================================ | |
37 | // | |
38 | const StringList& GetStringTable() | |
39 | { | |
40 | return gStringTable; | |
41 | } | |
42 | ||
43 | // ============================================================================ | |
44 | // | |
45 | // Potentially adds a string to the table and returns the index of it. | |
46 | // | |
112
def56932f938
- changed the PROPERTY macro to a simper version and brought some refactoring with it
Teemu Piippo <crimsondusk64@gmail.com>
parents:
88
diff
changeset
|
47 | int StringTableIndex (const String& a) |
88 | 48 | { |
49 | // Find a free slot in the table. | |
50 | int idx; | |
51 | ||
52 | for (idx = 0; idx < gStringTable.Size(); idx++) | |
53 | { | |
54 | // String is already in the table, thus return it. | |
55 | if (gStringTable[idx] == a) | |
56 | return idx; | |
57 | } | |
58 | ||
59 | // Must not be too long. | |
60 | if (a.Length() >= gMaxStringLength) | |
61 | Error ("string `%1` too long (%2 characters, max is %3)\n", | |
62 | a, a.Length(), gMaxStringLength); | |
63 | ||
64 | // Check if the table is already full | |
65 | if (gStringTable.Size() == gMaxStringlistSize - 1) | |
66 | Error ("too many strings!\n"); | |
67 | ||
68 | // Now, dump the string into the slot | |
69 | gStringTable.Append (a); | |
70 | return (gStringTable.Size() - 1); | |
71 | } | |
72 | ||
73 | // ============================================================================ | |
74 | // | |
75 | // Counts the amount of strings in the table. | |
76 | // | |
77 | int CountStringsInTable() | |
78 | { | |
79 | return gStringTable.Size(); | |
80 | } |