2016-06-11 21:12:43 +00:00
|
|
|
/*
|
2017-09-08 20:19:51 +00:00
|
|
|
* PROJECT: ReactOS Application compatibility module
|
|
|
|
* LICENSE: GPL-2.0+ (https://spdx.org/licenses/GPL-2.0+)
|
|
|
|
* PURPOSE: Shim database string table interface
|
|
|
|
* COPYRIGHT: Copyright 2016 Mark Jansen (mark.jansen@reactos.org)
|
2016-06-11 21:12:43 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SDBSTRINGTABLE_H
|
|
|
|
#define SDBSTRINGTABLE_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroy the hashtable and release all resources.
|
|
|
|
*
|
|
|
|
* @param [in] table Pointer to table pointer, will be cleared after use
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void SdbpTableDestroy(struct SdbStringHashTable* * table);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find an entry in the stringtable, or allocate it when an entry could not be found.
|
|
|
|
* - When the string specified does not yet exist, a new entry will be added to the table,
|
|
|
|
* and the pTagid specified will be associated with this string.
|
|
|
|
* - When the string specified does already exist,
|
|
|
|
* the TAGID associated with this string will be returned in pTagid.
|
2021-09-13 01:33:14 +00:00
|
|
|
*
|
2016-06-11 21:12:43 +00:00
|
|
|
*
|
|
|
|
* @param [in] table Pointer to table pointer, will be allocated when needed.
|
|
|
|
* @param [in] str The string to search for
|
2021-09-13 01:33:14 +00:00
|
|
|
* @param [in,out] pTagid
|
2016-06-11 21:12:43 +00:00
|
|
|
* the data written (in bytes)
|
|
|
|
*
|
|
|
|
* @return TRUE if the string was added to the table, FALSE if it already existed
|
|
|
|
*/
|
|
|
|
BOOL SdbpAddStringToTable(struct SdbStringHashTable* * table, const WCHAR* str, TAGID* pTagid);
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} // extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // SDBSTRINGTABLE_H
|