xmlsrv_plat/cxml_library_api/inc/nw_xmlp_xmlreader.h
author hgs
Wed, 23 Jun 2010 20:27:15 +0530
changeset 24 74f0b3eb154c
permissions -rw-r--r--
201024
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2000 - 2001 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: 
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    20
    @package:     NW_XML
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
    @synopsis:    default
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
    @description: default
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
#ifndef NW_XML_READER_H
hgs
parents:
diff changeset
    29
#define NW_XML_READER_H
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
#include <xml/cxml/cxml_proj.h>
hgs
parents:
diff changeset
    32
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    33
    @enum:        NW_XML_Endianness
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
    @synopsis:    Endian indication.
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
    @scope:       public
hgs
parents:
diff changeset
    38
    @names:
hgs
parents:
diff changeset
    39
       [NW_NATIVE_ENDIAN]
hgs
parents:
diff changeset
    40
                  Use native endianness.
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
       [NW_BIG_ENDIAN]
hgs
parents:
diff changeset
    43
                  The leftmost bytes (those with a lower address) are 
hgs
parents:
diff changeset
    44
                  most significant. 
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
       [NW_LITTLE_ENDIAN]
hgs
parents:
diff changeset
    47
                  The rightmost bytes (those with a higher address) are 
hgs
parents:
diff changeset
    48
                  most significant
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
    @description: Endian indication.
hgs
parents:
diff changeset
    51
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    52
typedef enum NW_XML_Endianness_e {
hgs
parents:
diff changeset
    53
  NW_NATIVE_ENDIAN,
hgs
parents:
diff changeset
    54
  NW_BIG_ENDIAN,
hgs
parents:
diff changeset
    55
  NW_LITTLE_ENDIAN
hgs
parents:
diff changeset
    56
} NW_XML_Endianness_t;
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
/* Remove references to this deprecated typedef */
hgs
parents:
diff changeset
    59
typedef NW_XML_Endianness_t NW_Endianness_t;
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    62
    @struct:      NW_XML_Reader_LineColumn
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
    @synopsis:    Line and column cursor.
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
    @scope:       public
hgs
parents:
diff changeset
    67
    @variables:
hgs
parents:
diff changeset
    68
       NW_Uint32 crCount
hgs
parents:
diff changeset
    69
                  Carriage return count.
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
       NW_Uint32 lfCount
hgs
parents:
diff changeset
    72
                  Line feed count.
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
       NW_Uint32 charsSinceLastCR
hgs
parents:
diff changeset
    75
                  Chars since last CR
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
       NW_Uint32 charsSinceLastLF
hgs
parents:
diff changeset
    78
                  Chars since last LF
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
    @description: Line and column cursor.  
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    83
typedef struct NW_XML_Reader_LineColumn_s{
hgs
parents:
diff changeset
    84
    NW_Uint32 crCount;
hgs
parents:
diff changeset
    85
    NW_Uint32 lfCount;
hgs
parents:
diff changeset
    86
    NW_Uint32 charsSinceLastCR;
hgs
parents:
diff changeset
    87
    NW_Uint32 charsSinceLastLF;
hgs
parents:
diff changeset
    88
}NW_XML_Reader_LineColumn_t;
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    92
    @struct:       NW_XML_Reader
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
    @synopsis:    The XML reader structure.
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
    @scope:       public
hgs
parents:
diff changeset
    97
    @variables:
hgs
parents:
diff changeset
    98
       NW_Uint32 encoding
hgs
parents:
diff changeset
    99
                  Character set encoding code in force at this index, 
hgs
parents:
diff changeset
   100
                  may change.
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
       NW_XML_Endianness_t endianness
hgs
parents:
diff changeset
   103
                  Big, little or native endianness indicator.
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
       NW_Uint32 index
hgs
parents:
diff changeset
   106
                  Current read position in pBuf, a byte index moved
hgs
parents:
diff changeset
   107
                  by character according to the encoding.
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
       NW_Uint32 charIndex
hgs
parents:
diff changeset
   110
                  Similar to index but in terms of characters not bytes.
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
       NW_XML_Reader_LineColumn_t lineColumn
hgs
parents:
diff changeset
   113
                  Information for giving text position as line and column,
hgs
parents:
diff changeset
   114
                  useful for reporting parsing failure.
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
       NW_Uint32 length
hgs
parents:
diff changeset
   117
                  Length of data.
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
       NW_Uint8* pBuf
hgs
parents:
diff changeset
   120
                  Text is stored in pBuf and the Reader functions provide
hgs
parents:
diff changeset
   121
                  the interface to the characters in pBuf.
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
       NW_Bool end
hgs
parents:
diff changeset
   124
                  End (like EOF): 0 = not at end, 1 = at end.
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
    @description: Users of Reader should not look directly inside the structure.
hgs
parents:
diff changeset
   127
                  Instead, use access functions and macros.
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   130
typedef struct NW_XML_Reader_s{
hgs
parents:
diff changeset
   131
    NW_Uint32 encoding;
hgs
parents:
diff changeset
   132
    NW_XML_Endianness_t endianness;
hgs
parents:
diff changeset
   133
    NW_Uint32 index;
hgs
parents:
diff changeset
   134
    NW_Uint32 charIndex;
hgs
parents:
diff changeset
   135
    NW_XML_Reader_LineColumn_t lineColumn;
hgs
parents:
diff changeset
   136
    NW_Uint32 length;
hgs
parents:
diff changeset
   137
    NW_Uint8* pBuf;
hgs
parents:
diff changeset
   138
    NW_Bool end;
hgs
parents:
diff changeset
   139
} NW_XML_Reader_t;
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   143
    @struct:      NW_XML_Reader_Interval
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
    @synopsis:    XML reader interval structure.
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
    @scope:       public
hgs
parents:
diff changeset
   148
    @variables:
hgs
parents:
diff changeset
   149
       NW_Uint32 start
hgs
parents:
diff changeset
   150
                  Byte index.
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
       NW_Uint32 stop
hgs
parents:
diff changeset
   153
                  Byte index.
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
       NW_Uint32 charStart
hgs
parents:
diff changeset
   156
                  Character index.
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
       NW_Uint32 charStop
hgs
parents:
diff changeset
   159
                  Character index.
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
    @description: Holds Reader index values defining an interval.
hgs
parents:
diff changeset
   162
                  Useful to mark a substring in a Reader.  If the text
hgs
parents:
diff changeset
   163
                  is "this is a sample" and the interval has start = 0,
hgs
parents:
diff changeset
   164
                  stop = 4 then the substring is "this".  Length is stop
hgs
parents:
diff changeset
   165
                  - start.  If both values are NW_UINT32_MAX then these
hgs
parents:
diff changeset
   166
                  are sentinel values meaning an initialized but unset
hgs
parents:
diff changeset
   167
                  interval, otherwise, if both are the same, it means
hgs
parents:
diff changeset
   168
                  start has been set but stop hasn't been set.  Don't
hgs
parents:
diff changeset
   169
                  directly set, use appropriate interval functions.
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
                  Note: You may also need to record the encoding that
hgs
parents:
diff changeset
   172
                  applies to this interval if Reader encoding has changed.
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   175
typedef struct NW_XML_Reader_Interval_s{
hgs
parents:
diff changeset
   176
    NW_Uint32 start;
hgs
parents:
diff changeset
   177
    NW_Uint32 stop;
hgs
parents:
diff changeset
   178
    NW_Uint32 charStart;
hgs
parents:
diff changeset
   179
    NW_Uint32 charStop;
hgs
parents:
diff changeset
   180
} NW_XML_Reader_Interval_t;
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
#ifdef __cplusplus
hgs
parents:
diff changeset
   184
extern "C"
hgs
parents:
diff changeset
   185
{
hgs
parents:
diff changeset
   186
#endif /* __cplusplus */
hgs
parents:
diff changeset
   187
hgs
parents:
diff changeset
   188
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   189
Reader Functions  
hgs
parents:
diff changeset
   190
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   194
    @function:    NW_XML_Reader_InitFromBuffer
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
    @synopsis:    Initialize from buffer.
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
    @scope:       public
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
    @parameters:
hgs
parents:
diff changeset
   201
       [in-out] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   202
                  The XML reader.
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
       [in] NW_Uint32 length
hgs
parents:
diff changeset
   205
                  Length of buffer.
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
       [in] unsigned char* pBuf
hgs
parents:
diff changeset
   208
                  The buffer.
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
    @description: Pass in pBuf, the pointer (not the data) will be copied 
hgs
parents:
diff changeset
   211
                  into the NW_XML_Reader_t.pBuf.
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   214
                  Status of operation.
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   217
                  Always returns success.
hgs
parents:
diff changeset
   218
hgs
parents:
diff changeset
   219
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   220
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   221
NW_XML_Reader_InitFromBuffer(NW_XML_Reader_t* pT, NW_Uint32 length, unsigned char* pBuf);
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
hgs
parents:
diff changeset
   224
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   225
    @function:    NW_XML_Reader_DataAddressFromBuffer
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
    @synopsis:    Gets pointer into buffer.
hgs
parents:
diff changeset
   228
hgs
parents:
diff changeset
   229
    @scope:       public
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
    @parameters:
hgs
parents:
diff changeset
   232
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   233
                  The XML reader.
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
       [in] NW_Uint32 startByteIndex
hgs
parents:
diff changeset
   236
                  The index.
hgs
parents:
diff changeset
   237
hgs
parents:
diff changeset
   238
       [in-out] NW_Uint32* byteLength
hgs
parents:
diff changeset
   239
                  IN as desired length, OUT as either desired length or
hgs
parents:
diff changeset
   240
                  remainder of buffer, whichever is less.
hgs
parents:
diff changeset
   241
hgs
parents:
diff changeset
   242
       [out] NW_Uint8** ppData
hgs
parents:
diff changeset
   243
                  Pointer to data.
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
    @description: Returns a pointer into pBuf in *ppData, clips length 
hgs
parents:
diff changeset
   246
                  to fit in buffer limits.
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   249
                  Status of operation.
hgs
parents:
diff changeset
   250
hgs
parents:
diff changeset
   251
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   252
                  Address resolved.
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   255
                  Index out of range.
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   258
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   259
NW_XML_Reader_DataAddressFromBuffer(NW_XML_Reader_t* pT, NW_Uint32 startByteIndex,
hgs
parents:
diff changeset
   260
                                 NW_Uint32* byteLength, NW_Uint8** ppData);
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
#define NW_XML_Reader_GetEncoding(pT) (((const NW_XML_Reader_t*)pT)->encoding)
hgs
parents:
diff changeset
   263
#define NW_XML_Reader_SetEncoding(pT, e) ((pT)->encoding = (e))
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
#define NW_XML_Reader_GetEndianness(pT) (((const NW_XML_Reader_t*)pT)->endianness)
hgs
parents:
diff changeset
   266
#define NW_XML_Reader_SetEndianness(pT, e) ((pT)->endianness = (e))
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   270
    @function:    NW_XML_Reader_GetPosition
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
    @synopsis:    Returns current position.
hgs
parents:
diff changeset
   273
hgs
parents:
diff changeset
   274
    @scope:       public
hgs
parents:
diff changeset
   275
hgs
parents:
diff changeset
   276
    @parameters:
hgs
parents:
diff changeset
   277
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   278
                  The XML reader.
hgs
parents:
diff changeset
   279
hgs
parents:
diff changeset
   280
       [out] NW_Uint32* pByteIndex
hgs
parents:
diff changeset
   281
                  Current byte index.
hgs
parents:
diff changeset
   282
hgs
parents:
diff changeset
   283
       [out] NW_Uint32* pCharIndex
hgs
parents:
diff changeset
   284
                  Current character index.
hgs
parents:
diff changeset
   285
hgs
parents:
diff changeset
   286
       [out] NW_XML_Reader_LineColumn_t* pLineColumn
hgs
parents:
diff changeset
   287
                  Current line and column.
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
    @description: Returns current position.
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   292
IMPORT_C
hgs
parents:
diff changeset
   293
void NW_XML_Reader_GetPosition(NW_XML_Reader_t* pT, NW_Uint32* pByteIndex,
hgs
parents:
diff changeset
   294
                               NW_Uint32* pCharIndex,
hgs
parents:
diff changeset
   295
                               NW_XML_Reader_LineColumn_t* pLineColumn);
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
hgs
parents:
diff changeset
   298
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   299
    @function:    NW_XML_Reader_SetPosition
hgs
parents:
diff changeset
   300
hgs
parents:
diff changeset
   301
    @synopsis:    Sets position in reader.
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
    @scope:       public
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
    @parameters:
hgs
parents:
diff changeset
   306
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   307
                  The XML reader.
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
       [in] NW_Uint32 byteIndex
hgs
parents:
diff changeset
   310
                  The byte index.
hgs
parents:
diff changeset
   311
hgs
parents:
diff changeset
   312
       [in] NW_Uint32 charIndex
hgs
parents:
diff changeset
   313
                  The character index.
hgs
parents:
diff changeset
   314
hgs
parents:
diff changeset
   315
       [in] const pLineColumn
hgs
parents:
diff changeset
   316
                  The line and column.
hgs
parents:
diff changeset
   317
hgs
parents:
diff changeset
   318
    @description: Setting the position (similar to seeking in a file) is
hgs
parents:
diff changeset
   319
                  in general not possible without reading the characters
hgs
parents:
diff changeset
   320
                  (usually reading forward) because character encoding
hgs
parents:
diff changeset
   321
                  may use a variable numbers of bytes per character. This
hgs
parents:
diff changeset
   322
                  is here so that if you have defined a valid interval, 
hgs
parents:
diff changeset
   323
                  then you can reposition to the beginning of the interval.
hgs
parents:
diff changeset
   324
                  Setting to the position to a bad value will not always be
hgs
parents:
diff changeset
   325
                  caught immediately.
hgs
parents:
diff changeset
   326
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   327
IMPORT_C
hgs
parents:
diff changeset
   328
void NW_XML_Reader_SetPosition(NW_XML_Reader_t* pT, NW_Uint32 byteIndex,
hgs
parents:
diff changeset
   329
                               NW_Uint32 charIndex,
hgs
parents:
diff changeset
   330
                               const NW_XML_Reader_LineColumn_t* pLineColumn);
hgs
parents:
diff changeset
   331
hgs
parents:
diff changeset
   332
hgs
parents:
diff changeset
   333
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   334
    @function:    NW_XML_Reader_GetLineColumn
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
    @synopsis:    Gets estimate of line and column.
hgs
parents:
diff changeset
   337
hgs
parents:
diff changeset
   338
    @scope:       public
hgs
parents:
diff changeset
   339
hgs
parents:
diff changeset
   340
    @parameters:
hgs
parents:
diff changeset
   341
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   342
                  The XML reader.
hgs
parents:
diff changeset
   343
hgs
parents:
diff changeset
   344
       [out] NW_Uint32* pLine
hgs
parents:
diff changeset
   345
                  The current line.
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
       [out] NW_Uint32* pColumn
hgs
parents:
diff changeset
   348
                  The current column.
hgs
parents:
diff changeset
   349
hgs
parents:
diff changeset
   350
    @description: Returns an estimate of the current line and column 
hgs
parents:
diff changeset
   351
                  position in the text. It is an estimate because it has
hgs
parents:
diff changeset
   352
                  to guess at what the intended line ending sequence is 
hgs
parents:
diff changeset
   353
                  using a count of CR and LF characters.  Line and Column
hgs
parents:
diff changeset
   354
                  indices are 1-based not 0-based.
hgs
parents:
diff changeset
   355
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   356
IMPORT_C
hgs
parents:
diff changeset
   357
void NW_XML_Reader_GetLineColumn(NW_XML_Reader_t* pT, NW_Uint32* pLine,
hgs
parents:
diff changeset
   358
                                 NW_Uint32* pColumn);
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
#define NW_XML_Reader_AtEnd(pT) (((const NW_XML_Reader_t*)pT)->end)
hgs
parents:
diff changeset
   361
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   364
    @function:    NW_XML_Reader_PeekOffset
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
    @synopsis:    Peeks at offset.
hgs
parents:
diff changeset
   367
hgs
parents:
diff changeset
   368
    @scope:       public
hgs
parents:
diff changeset
   369
hgs
parents:
diff changeset
   370
    @parameters:
hgs
parents:
diff changeset
   371
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   372
                  The XML reader.
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
       [in] NW_Uint32 nChars
hgs
parents:
diff changeset
   375
                  Offset in characters.
hgs
parents:
diff changeset
   376
hgs
parents:
diff changeset
   377
       [out] NW_Uint32* pC
hgs
parents:
diff changeset
   378
                  Address of character at offset.
hgs
parents:
diff changeset
   379
hgs
parents:
diff changeset
   380
    @description: Fails on encountering illegal char anywhere from current 
hgs
parents:
diff changeset
   381
                  read position to offset position or if position is illegal
hgs
parents:
diff changeset
   382
                  (e.g., off end).  Leaves read position unchanged.
hgs
parents:
diff changeset
   383
hgs
parents:
diff changeset
   384
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   385
                  Status of operation.
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   388
                  Address returned.
hgs
parents:
diff changeset
   389
hgs
parents:
diff changeset
   390
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   391
                  Invalid offset or at end of file.
hgs
parents:
diff changeset
   392
hgs
parents:
diff changeset
   393
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   394
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   395
NW_XML_Reader_PeekOffset(NW_XML_Reader_t* pT, NW_Uint32 nChars, NW_Uint32* pC);
hgs
parents:
diff changeset
   396
hgs
parents:
diff changeset
   397
#define NW_XML_Reader_Peek(pT, pC) NW_XML_Reader_PeekOffset((pT), 0, (pC))
hgs
parents:
diff changeset
   398
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   401
    @function:    NW_XML_Reader_AdvanceOffset
hgs
parents:
diff changeset
   402
hgs
parents:
diff changeset
   403
    @synopsis:    Advances offset in reader.
hgs
parents:
diff changeset
   404
hgs
parents:
diff changeset
   405
    @scope:       public
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
    @parameters:
hgs
parents:
diff changeset
   408
       [in-out] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   409
                  The XML reader.
hgs
parents:
diff changeset
   410
hgs
parents:
diff changeset
   411
       [in] NW_Uint32 nChars
hgs
parents:
diff changeset
   412
                  Offset to move in characters.
hgs
parents:
diff changeset
   413
hgs
parents:
diff changeset
   414
    @description: Fails on encountering illegal char anywhere from 
hgs
parents:
diff changeset
   415
                  current read position to offset position or if 
hgs
parents:
diff changeset
   416
                  position is illegal (e.g., off end).  Moves read
hgs
parents:
diff changeset
   417
                  position to current + offset.
hgs
parents:
diff changeset
   418
hgs
parents:
diff changeset
   419
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   420
                  Status of operation.
hgs
parents:
diff changeset
   421
hgs
parents:
diff changeset
   422
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   423
                  Read position advanced nChars.
hgs
parents:
diff changeset
   424
hgs
parents:
diff changeset
   425
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   426
                  Invalid offset or at end of file, reader not advanced.
hgs
parents:
diff changeset
   427
hgs
parents:
diff changeset
   428
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   429
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   430
NW_XML_Reader_AdvanceOffset(NW_XML_Reader_t* pT, NW_Uint32 nChars);
hgs
parents:
diff changeset
   431
hgs
parents:
diff changeset
   432
#define NW_XML_Reader_Advance(pT) NW_XML_Reader_AdvanceOffset((pT), 1)
hgs
parents:
diff changeset
   433
hgs
parents:
diff changeset
   434
hgs
parents:
diff changeset
   435
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   436
    @function:    NW_XML_Reader_AsciiCharMatch
hgs
parents:
diff changeset
   437
hgs
parents:
diff changeset
   438
    @synopsis:    Tests for character match.
hgs
parents:
diff changeset
   439
    @scope:       public
hgs
parents:
diff changeset
   440
hgs
parents:
diff changeset
   441
    @parameters:
hgs
parents:
diff changeset
   442
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   443
                  The XML reader.
hgs
parents:
diff changeset
   444
hgs
parents:
diff changeset
   445
       [in] NW_Uint32 c
hgs
parents:
diff changeset
   446
                  The character to match.
hgs
parents:
diff changeset
   447
hgs
parents:
diff changeset
   448
       [out] NW_Uint32* pMatch
hgs
parents:
diff changeset
   449
                  default
hgs
parents:
diff changeset
   450
hgs
parents:
diff changeset
   451
    @description: pMatch is 1 if ASCII character c matches Reader char in its encoding.
hgs
parents:
diff changeset
   452
hgs
parents:
diff changeset
   453
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   454
                  Status of operation.
hgs
parents:
diff changeset
   455
hgs
parents:
diff changeset
   456
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   457
                  Match results are valid.
hgs
parents:
diff changeset
   458
hgs
parents:
diff changeset
   459
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   460
                  Match results are not valid. Invalid offset or at end of file.
hgs
parents:
diff changeset
   461
hgs
parents:
diff changeset
   462
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   463
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   464
NW_XML_Reader_AsciiCharMatch(NW_XML_Reader_t* pT, NW_Uint32 c, NW_Uint32* pMatch);
hgs
parents:
diff changeset
   465
hgs
parents:
diff changeset
   466
hgs
parents:
diff changeset
   467
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   468
    @function:    NW_XML_Reader_AsciiStringMatch
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
    @synopsis:    Tests for character match.
hgs
parents:
diff changeset
   471
hgs
parents:
diff changeset
   472
    @scope:       public
hgs
parents:
diff changeset
   473
hgs
parents:
diff changeset
   474
    @parameters:
hgs
parents:
diff changeset
   475
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   476
                  The XML reader.
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
       [in] NW_Uint32 length
hgs
parents:
diff changeset
   479
                  String length.
hgs
parents:
diff changeset
   480
hgs
parents:
diff changeset
   481
       [in] const NW_Uint8* pString,
hgs
parents:
diff changeset
   482
                  String characters.
hgs
parents:
diff changeset
   483
hgs
parents:
diff changeset
   484
       [out] NW_Uint32* pMatch
hgs
parents:
diff changeset
   485
                  1 if match, otherwise 0.
hgs
parents:
diff changeset
   486
hgs
parents:
diff changeset
   487
    @description: pMatch is 1 if ASCII string matches Reader sequence in its encoding.
hgs
parents:
diff changeset
   488
hgs
parents:
diff changeset
   489
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   490
                  Status of operation.
hgs
parents:
diff changeset
   491
hgs
parents:
diff changeset
   492
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   493
                  Match results are valid.
hgs
parents:
diff changeset
   494
hgs
parents:
diff changeset
   495
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   496
                  Match results are not valid. Invalid offset or at end of file.
hgs
parents:
diff changeset
   497
hgs
parents:
diff changeset
   498
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   499
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   500
NW_XML_Reader_AsciiStringMatch(NW_XML_Reader_t* pT, NW_Uint32 length, const NW_Uint8* pString,
hgs
parents:
diff changeset
   501
                               NW_Uint32* pMatch);
hgs
parents:
diff changeset
   502
hgs
parents:
diff changeset
   503
hgs
parents:
diff changeset
   504
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   505
    @function:    NW_XML_Reader_SkipSpace
hgs
parents:
diff changeset
   506
hgs
parents:
diff changeset
   507
    @synopsis:    Skip a space.
hgs
parents:
diff changeset
   508
hgs
parents:
diff changeset
   509
    @scope:       public
hgs
parents:
diff changeset
   510
hgs
parents:
diff changeset
   511
    @parameters:
hgs
parents:
diff changeset
   512
       [in-out] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   513
                  The XML reader.
hgs
parents:
diff changeset
   514
hgs
parents:
diff changeset
   515
    @description: Skip a space. For XML, whitespace is only ASCII 
hgs
parents:
diff changeset
   516
                  0x20 (space), 0x09 (tab), 0x0d (CR), 0x0a (LF).
hgs
parents:
diff changeset
   517
                  The base test used here, NW_Str_Isspace(), includes
hgs
parents:
diff changeset
   518
                  two other forms of whitespace.
hgs
parents:
diff changeset
   519
hgs
parents:
diff changeset
   520
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   521
                  Status of operation.
hgs
parents:
diff changeset
   522
hgs
parents:
diff changeset
   523
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   524
                  Skip successful.
hgs
parents:
diff changeset
   525
hgs
parents:
diff changeset
   526
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   527
                  Skip not done. Invalid offset or at end of file.
hgs
parents:
diff changeset
   528
hgs
parents:
diff changeset
   529
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   530
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   531
NW_XML_Reader_SkipSpace(NW_XML_Reader_t* pT);
hgs
parents:
diff changeset
   532
hgs
parents:
diff changeset
   533
hgs
parents:
diff changeset
   534
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   535
    @function:    NW_XML_Reader_IsSpace
hgs
parents:
diff changeset
   536
hgs
parents:
diff changeset
   537
    @synopsis:    Tests for space.
hgs
parents:
diff changeset
   538
hgs
parents:
diff changeset
   539
    @scope:       public
hgs
parents:
diff changeset
   540
hgs
parents:
diff changeset
   541
    @parameters:
hgs
parents:
diff changeset
   542
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   543
                  The XML reader.
hgs
parents:
diff changeset
   544
hgs
parents:
diff changeset
   545
       [out] NW_Uint32* pMatch
hgs
parents:
diff changeset
   546
                  1 if space, otherwise 0.
hgs
parents:
diff changeset
   547
hgs
parents:
diff changeset
   548
    @description: Tests for space. For XML, whitespace is only ASCII 
hgs
parents:
diff changeset
   549
                  0x20 (space), 0x09 (tab), 0x0d (CR), 0x0a (LF).  The 
hgs
parents:
diff changeset
   550
                  base test used here, NW_Str_Isspace(), includes two 
hgs
parents:
diff changeset
   551
                  other forms of whitespace. 
hgs
parents:
diff changeset
   552
hgs
parents:
diff changeset
   553
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   554
                  Status of operation.
hgs
parents:
diff changeset
   555
hgs
parents:
diff changeset
   556
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   557
                  Test results are valid.
hgs
parents:
diff changeset
   558
hgs
parents:
diff changeset
   559
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   560
                  Test results are not valid. Invalid offset or at end of file.
hgs
parents:
diff changeset
   561
hgs
parents:
diff changeset
   562
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   563
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   564
NW_XML_Reader_IsSpace(NW_XML_Reader_t* pT, NW_Uint32* pMatch);
hgs
parents:
diff changeset
   565
hgs
parents:
diff changeset
   566
hgs
parents:
diff changeset
   567
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   568
    @function:    NW_XML_Reader_IsLetter
hgs
parents:
diff changeset
   569
hgs
parents:
diff changeset
   570
    @synopsis:    Tests for letter.
hgs
parents:
diff changeset
   571
hgs
parents:
diff changeset
   572
    @scope:       public
hgs
parents:
diff changeset
   573
hgs
parents:
diff changeset
   574
    @parameters:
hgs
parents:
diff changeset
   575
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   576
                  The XML reader.
hgs
parents:
diff changeset
   577
hgs
parents:
diff changeset
   578
       [out] NW_Uint32* pMatch
hgs
parents:
diff changeset
   579
                  1 if letter, otherwise 0.
hgs
parents:
diff changeset
   580
hgs
parents:
diff changeset
   581
    @description: Tests for letter.
hgs
parents:
diff changeset
   582
hgs
parents:
diff changeset
   583
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   584
                  Status of operation.
hgs
parents:
diff changeset
   585
hgs
parents:
diff changeset
   586
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   587
                  Test results are valid.
hgs
parents:
diff changeset
   588
hgs
parents:
diff changeset
   589
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   590
                  Test results are not valid. Invalid offset or at end of file.
hgs
parents:
diff changeset
   591
hgs
parents:
diff changeset
   592
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   593
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   594
NW_XML_Reader_IsLetter(NW_XML_Reader_t* pT, NW_Uint32* pMatch);
hgs
parents:
diff changeset
   595
hgs
parents:
diff changeset
   596
hgs
parents:
diff changeset
   597
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   598
    @function:    NW_XML_Reader_IsDigit
hgs
parents:
diff changeset
   599
hgs
parents:
diff changeset
   600
    @synopsis:    Tests for digit.
hgs
parents:
diff changeset
   601
hgs
parents:
diff changeset
   602
    @scope:       public
hgs
parents:
diff changeset
   603
hgs
parents:
diff changeset
   604
    @parameters:
hgs
parents:
diff changeset
   605
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   606
                  The XML reader.
hgs
parents:
diff changeset
   607
hgs
parents:
diff changeset
   608
       [out] NW_Uint32* pMatch
hgs
parents:
diff changeset
   609
                  1 if letter, otherwise 0.
hgs
parents:
diff changeset
   610
hgs
parents:
diff changeset
   611
    @description: Tests for digit. Digits include not only the ASCII
hgs
parents:
diff changeset
   612
                  digits but other language forms of digits.  The base
hgs
parents:
diff changeset
   613
                  test used here, NW_Str_Isdigit() only tests for ASCII 
hgs
parents:
diff changeset
   614
                  digits.
hgs
parents:
diff changeset
   615
hgs
parents:
diff changeset
   616
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   617
                  Status of operation.
hgs
parents:
diff changeset
   618
hgs
parents:
diff changeset
   619
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   620
                  Test results are valid.
hgs
parents:
diff changeset
   621
hgs
parents:
diff changeset
   622
       [NW_STAT_FAILURE]
hgs
parents:
diff changeset
   623
                  Test results are not valid. Invalid offset or at end of file.
hgs
parents:
diff changeset
   624
hgs
parents:
diff changeset
   625
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   626
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   627
NW_XML_Reader_IsDigit(NW_XML_Reader_t* pT, NW_Uint32* pMatch);
hgs
parents:
diff changeset
   628
hgs
parents:
diff changeset
   629
hgs
parents:
diff changeset
   630
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   631
   Reader Interval Functions  
hgs
parents:
diff changeset
   632
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   633
hgs
parents:
diff changeset
   634
hgs
parents:
diff changeset
   635
/* Always initialize the interval. */
hgs
parents:
diff changeset
   636
#define NW_XML_Reader_Interval_Init(pI) \
hgs
parents:
diff changeset
   637
    ((pI)->start = (pI)->stop = (pI)->charStart = (pI)->charStop = NW_UINT32_MAX)
hgs
parents:
diff changeset
   638
hgs
parents:
diff changeset
   639
/* Useful in error tests and asserts. */
hgs
parents:
diff changeset
   640
#define NW_XML_Reader_Interval_IsWellFormed(pI) \
hgs
parents:
diff changeset
   641
    (((pI)->stop > (pI)->start) && ((pI)->charStop > (pI)->charStart))
hgs
parents:
diff changeset
   642
hgs
parents:
diff changeset
   643
hgs
parents:
diff changeset
   644
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   645
    @function:    NW_XML_Reader_Interval_Start
hgs
parents:
diff changeset
   646
hgs
parents:
diff changeset
   647
    @synopsis:    Initializes interval to current position.
hgs
parents:
diff changeset
   648
hgs
parents:
diff changeset
   649
    @scope:       public
hgs
parents:
diff changeset
   650
hgs
parents:
diff changeset
   651
    @parameters:
hgs
parents:
diff changeset
   652
       [out] NW_XML_Reader_Interval_t* pI
hgs
parents:
diff changeset
   653
                  The XML reader interval.
hgs
parents:
diff changeset
   654
hgs
parents:
diff changeset
   655
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   656
                  The XML reader.
hgs
parents:
diff changeset
   657
hgs
parents:
diff changeset
   658
    @description: Sets start, stop, charStart, charStop to current 
hgs
parents:
diff changeset
   659
                  Reader position.
hgs
parents:
diff changeset
   660
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   661
IMPORT_C void
hgs
parents:
diff changeset
   662
NW_XML_Reader_Interval_Start(NW_XML_Reader_Interval_t* pI, NW_XML_Reader_t* pT);
hgs
parents:
diff changeset
   663
hgs
parents:
diff changeset
   664
hgs
parents:
diff changeset
   665
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   666
    @function:    NW_XML_Reader_Interval_Stop
hgs
parents:
diff changeset
   667
hgs
parents:
diff changeset
   668
    @synopsis:    Sets stop to Reader read index.
hgs
parents:
diff changeset
   669
hgs
parents:
diff changeset
   670
    @scope:       public
hgs
parents:
diff changeset
   671
hgs
parents:
diff changeset
   672
    @parameters:
hgs
parents:
diff changeset
   673
       [out] NW_XML_Reader_Interval_t* pI
hgs
parents:
diff changeset
   674
                  The XML reader interval.
hgs
parents:
diff changeset
   675
hgs
parents:
diff changeset
   676
       [in] NW_XML_Reader_t* pT
hgs
parents:
diff changeset
   677
                  The XML reader.
hgs
parents:
diff changeset
   678
hgs
parents:
diff changeset
   679
    @description: Sets stop to Reader read index.
hgs
parents:
diff changeset
   680
hgs
parents:
diff changeset
   681
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   682
IMPORT_C void
hgs
parents:
diff changeset
   683
NW_XML_Reader_Interval_Stop(NW_XML_Reader_Interval_t* pI, NW_XML_Reader_t* pT);
hgs
parents:
diff changeset
   684
hgs
parents:
diff changeset
   685
#ifdef __cplusplus
hgs
parents:
diff changeset
   686
} /* extern "C" { */
hgs
parents:
diff changeset
   687
#endif /* __cplusplus */
hgs
parents:
diff changeset
   688
hgs
parents:
diff changeset
   689
#endif /* NW_XML_READER_H */