src/stringtable.cxx

changeset 72
03e4d9db3fd9
parent 71
11f23fabf8a6
child 73
1ee9b312dc18
--- a/src/stringtable.cxx	Fri Jan 10 16:11:49 2014 +0200
+++ b/src/stringtable.cxx	Fri Jan 10 21:58:42 2014 +0200
@@ -1,104 +1,53 @@
-/*
- *	botc source code
- *	Copyright (C) 2012 Santeri `Dusk` Piippo
- *	All rights reserved.
- *	
- *	Redistribution and use in source and binary forms, with or without
- *	modification, are permitted provided that the following conditions are met:
- *	
- *	1. Redistributions of source code must retain the above copyright notice,
- *	   this list of conditions and the following disclaimer.
- *	2. Redistributions in binary form must reproduce the above copyright notice,
- *	   this list of conditions and the following disclaimer in the documentation
- *	   and/or other materials provided with the distribution.
- *	3. Neither the name of the developer nor the names of its contributors may
- *	   be used to endorse or promote products derived from this software without
- *	   specific prior written permission.
- *	4. Redistributions in any form must be accompanied by information on how to
- *	   obtain complete source code for the software and any accompanying
- *	   software that uses the software. The source code must either be included
- *	   in the distribution or be available for no more than the cost of
- *	   distribution plus a nominal fee, and must be freely redistributable
- *	   under reasonable conditions. For an executable file, complete source
- *	   code means the source code for all modules it contains. It does not
- *	   include source code for modules or files that typically accompany the
- *	   major components of the operating system on which the executable file
- *	   runs.
- *	
- *	THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- *	AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- *	IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- *	ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
- *	LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- *	CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- *	SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- *	INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- *	CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- *	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- *	POSSIBILITY OF SUCH DAMAGE.
- */
-
-#define __STRINGTABLE_CXX__
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
-#include "common.h"
+#include "main.h"
 #include "bots.h"
 #include "stringtable.h"
 
+static string_list g_string_table;
+
 // ============================================================================
-// Initializes the string table
-void InitStringTable() {
-	// Zero out everything first.
-	for (unsigned int a = 0; a < MAX_LIST_STRINGS; a++)
-		for (unsigned int b = 0; b < MAX_STRING_LENGTH; b++)
-			g_StringTable[a][b] = 0;
+//
+const string_list& get_string_table()
+{
+	return g_string_table;
 }
 
 // ============================================================================
 // Potentially adds a string to the table and returns the index of it.
-unsigned int PushToStringTable (char* s) {
+//
+int get_string_table_index (const string& a)
+{
 	// Must not be too long.
-	if (strlen (s) >= MAX_STRING_LENGTH)
-		error ("string `%s` too long (%d characters max)\n", s, strlen (s));
-	
-	// Find a free slot in the table. 
-	unsigned int a;
-	for (a = 0; a < MAX_LIST_STRINGS; a++) {
+	if (strlen (a) >= MAX_STRING_LENGTH)
+		error ("string `%s` too long (%d characters, max is %d)\n",
+			   a.c_str(), a.length(), MAX_STRING_LENGTH);
+
+	// Find a free slot in the table.
+	int idx;
+
+	for (idx = 0; idx < g_string_table.size(); idx++)
+	{
 		// String is already in the table, thus return it.
-		if (!strcmp (s, g_StringTable[a]))
-			return a;
-		
-		// String is empty, thus it's free.
-		if (!strlen (g_StringTable[a]))
-			break;
+		if (g_string_table[idx] == a)
+			return idx;
 	}
-	
-	// no free slots!
-	if (a == MAX_LIST_STRINGS)
-		error ("too many strings defined!\n");
-	
-	// Determine the length
-	size_t l1 = strlen (s);
-	size_t l2 = MAX_LIST_STRINGS - 1;
-	size_t len = (l1 < l2) ? l1 : l2;
-	
+
+	// Check if the table is already full
+	if (g_string_table.size() == MAX_LIST_STRINGS - 1)
+		error ("too many strings!\n");
+
 	// Now, dump the string into the slot
-	strncpy (g_StringTable[a], s, len);
-	g_StringTable[a][len] = 0;
-	
-	return a;
+	g_string_table[idx] = a;
+
+	return idx;
 }
 
 // ============================================================================
 // Counts the amount of strings in the table.
-unsigned int CountStringTable () {
-	unsigned int count = 0;
-	for (unsigned int a = 0; a < MAX_LIST_STRINGS; a++) {
-		if (!strlen (g_StringTable[a]))
-			break;
-		else
-			count++;
-	}
-	return count;
-}
\ No newline at end of file
+//
+int num_strings_in_table()
+{
+	return g_string_table.size();
+}

mercurial