2001-09-07 18:42:29 +00:00
|
|
|
/*
|
|
|
|
******************************************************************************
|
|
|
|
*
|
2003-11-19 01:04:19 +00:00
|
|
|
* Copyright (C) 1999-2003, International Business Machines
|
2001-09-07 18:42:29 +00:00
|
|
|
* Corporation and others. All Rights Reserved.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
/*----------------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* UDataMemory A class-like struct that serves as a handle to a piece of memory
|
|
|
|
* that contains some ICU data (resource, converters, whatever.)
|
|
|
|
*
|
|
|
|
* When an application opens ICU data (with udata_open, for example,
|
|
|
|
* a UDataMemory * is returned.
|
|
|
|
*
|
|
|
|
*----------------------------------------------------------------------------------*/
|
|
|
|
#ifndef __UDATAMEM_H__
|
|
|
|
#define __UDATAMEM_H__
|
|
|
|
|
2001-09-08 00:27:05 +00:00
|
|
|
#include "unicode/udata.h"
|
2001-09-07 18:42:29 +00:00
|
|
|
#include "ucmndata.h"
|
|
|
|
|
2001-09-08 00:27:05 +00:00
|
|
|
struct UDataMemory {
|
2001-10-05 21:48:05 +00:00
|
|
|
const commonDataFuncs *vFuncs; /* Function Pointers for accessing TOC */
|
2001-09-08 00:27:05 +00:00
|
|
|
|
|
|
|
const DataHeader *pHeader; /* Header of the memory being described by this */
|
2002-02-28 01:42:40 +00:00
|
|
|
/* UDataMemory object. */
|
2001-09-08 00:27:05 +00:00
|
|
|
const void *toc; /* For common memory, table of contents for */
|
2002-02-28 01:42:40 +00:00
|
|
|
/* the pieces within. */
|
2001-09-08 00:27:05 +00:00
|
|
|
UBool heapAllocated; /* True if this UDataMemory Object is on the */
|
|
|
|
/* heap and thus needs to be deleted when closed. */
|
|
|
|
|
|
|
|
void *mapAddr; /* For mapped or allocated memory, the start addr. */
|
|
|
|
/* Only non-null if a close operation should unmap */
|
|
|
|
/* the associated data. */
|
|
|
|
void *map; /* Handle, or other data, OS dependent. */
|
|
|
|
/* Only non-null if a close operation should unmap */
|
|
|
|
/* the associated data, and additional info */
|
2002-02-28 01:42:40 +00:00
|
|
|
/* beyond the mapAddr is needed to do that. */
|
2003-11-19 01:04:19 +00:00
|
|
|
int32_t length; /* Length of the data in bytes; -1 if unknown. */
|
2001-09-08 00:27:05 +00:00
|
|
|
};
|
2001-09-07 18:42:29 +00:00
|
|
|
|
|
|
|
UDataMemory *UDataMemory_createNewInstance(UErrorCode *pErr);
|
|
|
|
void UDatamemory_assign (UDataMemory *dest, UDataMemory *source);
|
|
|
|
void UDataMemory_init (UDataMemory *This);
|
|
|
|
UBool UDataMemory_isLoaded(UDataMemory *This);
|
|
|
|
void UDataMemory_setData (UDataMemory *This, const void *dataAddr);
|
|
|
|
|
|
|
|
|
2001-10-05 21:48:05 +00:00
|
|
|
const DataHeader *UDataMemory_normalizeDataPointer(const void *p);
|
2003-12-06 01:29:37 +00:00
|
|
|
|
|
|
|
U_CAPI int32_t U_EXPORT2
|
|
|
|
udata_getLength(UDataMemory *pData);
|
|
|
|
|
|
|
|
U_CAPI const void * U_EXPORT2
|
|
|
|
udata_getRawMemory(UDataMemory *pData);
|
|
|
|
|
2001-09-07 18:42:29 +00:00
|
|
|
#endif
|
2001-09-08 00:27:05 +00:00
|
|
|
|