obiblob_indexer.h 4.95 KB
Newer Older
Celine Mercier committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/****************************************************************************
 * Blob indexer header file	                                                    *
 ****************************************************************************/

/**
 * @file obiblob_indexer.h
 * @author Celine Mercier
 * @date April 12th 2016
 * @brief Header file for the functions handling the indexing of values.
 */


#ifndef OBIBLOB_INDEXER_H_
#define OBIBLOB_INDEXER_H_


#include <stdlib.h>
#include <stdio.h>

#include "obidms.h"
#include "obiavl.h"
#include "obitypes.h"
#include "obiblob.h"


#define INDEXER_MAX_NAME AVL_MAX_NAME 			/**< Macro to refer to the maximum size of the name of an indexer structure.
 	 	 	 	 	 	 	 	 	 	 	 	 */


30 31 32
typedef struct OBIDMS_avl_group Obi_indexer;	/**< Typedef to refer to the used indexer structure.
 	 	 	 	 	 	 	 	 	 	 	 	 */
typedef OBIDMS_avl_group_p Obi_indexer_p; 		/**< Typedef to refer to the pointer of the used indexer structure.
Celine Mercier committed
33 34 35
 	 	 	 	 	 	 	 	 	 	 	 	 */


36 37 38 39 40 41 42 43 44 45 46 47 48 49
/**
 * @brief Checks if an indexer already exists or not.
 *
 * @param dms The OBIDMS to which the indexer belongs.
 * @param name The name of the indexer.
 *
 * @returns A value indicating whether the indexer exists or not.
 * @retval 1 if the indexer exists.
 * @retval 0 if the indexer does not exist.
 * @retval -1 if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
50 51 52 53 54 55
inline int obi_indexer_exists(OBIDMS_p dms, const char* name)
{
	return obi_avl_exists(dms, name);
}


56 57 58 59 60 61 62 63 64 65 66 67
/**
 * @brief Opens an indexer and creates it if it does not already exist.
 *
 * @param dms The OBIDMS to which the indexer belongs.
 * @param name The name of the indexer.
 *
 * @returns A pointer to the indexer structure.
 * @retval NULL if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
68 69 70 71 72 73
inline Obi_indexer_p obi_indexer(OBIDMS_p dms, const char* name)
{
	return obi_avl_group(dms, name);
}


74 75 76 77 78 79 80 81 82 83 84 85
/**
 * @brief Creates an indexer.
 *
 * @param dms The OBIDMS to which the indexer belongs.
 * @param name The name of the indexer.
 *
 * @returns A pointer to the AVL tree group structure.
 * @retval NULL if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
86 87 88 89 90 91
inline Obi_indexer_p obi_create_indexer(OBIDMS_p dms, const char* name)
{
	return obi_create_avl_group(dms, name);
}


92 93 94 95 96 97 98 99 100 101 102 103
/**
 * @brief Opens an indexer.
 *
 * @param dms The OBIDMS to which the indexer belongs.
 * @param name The name of the indexer.
 *
 * @returns A pointer to the indexer structure.
 * @retval NULL if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
104 105 106 107 108 109
inline Obi_indexer_p obi_open_indexer(OBIDMS_p dms, const char* name)
{
	return obi_open_avl_group(dms, name);
}


110 111 112 113 114 115 116 117 118 119 120
/**
 * @brief Closes an indexer.
 *
 * @param indexer A pointer to the indexer structure to close and free.
 *
 * @retval 0 if the operation was successfully completed.
 * @retval -1 if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
121 122 123 124 125 126
inline int obi_close_indexer(Obi_indexer_p indexer)
{
	return obi_close_avl_group(indexer);
}


127 128 129 130 131 132 133 134 135 136 137 138
/**
 * @brief Indexes a blob in an indexer and returns the index referring to the blob.
 *
 * @param indexer A pointer to the indexer.
 * @param value The blob to index.
 *
 * @returns The index of the blob newly added in the indexer.
 * @retval -1 if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
139 140 141 142 143 144
inline index_t obi_indexer_add(Obi_indexer_p indexer, Obi_blob_p value)
{
	return obi_avl_group_add(indexer, value);
}


145 146 147 148 149 150 151 152 153 154 155
/**
 * @brief Recovers a blob from an indexer.
 *
 * @param indexer A pointer to the indexer.
 * @param index The index of the blob in the indexer.
 *
 * @returns A pointer to the blob recovered.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
Celine Mercier committed
156 157 158 159 160 161
inline Obi_blob_p obi_indexer_get(Obi_indexer_p indexer, index_t idx)
{
	return obi_avl_group_get(indexer, idx);
}


162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177
/**
 * @brief Recovers the name of an indexer.
 *
 * @param indexer A pointer on the indexer.
 *
 * @returns A pointer on the name of the indexer.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
inline const char* obi_indexer_get_name(Obi_indexer_p indexer)
{
	return obi_avl_group_get_name(indexer);
}


178 179 180
/**
 * @brief Builds an indexer name in the form columnname_columnversion_indexer.
 *
181 182
 * @warning The returned pointer has to be freed by the caller.
 *
183 184 185 186 187 188 189 190 191
 * @param column_name The name of the column associated with the indexer.
 * @param column_version The version of the column associated with the indexer.
 *
 * @returns A pointer on the indexer name built.
 * @retval NULL if an error occurred.
 *
 * @since April 2016
 * @author Celine Mercier (celine.mercier@metabarcoding.org)
 */
192
char* obi_build_indexer_name(const char* column_name, obiversion_t column_version);
193 194


Celine Mercier committed
195 196
#endif /* OBIBLOB_INDEXER_H_ */