/* Copyright (C) 2010, Rodrigo Cánovas, all rights reserved.
 *
 *This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 *
 */



/* General interface for using the compressed index libraries */

#ifndef uchar
#define uchar unsigned char
#endif
#ifndef uint
#define uint  unsigned int
#endif
#ifndef ulong
#define ulong unsigned long
#endif


namespace cds_static{
	/* Error management */

					/* Returns a string describing the error associated with error number
						e. The string must not be freed, and it will be overwritten with
						subsequent calls. */

	char *error_index (int e);

	/* Building the index */

					/* Creates index from text[0..length-1]. Note that the index is an 
						opaque data type. Any build option must be passed in string 
						build_options, whose syntax depends on the index. The index must 
						always work with some default parameters if build_options is NULL. 
						The returned index is ready to be queried. */

	int build_index (uchar *text, ulong length, char *build_options, void **index);

					/*  Saves index on disk by using single or multiple files, having 
						proper extensions. */

	int save_index (void *index, char *filename);

					/*  Loads index from one or more file(s) named filename, possibly 
						adding the proper extensions. */

	int load_index (char *filename, void **index);

					/* Frees the memory occupied by index. */

	int free_index (void *index);

					/* Gives the memory occupied by index in bytes. */

	int index_size(void *index, ulong *size);

	/* Querying the index */

					/* Writes in numocc the number of occurrences of the substring 
						pattern[0..length-1] found in the text indexed by index. */

	int count (void *index, uchar *pattern, ulong length, ulong *numocc);

					/* Writes in numocc the number of occurrences of the substring 
						pattern[0..length-1] in the text indexed by index. It also allocates
						occ (which must be freed by the caller) and writes the locations of 
						the numocc occurrences in occ, in arbitrary order.  */

	int locate (void *index, uchar *pattern, ulong length, ulong **occ, 
					ulong *numocc);

					/* Gives the length of the text indexed */

	int get_length(void *index, ulong *length);

	/* Accessing the indexed text  */

					/*  Allocates snippet (which must be freed by the caller) and writes 
						the substring text[from..to] into it. Returns in snippet_length the 
						length of the text snippet actually extracted (that could be less 
						than to-from+1 if to is larger than the text size). */

	int extract (void *index, ulong from, ulong to, uchar **snippet, 
					ulong *snippet_length);

					/* Displays the text (snippet) surrounding any occurrence of the 
						substring pattern[0..length-1] within the text indexed by index. 
						The snippet must include numc characters before and after the 
						pattern occurrence, totalizing length+2*numc characters, or less if 
						the text boundaries are reached. Writes in numocc the number of 
						occurrences, and allocates the arrays snippet_text and 
						snippet_lengths (which must be freed by the caller). The first is a 
						character array of numocc*(length+2*numc) characters, with a new 
						snippet starting at every multiple of length+2*numc. The second 
						gives the real length of each of the numocc snippets. */

	int display (void *index, uchar *pattern, ulong length, ulong numc, 
					ulong *numocc, uchar **snippet_text, ulong **snippet_lengths);

					/*  Obtains the length of the text indexed by index. */

	int length (void *index, ulong *length);

};

