xmlsrv_plat/cxml_library_api/inc/nw_wbxml_parse.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_WBXML
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
    @synopsis:    default
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
    @description: Wbxml token definitions
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
#ifndef NW_PARSER_WBXML_PARSE_H
hgs
parents:
diff changeset
    29
#define NW_PARSER_WBXML_PARSE_H
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
#include <xml/cxml/cxml_proj.h>
hgs
parents:
diff changeset
    32
#include <xml/cxml/nw_wbxml_token.h>
hgs
parents:
diff changeset
    33
#include <xml/cxml/nw_wbxml_event.h>
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
#ifdef __cplusplus
hgs
parents:
diff changeset
    36
extern "C" {
hgs
parents:
diff changeset
    37
#endif /* __cplusplus */
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    41
    @struct:      NW_WBXML_CP_Registry_Entry
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
    @synopsis:    Registry entry.
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
    @scope:       public
hgs
parents:
diff changeset
    46
    @variables:
hgs
parents:
diff changeset
    47
       NW_Uint8 code_page
hgs
parents:
diff changeset
    48
                  The code page.
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
       NW_Uint32 start_offset
hgs
parents:
diff changeset
    51
                  Start offset.
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
    @description: Each entry must record if it is for tokens or attributes.
hgs
parents:
diff changeset
    54
                  A trick to encode this without extra memory relies on the
hgs
parents:
diff changeset
    55
                  use of two bytes in WBXML to encode a page switch.  With two 
hgs
parents:
diff changeset
    56
                  bytes one has an even offset and one an odd offset.  We pick
hgs
parents:
diff changeset
    57
                  the even if it is a tag page and the odd offset if it is an 
hgs
parents:
diff changeset
    58
                  attribute page. 
hgs
parents:
diff changeset
    59
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    60
typedef struct NW_WBXML_CP_Registry_Entry_s{
hgs
parents:
diff changeset
    61
  NW_Uint8 code_page;
hgs
parents:
diff changeset
    62
  NW_Uint32 start_offset;
hgs
parents:
diff changeset
    63
}NW_WBXML_CP_Registry_Entry_t;
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    67
    @struct:      NW_WBXML_CP_Registry
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
    @synopsis:    The code page registry.
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
    @scope:       public
hgs
parents:
diff changeset
    72
    @variables:
hgs
parents:
diff changeset
    73
       NW_WBXML_CP_Registry_Entry_t* storage
hgs
parents:
diff changeset
    74
                  Storage array.
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
       NW_WBXML_CP_Registry_Entry_t* current
hgs
parents:
diff changeset
    77
                  Current entry.
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
       NW_Int32 count
hgs
parents:
diff changeset
    80
                  Entry count.
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    @description: The code page registry.
hgs
parents:
diff changeset
    83
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    84
typedef struct NW_WBXML_CP_Registry_s {
hgs
parents:
diff changeset
    85
  NW_WBXML_CP_Registry_Entry_t* storage;
hgs
parents:
diff changeset
    86
  NW_WBXML_CP_Registry_Entry_t* current;
hgs
parents:
diff changeset
    87
  NW_Int32 count;
hgs
parents:
diff changeset
    88
  // WLIU_DEBUG:NW_Int32 realcount;
hgs
parents:
diff changeset
    89
} NW_WBXML_CP_Registry_t;
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    92
   TO DO: the NW_Byte code pointer needs to be removed and put into a
hgs
parents:
diff changeset
    93
   derived class in the buffer implementation 
hgs
parents:
diff changeset
    94
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
    97
    @struct:      NW_WBXML_Parser
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
    @synopsis:    The parser.
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
    @scope:       public
hgs
parents:
diff changeset
   102
    @variables:
hgs
parents:
diff changeset
   103
       const struct NW_WBXML_EventHandler_s* handler
hgs
parents:
diff changeset
   104
                  Event handlers.
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
       void* context
hgs
parents:
diff changeset
   107
                  Context to pass to event handlers.
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
       NW_Uint32 flags
hgs
parents:
diff changeset
   110
                  The flags.
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
       NW_Uint32 state
hgs
parents:
diff changeset
   113
                  The state.
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
       NW_Uint8 tag_code_page
hgs
parents:
diff changeset
   116
                  The tag code page.
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
       NW_Uint8 attribute_code_page
hgs
parents:
diff changeset
   119
                  The attribute code page.
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
       NW_WBXML_CP_Registry_t cp_registry
hgs
parents:
diff changeset
   122
                  The code page registry.
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
       NW_Uint32 dictionary
hgs
parents:
diff changeset
   125
                  1-based index into dictionary table.
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
       NW_WBXML_Document_t* doc
hgs
parents:
diff changeset
   128
                  The document.
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
       NW_Uint32 offset
hgs
parents:
diff changeset
   131
                  Offset into bytecode.
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
       NW_Uint32 left
hgs
parents:
diff changeset
   134
                  Byte code left after current pointer.
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
       NW_Status_t status
hgs
parents:
diff changeset
   137
                  Parser status from CallBacks.
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
       NW_Byte* p
hgs
parents:
diff changeset
   140
                  Byte code pointer.
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
       NW_Uint8 ext_t_not_table_index
hgs
parents:
diff changeset
   143
                  A boolean: whether the associated index with
hgs
parents:
diff changeset
   144
                  EXT_T_[0,1,2] refs a string table or not, defaults
hgs
parents:
diff changeset
   145
                  to 0 meaning use string table, 1 means associated
hgs
parents:
diff changeset
   146
                  integer with EXT_T_[0,1,2] is not a string table
hgs
parents:
diff changeset
   147
                  index
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    @description: The parser.
hgs
parents:
diff changeset
   150
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   151
struct NW_WBXML_Parser_s {
hgs
parents:
diff changeset
   152
  const struct NW_WBXML_EventHandler_s* handler; /* Event handlers */
hgs
parents:
diff changeset
   153
  void* context;                           /* Context to pass to event handlers */
hgs
parents:
diff changeset
   154
  NW_Uint32 flags;                         
hgs
parents:
diff changeset
   155
  NW_Uint32 state;
hgs
parents:
diff changeset
   156
  NW_Uint8 tag_code_page;
hgs
parents:
diff changeset
   157
  NW_Uint8 attribute_code_page;
hgs
parents:
diff changeset
   158
  NW_WBXML_CP_Registry_t cp_registry;
hgs
parents:
diff changeset
   159
  NW_Uint32 dictionary;                     /* 1-based index into dictionary table */
hgs
parents:
diff changeset
   160
  NW_WBXML_Document_t* doc;
hgs
parents:
diff changeset
   161
  NW_Uint32 offset;                          /*Offset into bytecode */
hgs
parents:
diff changeset
   162
  NW_Uint32 left;                            /* Byte code left after current pointer */
hgs
parents:
diff changeset
   163
  NW_Status_t status;                       /* Parser status from CallBacks */
hgs
parents:
diff changeset
   164
  NW_Byte* p;                               /*Byte code pointer */
hgs
parents:
diff changeset
   165
  NW_Uint32 recursiveCallCnt;               /* counts "element parse/content parse" recursive calls*/
hgs
parents:
diff changeset
   166
  /* a boolean, whether EXT_T_[0,1,2] refs a string table or not,
hgs
parents:
diff changeset
   167
     defaults to 0 meaning use string table, 1 means associated
hgs
parents:
diff changeset
   168
     integer with EXT_T_[0,1,2] is not a string table index */
hgs
parents:
diff changeset
   169
  NW_Uint8 ext_t_not_table_index;
hgs
parents:
diff changeset
   170
//  WLIU_DEBUG: NW_Int32 lastValid;
hgs
parents:
diff changeset
   171
};
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   176
    @function:    NW_WBXML_Parser_newInPlace
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
    @synopsis:    Parser initialization 
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
    @scope:       public
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
    @parameters:
hgs
parents:
diff changeset
   183
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   184
                  The parser.
hgs
parents:
diff changeset
   185
hgs
parents:
diff changeset
   186
    @description: Parser initialization 
hgs
parents:
diff changeset
   187
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   188
IMPORT_C void
hgs
parents:
diff changeset
   189
NW_WBXML_Parser_newInPlace (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   193
    @function:    NW_WBXML_Parser_reset
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
    @synopsis:    Reset the parser.
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
    @scope:       public
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
    @parameters:
hgs
parents:
diff changeset
   200
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   201
                  The parser.
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
    @description: Reset the parser.
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   206
void
hgs
parents:
diff changeset
   207
NW_WBXML_Parser_reset (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   211
    @function:    NW_WBXML_Parser_delete
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
    @synopsis:    Destructor.
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
    @scope:       public
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
    @parameters:
hgs
parents:
diff changeset
   218
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   219
                  The parser.
hgs
parents:
diff changeset
   220
hgs
parents:
diff changeset
   221
    @description: Destructor.
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   224
void
hgs
parents:
diff changeset
   225
NW_WBXML_Parser_delete (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   229
    @function:    NW_WBXML_Parser_addCPRegistry
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
    @synopsis:    Add CP registry.
hgs
parents:
diff changeset
   232
hgs
parents:
diff changeset
   233
    @scope:       public
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
    @parameters:
hgs
parents:
diff changeset
   236
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   237
                  The parser.
hgs
parents:
diff changeset
   238
hgs
parents:
diff changeset
   239
       [in] NW_WBXML_CP_Registry_Entry_t* storage
hgs
parents:
diff changeset
   240
                  The entries.
hgs
parents:
diff changeset
   241
hgs
parents:
diff changeset
   242
       [in] NW_Int32 count
hgs
parents:
diff changeset
   243
                  The number of entries.
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
    @description: Create an uninitialized code page registry. As long
hgs
parents:
diff changeset
   246
                  as the registry is not created, it will be
hgs
parents:
diff changeset
   247
                  ignored. Once it has been created, the parser will
hgs
parents:
diff changeset
   248
                  check the REGISTRY_INIT flag. If this is not set, the
hgs
parents:
diff changeset
   249
                  registry will be initialized as the parser runs. If
hgs
parents:
diff changeset
   250
                  this is set, then the registry will be consulted when
hgs
parents:
diff changeset
   251
                  updating the offset.
hgs
parents:
diff changeset
   252
hgs
parents:
diff changeset
   253
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   254
                  Status of operation.
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   257
                  Always returns success.
hgs
parents:
diff changeset
   258
hgs
parents:
diff changeset
   259
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   260
NW_Status_t
hgs
parents:
diff changeset
   261
NW_WBXML_Parser_addCPRegistry(NW_WBXML_Parser_t* parser,
hgs
parents:
diff changeset
   262
                              NW_WBXML_CP_Registry_Entry_t* storage,
hgs
parents:
diff changeset
   263
                              NW_Int32 count);
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   267
    @function:    NW_WBXML_Parser_registerHandler
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
    @synopsis:    Register handler.
hgs
parents:
diff changeset
   270
hgs
parents:
diff changeset
   271
    @scope:       public
hgs
parents:
diff changeset
   272
hgs
parents:
diff changeset
   273
    @parameters:
hgs
parents:
diff changeset
   274
       [in] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   275
                  The parser.
hgs
parents:
diff changeset
   276
hgs
parents:
diff changeset
   277
       [in] const struct NW_WBXML_EventHandler_s* handler
hgs
parents:
diff changeset
   278
                  The handler.
hgs
parents:
diff changeset
   279
hgs
parents:
diff changeset
   280
       [in] void* context
hgs
parents:
diff changeset
   281
                  The context.
hgs
parents:
diff changeset
   282
hgs
parents:
diff changeset
   283
    @description: Cache the parser's event handler and context.
hgs
parents:
diff changeset
   284
hgs
parents:
diff changeset
   285
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   286
                  Status of operation.
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   289
                  Always returns success.
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   292
IMPORT_C NW_Status_t
hgs
parents:
diff changeset
   293
NW_WBXML_Parser_registerHandler(NW_WBXML_Parser_t* parser,
hgs
parents:
diff changeset
   294
                                const struct NW_WBXML_EventHandler_s* handler,
hgs
parents:
diff changeset
   295
                                void* context);
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
hgs
parents:
diff changeset
   298
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   299
    @function:    NW_WBXML_Parser_saveContext
hgs
parents:
diff changeset
   300
hgs
parents:
diff changeset
   301
    @synopsis:    Save parser context.
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_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   307
                  The parser.
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
       [out] NW_WBXML_Parser_t* context
hgs
parents:
diff changeset
   310
                  The context.
hgs
parents:
diff changeset
   311
hgs
parents:
diff changeset
   312
    @description: Save/restore context can be used if the parser is to be
hgs
parents:
diff changeset
   313
                  invoked reentrantly (in a callback).  Normally this should
hgs
parents:
diff changeset
   314
                  be avoided since the only really safe way to do this is to
hgs
parents:
diff changeset
   315
                  save the whole parser object on the stack. 
hgs
parents:
diff changeset
   316
hgs
parents:
diff changeset
   317
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   318
                  Status of operation.
hgs
parents:
diff changeset
   319
hgs
parents:
diff changeset
   320
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   321
                  Always returns success.
hgs
parents:
diff changeset
   322
hgs
parents:
diff changeset
   323
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   324
NW_Status_t
hgs
parents:
diff changeset
   325
NW_WBXML_Parser_saveContext(NW_WBXML_Parser_t* parser,
hgs
parents:
diff changeset
   326
                            NW_WBXML_Parser_t* context);
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   330
    @function:    NW_WBXML_Parser_restoreContext
hgs
parents:
diff changeset
   331
hgs
parents:
diff changeset
   332
    @synopsis:    Restore parser context.
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
    @scope:       public
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
    @parameters:
hgs
parents:
diff changeset
   337
       [in] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   338
                  The parser.
hgs
parents:
diff changeset
   339
hgs
parents:
diff changeset
   340
       [in] NW_WBXML_Parser_t* context
hgs
parents:
diff changeset
   341
                  The context.
hgs
parents:
diff changeset
   342
hgs
parents:
diff changeset
   343
    @description: Restore parser context. See description for saveContext().
hgs
parents:
diff changeset
   344
hgs
parents:
diff changeset
   345
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   346
                  Status of operation.
hgs
parents:
diff changeset
   347
hgs
parents:
diff changeset
   348
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   349
                  Always returns success.
hgs
parents:
diff changeset
   350
hgs
parents:
diff changeset
   351
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   352
NW_Status_t
hgs
parents:
diff changeset
   353
NW_WBXML_Parser_restoreContext(NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   354
                               NW_WBXML_Parser_t* context);
hgs
parents:
diff changeset
   355
hgs
parents:
diff changeset
   356
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   357
   Get and set methods
hgs
parents:
diff changeset
   358
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
hgs
parents:
diff changeset
   361
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   362
    @function:    NW_WBXML_Parser_getOffset
hgs
parents:
diff changeset
   363
hgs
parents:
diff changeset
   364
    @synopsis:    Get offset.
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
    @scope:       public
hgs
parents:
diff changeset
   367
hgs
parents:
diff changeset
   368
    @parameters:
hgs
parents:
diff changeset
   369
       [in] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   370
                  The parser.
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
    @description: Get offset.
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
    @returns:     NW_Uint32
hgs
parents:
diff changeset
   375
                  Read offset.
hgs
parents:
diff changeset
   376
hgs
parents:
diff changeset
   377
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   378
NW_Uint32 
hgs
parents:
diff changeset
   379
NW_WBXML_Parser_getOffset(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   380
hgs
parents:
diff changeset
   381
hgs
parents:
diff changeset
   382
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   383
    @function:    NW_WBXML_Parser_setOffset
hgs
parents:
diff changeset
   384
hgs
parents:
diff changeset
   385
    @synopsis:    Set offset.
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
    @scope:       public
hgs
parents:
diff changeset
   388
hgs
parents:
diff changeset
   389
    @parameters:
hgs
parents:
diff changeset
   390
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   391
                  The parser.
hgs
parents:
diff changeset
   392
hgs
parents:
diff changeset
   393
       [in] NW_Uint32 offset
hgs
parents:
diff changeset
   394
                  New offset.
hgs
parents:
diff changeset
   395
hgs
parents:
diff changeset
   396
    @description: Set offset.
hgs
parents:
diff changeset
   397
hgs
parents:
diff changeset
   398
    @returns:     NW_Int32
hgs
parents:
diff changeset
   399
                  Offset or -1 if out of range.
hgs
parents:
diff changeset
   400
hgs
parents:
diff changeset
   401
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   402
NW_Int32 
hgs
parents:
diff changeset
   403
NW_WBXML_Parser_setOffset(NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   404
                          NW_Uint32 offset);  
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   408
    @function:    NW_WBXML_Parser_setTagCodepage
hgs
parents:
diff changeset
   409
hgs
parents:
diff changeset
   410
    @synopsis:    Set tag codepage.
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
    @scope:       public
hgs
parents:
diff changeset
   413
hgs
parents:
diff changeset
   414
    @parameters:
hgs
parents:
diff changeset
   415
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   416
                  The parser.
hgs
parents:
diff changeset
   417
hgs
parents:
diff changeset
   418
       [in] NW_Uint8 page
hgs
parents:
diff changeset
   419
                  The page.
hgs
parents:
diff changeset
   420
hgs
parents:
diff changeset
   421
    @description: Set tag codepage.
hgs
parents:
diff changeset
   422
hgs
parents:
diff changeset
   423
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   424
                  Status of operation.
hgs
parents:
diff changeset
   425
hgs
parents:
diff changeset
   426
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   427
                  Always returns success.
hgs
parents:
diff changeset
   428
hgs
parents:
diff changeset
   429
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   430
NW_Status_t
hgs
parents:
diff changeset
   431
NW_WBXML_Parser_setTagCodepage(NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   432
                               NW_Uint8 page);
hgs
parents:
diff changeset
   433
hgs
parents:
diff changeset
   434
hgs
parents:
diff changeset
   435
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   436
    @function:    NW_WBXML_Parser_getTagCodepage
hgs
parents:
diff changeset
   437
hgs
parents:
diff changeset
   438
    @synopsis:    Get tag codepage.
hgs
parents:
diff changeset
   439
hgs
parents:
diff changeset
   440
    @scope:       public
hgs
parents:
diff changeset
   441
hgs
parents:
diff changeset
   442
    @parameters:
hgs
parents:
diff changeset
   443
       [in] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   444
                  The parser.
hgs
parents:
diff changeset
   445
hgs
parents:
diff changeset
   446
    @description: Get tag codepage.
hgs
parents:
diff changeset
   447
hgs
parents:
diff changeset
   448
    @returns:     NW_Uint8
hgs
parents:
diff changeset
   449
                  The code page.
hgs
parents:
diff changeset
   450
hgs
parents:
diff changeset
   451
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   452
NW_Uint8
hgs
parents:
diff changeset
   453
NW_WBXML_Parser_getTagCodepage(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   454
hgs
parents:
diff changeset
   455
hgs
parents:
diff changeset
   456
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   457
    @function:    NW_WBXML_Parser_setAttrCodepage
hgs
parents:
diff changeset
   458
hgs
parents:
diff changeset
   459
    @synopsis:    Set attribute codepage.
hgs
parents:
diff changeset
   460
hgs
parents:
diff changeset
   461
    @scope:       public
hgs
parents:
diff changeset
   462
hgs
parents:
diff changeset
   463
    @parameters:
hgs
parents:
diff changeset
   464
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   465
                  The parser.
hgs
parents:
diff changeset
   466
hgs
parents:
diff changeset
   467
       [in] NW_Uint8 page
hgs
parents:
diff changeset
   468
                  The code page.
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
    @description: Set attribute codepage.
hgs
parents:
diff changeset
   471
hgs
parents:
diff changeset
   472
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   473
                  Status of operation.
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   476
                  Always returns success.
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   479
NW_Status_t
hgs
parents:
diff changeset
   480
NW_WBXML_Parser_setAttrCodepage(NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   481
                                NW_Uint8 page);
hgs
parents:
diff changeset
   482
hgs
parents:
diff changeset
   483
hgs
parents:
diff changeset
   484
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   485
    @function:    NW_WBXML_Parser_getAttrCodepage
hgs
parents:
diff changeset
   486
hgs
parents:
diff changeset
   487
    @synopsis:    Get attribute codepage.
hgs
parents:
diff changeset
   488
hgs
parents:
diff changeset
   489
    @scope:       public
hgs
parents:
diff changeset
   490
hgs
parents:
diff changeset
   491
    @parameters:
hgs
parents:
diff changeset
   492
       [in] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   493
                  The parser.
hgs
parents:
diff changeset
   494
hgs
parents:
diff changeset
   495
    @description: Get attribute codepage.
hgs
parents:
diff changeset
   496
hgs
parents:
diff changeset
   497
    @returns:     NW_Uint8
hgs
parents:
diff changeset
   498
                  Code page.
hgs
parents:
diff changeset
   499
hgs
parents:
diff changeset
   500
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   501
NW_Uint8
hgs
parents:
diff changeset
   502
NW_WBXML_Parser_getAttrCodepage(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   503
hgs
parents:
diff changeset
   504
hgs
parents:
diff changeset
   505
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   506
    Parse document elements 
hgs
parents:
diff changeset
   507
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   508
hgs
parents:
diff changeset
   509
hgs
parents:
diff changeset
   510
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   511
    @function:    NW_WBXML_Parser_tagNameParse
hgs
parents:
diff changeset
   512
hgs
parents:
diff changeset
   513
    @synopsis:    Tag name parse.
hgs
parents:
diff changeset
   514
hgs
parents:
diff changeset
   515
    @scope:       public
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
    @parameters:
hgs
parents:
diff changeset
   518
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   519
                  The parser.
hgs
parents:
diff changeset
   520
hgs
parents:
diff changeset
   521
    @description: Parse the token and name part of a tag. This generates a
hgs
parents:
diff changeset
   522
                  fully qualified token.
hgs
parents:
diff changeset
   523
hgs
parents:
diff changeset
   524
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   525
                  Status of operation.
hgs
parents:
diff changeset
   526
hgs
parents:
diff changeset
   527
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   528
                  Tag name parsed.
hgs
parents:
diff changeset
   529
hgs
parents:
diff changeset
   530
       [NW_STAT_WBXML_HAS_ATTRIBUTES]
hgs
parents:
diff changeset
   531
                  Has attributes.
hgs
parents:
diff changeset
   532
hgs
parents:
diff changeset
   533
       [NW_STAT_WBXML_HAS_ATTR_CONTENT]
hgs
parents:
diff changeset
   534
                  Has attribute content.
hgs
parents:
diff changeset
   535
hgs
parents:
diff changeset
   536
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   537
                  Parse error.
hgs
parents:
diff changeset
   538
hgs
parents:
diff changeset
   539
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   540
NW_Status_t
hgs
parents:
diff changeset
   541
NW_WBXML_Parser_tagNameParse(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   542
hgs
parents:
diff changeset
   543
hgs
parents:
diff changeset
   544
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   545
    @function:    NW_WBXML_Parser_attributeListIterate
hgs
parents:
diff changeset
   546
hgs
parents:
diff changeset
   547
    @synopsis:    Parse an attribute list.
hgs
parents:
diff changeset
   548
    @scope:       public
hgs
parents:
diff changeset
   549
hgs
parents:
diff changeset
   550
    @parameters:
hgs
parents:
diff changeset
   551
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   552
                  The parser.
hgs
parents:
diff changeset
   553
hgs
parents:
diff changeset
   554
    @description: Parse an attribute list
hgs
parents:
diff changeset
   555
hgs
parents:
diff changeset
   556
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   557
                  Status of operation.
hgs
parents:
diff changeset
   558
hgs
parents:
diff changeset
   559
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   560
                  Parse error.
hgs
parents:
diff changeset
   561
hgs
parents:
diff changeset
   562
       [NW_STAT_WBXML_ITERATE_DONE]
hgs
parents:
diff changeset
   563
                  Done.
hgs
parents:
diff changeset
   564
hgs
parents:
diff changeset
   565
       [NW_STAT_WBXML_ITERATE_MORE]
hgs
parents:
diff changeset
   566
                  More to do.
hgs
parents:
diff changeset
   567
hgs
parents:
diff changeset
   568
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   569
NW_Status_t 
hgs
parents:
diff changeset
   570
NW_WBXML_Parser_attributeListIterate (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   571
hgs
parents:
diff changeset
   572
hgs
parents:
diff changeset
   573
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   574
    @function:    NW_WBXML_Parser_attributeValsIterate
hgs
parents:
diff changeset
   575
hgs
parents:
diff changeset
   576
    @synopsis:    Parse an attribute value list.
hgs
parents:
diff changeset
   577
hgs
parents:
diff changeset
   578
    @scope:       public
hgs
parents:
diff changeset
   579
hgs
parents:
diff changeset
   580
    @parameters:
hgs
parents:
diff changeset
   581
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   582
                  The parser.
hgs
parents:
diff changeset
   583
hgs
parents:
diff changeset
   584
    @description: Parse an attribute value list.
hgs
parents:
diff changeset
   585
hgs
parents:
diff changeset
   586
    @returns:     NW_Status_t 
hgs
parents:
diff changeset
   587
                  Status of operation.
hgs
parents:
diff changeset
   588
hgs
parents:
diff changeset
   589
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   590
                  Parse error.
hgs
parents:
diff changeset
   591
hgs
parents:
diff changeset
   592
       [NW_STAT_WBXML_ITERATE_DONE]
hgs
parents:
diff changeset
   593
                  Done.
hgs
parents:
diff changeset
   594
hgs
parents:
diff changeset
   595
       [NW_STAT_WBXML_ITERATE_MORE]
hgs
parents:
diff changeset
   596
                  More to do.
hgs
parents:
diff changeset
   597
hgs
parents:
diff changeset
   598
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   599
NW_Status_t 
hgs
parents:
diff changeset
   600
NW_WBXML_Parser_attributeValsIterate (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   601
hgs
parents:
diff changeset
   602
hgs
parents:
diff changeset
   603
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   604
    @function:    NW_WBXML_Parser_attributeNameParse
hgs
parents:
diff changeset
   605
hgs
parents:
diff changeset
   606
    @synopsis:    Parse an attribute.
hgs
parents:
diff changeset
   607
hgs
parents:
diff changeset
   608
    @scope:       public
hgs
parents:
diff changeset
   609
hgs
parents:
diff changeset
   610
    @parameters:
hgs
parents:
diff changeset
   611
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   612
                  The parser.
hgs
parents:
diff changeset
   613
hgs
parents:
diff changeset
   614
    @description: Parse an attribute.
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
                  Attribute parsed.
hgs
parents:
diff changeset
   621
hgs
parents:
diff changeset
   622
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   623
                  Parse error.
hgs
parents:
diff changeset
   624
hgs
parents:
diff changeset
   625
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   626
NW_Status_t 
hgs
parents:
diff changeset
   627
NW_WBXML_Parser_attributeNameParse (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   628
hgs
parents:
diff changeset
   629
hgs
parents:
diff changeset
   630
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   631
    @function:    NW_WBXML_Parser_textIterate
hgs
parents:
diff changeset
   632
hgs
parents:
diff changeset
   633
    @synopsis:    Parse text.
hgs
parents:
diff changeset
   634
hgs
parents:
diff changeset
   635
    @scope:       public
hgs
parents:
diff changeset
   636
hgs
parents:
diff changeset
   637
    @parameters:
hgs
parents:
diff changeset
   638
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   639
                  The parser.
hgs
parents:
diff changeset
   640
hgs
parents:
diff changeset
   641
    @description: Parse text.
hgs
parents:
diff changeset
   642
hgs
parents:
diff changeset
   643
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   644
                  Status of operation.
hgs
parents:
diff changeset
   645
hgs
parents:
diff changeset
   646
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   647
                  Parse error.
hgs
parents:
diff changeset
   648
hgs
parents:
diff changeset
   649
       [NW_STAT_WBXML_ITERATE_DONE]
hgs
parents:
diff changeset
   650
                  Done.
hgs
parents:
diff changeset
   651
hgs
parents:
diff changeset
   652
       [NW_STAT_WBXML_ITERATE_MORE]
hgs
parents:
diff changeset
   653
                  More to do.
hgs
parents:
diff changeset
   654
hgs
parents:
diff changeset
   655
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   656
NW_Status_t
hgs
parents:
diff changeset
   657
NW_WBXML_Parser_textIterate(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   658
hgs
parents:
diff changeset
   659
hgs
parents:
diff changeset
   660
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   661
    @function:    NW_WBXML_parser_attributeListIterate
hgs
parents:
diff changeset
   662
hgs
parents:
diff changeset
   663
    @synopsis:    Parse an attribute list.
hgs
parents:
diff changeset
   664
    @scope:       public
hgs
parents:
diff changeset
   665
hgs
parents:
diff changeset
   666
    @parameters:
hgs
parents:
diff changeset
   667
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   668
                  The parser.
hgs
parents:
diff changeset
   669
hgs
parents:
diff changeset
   670
    @description: Parse an attribute list.
hgs
parents:
diff changeset
   671
hgs
parents:
diff changeset
   672
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   673
                  Status of operation.
hgs
parents:
diff changeset
   674
hgs
parents:
diff changeset
   675
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   676
                  Parse error.
hgs
parents:
diff changeset
   677
hgs
parents:
diff changeset
   678
       [NW_STAT_WBXML_ITERATE_DONE]
hgs
parents:
diff changeset
   679
                  Done.
hgs
parents:
diff changeset
   680
hgs
parents:
diff changeset
   681
       [NW_STAT_WBXML_ITERATE_MORE]
hgs
parents:
diff changeset
   682
                  More to do.
hgs
parents:
diff changeset
   683
hgs
parents:
diff changeset
   684
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   685
NW_Status_t
hgs
parents:
diff changeset
   686
NW_WBXML_parser_attributeListIterate(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   687
hgs
parents:
diff changeset
   688
hgs
parents:
diff changeset
   689
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   690
    @function:    NW_WBXML_parser_attributeValsIterate
hgs
parents:
diff changeset
   691
hgs
parents:
diff changeset
   692
    @synopsis:    Parse attribute values.
hgs
parents:
diff changeset
   693
hgs
parents:
diff changeset
   694
    @scope:       public
hgs
parents:
diff changeset
   695
hgs
parents:
diff changeset
   696
    @parameters:
hgs
parents:
diff changeset
   697
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   698
                  The parser.
hgs
parents:
diff changeset
   699
hgs
parents:
diff changeset
   700
    @description: Parse attribute values.
hgs
parents:
diff changeset
   701
hgs
parents:
diff changeset
   702
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   703
                  Status of operation.
hgs
parents:
diff changeset
   704
hgs
parents:
diff changeset
   705
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   706
                  Parse error.
hgs
parents:
diff changeset
   707
hgs
parents:
diff changeset
   708
       [NW_STAT_WBXML_ITERATE_DONE]
hgs
parents:
diff changeset
   709
                  Done.
hgs
parents:
diff changeset
   710
hgs
parents:
diff changeset
   711
       [NW_STAT_WBXML_ITERATE_MORE]
hgs
parents:
diff changeset
   712
                  More to do.
hgs
parents:
diff changeset
   713
hgs
parents:
diff changeset
   714
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   715
NW_Status_t 
hgs
parents:
diff changeset
   716
NW_WBXML_parser_attributeValsIterate (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   717
hgs
parents:
diff changeset
   718
hgs
parents:
diff changeset
   719
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   720
    @function:    NW_WBXML_Parser_attributeParse
hgs
parents:
diff changeset
   721
hgs
parents:
diff changeset
   722
    @synopsis:    Attribute parse.
hgs
parents:
diff changeset
   723
hgs
parents:
diff changeset
   724
    @scope:       public
hgs
parents:
diff changeset
   725
hgs
parents:
diff changeset
   726
    @parameters:
hgs
parents:
diff changeset
   727
       [in] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   728
                  The parser.
hgs
parents:
diff changeset
   729
hgs
parents:
diff changeset
   730
    @description: Attribute parse.
hgs
parents:
diff changeset
   731
hgs
parents:
diff changeset
   732
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   733
                  Status of operation.
hgs
parents:
diff changeset
   734
hgs
parents:
diff changeset
   735
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   736
                  Done.
hgs
parents:
diff changeset
   737
hgs
parents:
diff changeset
   738
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   739
                  Parse error.
hgs
parents:
diff changeset
   740
hgs
parents:
diff changeset
   741
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   742
NW_Status_t
hgs
parents:
diff changeset
   743
NW_WBXML_Parser_attributeParse(NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   744
hgs
parents:
diff changeset
   745
hgs
parents:
diff changeset
   746
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   747
    @function:    NW_WBXML_Parser_contentParse
hgs
parents:
diff changeset
   748
hgs
parents:
diff changeset
   749
    @synopsis:    Parse content.
hgs
parents:
diff changeset
   750
hgs
parents:
diff changeset
   751
    @scope:       public
hgs
parents:
diff changeset
   752
hgs
parents:
diff changeset
   753
    @parameters:
hgs
parents:
diff changeset
   754
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   755
                  The parser.
hgs
parents:
diff changeset
   756
hgs
parents:
diff changeset
   757
    @description: Parse content.
hgs
parents:
diff changeset
   758
hgs
parents:
diff changeset
   759
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   760
                  Status of operation.
hgs
parents:
diff changeset
   761
hgs
parents:
diff changeset
   762
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   763
                  Done.
hgs
parents:
diff changeset
   764
hgs
parents:
diff changeset
   765
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   766
                  Parse error.
hgs
parents:
diff changeset
   767
hgs
parents:
diff changeset
   768
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   769
NW_Status_t
hgs
parents:
diff changeset
   770
NW_WBXML_Parser_contentParse (NW_WBXML_Parser_t* parser);
hgs
parents:
diff changeset
   771
hgs
parents:
diff changeset
   772
hgs
parents:
diff changeset
   773
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   774
    @function:    NW_WBXML_Parser_extensionParse
hgs
parents:
diff changeset
   775
hgs
parents:
diff changeset
   776
    @synopsis:    Parse extension.
hgs
parents:
diff changeset
   777
hgs
parents:
diff changeset
   778
    @scope:       public
hgs
parents:
diff changeset
   779
hgs
parents:
diff changeset
   780
    @parameters:
hgs
parents:
diff changeset
   781
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   782
                  The parser.
hgs
parents:
diff changeset
   783
hgs
parents:
diff changeset
   784
       [in] NW_Int32 token_state
hgs
parents:
diff changeset
   785
                  Token state.
hgs
parents:
diff changeset
   786
hgs
parents:
diff changeset
   787
    @description: Parse extension.
hgs
parents:
diff changeset
   788
hgs
parents:
diff changeset
   789
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   790
                  Status of operation.
hgs
parents:
diff changeset
   791
hgs
parents:
diff changeset
   792
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   793
                  Done.
hgs
parents:
diff changeset
   794
hgs
parents:
diff changeset
   795
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   796
                  Parse error.
hgs
parents:
diff changeset
   797
hgs
parents:
diff changeset
   798
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   799
NW_Status_t
hgs
parents:
diff changeset
   800
NW_WBXML_Parser_extensionParse (NW_WBXML_Parser_t* parser,
hgs
parents:
diff changeset
   801
                                NW_Int32 token_state);
hgs
parents:
diff changeset
   802
hgs
parents:
diff changeset
   803
hgs
parents:
diff changeset
   804
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   805
    @function:    NW_WBXML_Parser_opaqueParse
hgs
parents:
diff changeset
   806
hgs
parents:
diff changeset
   807
    @synopsis:    Parse opaque data.
hgs
parents:
diff changeset
   808
hgs
parents:
diff changeset
   809
    @scope:       public
hgs
parents:
diff changeset
   810
hgs
parents:
diff changeset
   811
    @parameters:
hgs
parents:
diff changeset
   812
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   813
                  The parser.
hgs
parents:
diff changeset
   814
hgs
parents:
diff changeset
   815
       [in] NW_Int32 token_state
hgs
parents:
diff changeset
   816
                  Token state.
hgs
parents:
diff changeset
   817
hgs
parents:
diff changeset
   818
    @description: Parse opaque data.
hgs
parents:
diff changeset
   819
hgs
parents:
diff changeset
   820
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   821
                  Status of operation.
hgs
parents:
diff changeset
   822
hgs
parents:
diff changeset
   823
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   824
                  Done.
hgs
parents:
diff changeset
   825
hgs
parents:
diff changeset
   826
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   827
                  Parse error.
hgs
parents:
diff changeset
   828
hgs
parents:
diff changeset
   829
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   830
NW_Status_t
hgs
parents:
diff changeset
   831
NW_WBXML_Parser_opaqueParse (NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   832
                             NW_Int32 token_state);
hgs
parents:
diff changeset
   833
hgs
parents:
diff changeset
   834
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   835
   TODO READ_WRITE only? 
hgs
parents:
diff changeset
   836
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   837
hgs
parents:
diff changeset
   838
hgs
parents:
diff changeset
   839
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   840
    @function:    NW_WBXML_Parser_setBuffer
hgs
parents:
diff changeset
   841
hgs
parents:
diff changeset
   842
    @synopsis:    Sets parser to use a buffer without parsing it.
hgs
parents:
diff changeset
   843
hgs
parents:
diff changeset
   844
    @scope:       public
hgs
parents:
diff changeset
   845
hgs
parents:
diff changeset
   846
    @parameters:
hgs
parents:
diff changeset
   847
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   848
                  The parser.
hgs
parents:
diff changeset
   849
hgs
parents:
diff changeset
   850
       [in] NW_WBXML_Document_t* doc
hgs
parents:
diff changeset
   851
                  The document.
hgs
parents:
diff changeset
   852
hgs
parents:
diff changeset
   853
       [in] NW_Byte* buf
hgs
parents:
diff changeset
   854
                  The buffer.
hgs
parents:
diff changeset
   855
hgs
parents:
diff changeset
   856
       [in] NW_Uint32 bufsize
hgs
parents:
diff changeset
   857
                  The size of the buffer.
hgs
parents:
diff changeset
   858
hgs
parents:
diff changeset
   859
    @description: This method sets the parser to use a buffer without
hgs
parents:
diff changeset
   860
                  actually parsing it.  This is used by clients who want
hgs
parents:
diff changeset
   861
                  to create a tree from scratch without parsing a 
hgs
parents:
diff changeset
   862
                  document. This requires that doc be initialized with
hgs
parents:
diff changeset
   863
                  any document type and charset and that the parser be 
hgs
parents:
diff changeset
   864
                  initialized.  This should leave the parser in the same
hgs
parents:
diff changeset
   865
                  state as NW_WBXML_Parser_parserBuffer() followed by
hgs
parents:
diff changeset
   866
                  NW_WBXML_Parser_reintialize().  
hgs
parents:
diff changeset
   867
hgs
parents:
diff changeset
   868
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   869
                  Status of operation.
hgs
parents:
diff changeset
   870
hgs
parents:
diff changeset
   871
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   872
                  Always returns success.
hgs
parents:
diff changeset
   873
hgs
parents:
diff changeset
   874
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   875
NW_Status_t
hgs
parents:
diff changeset
   876
NW_WBXML_Parser_setBuffer (NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   877
                           NW_WBXML_Document_t* doc,
hgs
parents:
diff changeset
   878
                           NW_Byte* buf,
hgs
parents:
diff changeset
   879
                           NW_Uint32 bufsize);
hgs
parents:
diff changeset
   880
hgs
parents:
diff changeset
   881
hgs
parents:
diff changeset
   882
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   883
    @function:    NW_WBXML_Parser_resetBuffer
hgs
parents:
diff changeset
   884
hgs
parents:
diff changeset
   885
    @synopsis:    Reset buffer.
hgs
parents:
diff changeset
   886
hgs
parents:
diff changeset
   887
    @scope:       public
hgs
parents:
diff changeset
   888
hgs
parents:
diff changeset
   889
    @parameters:
hgs
parents:
diff changeset
   890
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   891
                  The parser.
hgs
parents:
diff changeset
   892
hgs
parents:
diff changeset
   893
       [in] NW_Byte* buff
hgs
parents:
diff changeset
   894
                  The buffer.
hgs
parents:
diff changeset
   895
hgs
parents:
diff changeset
   896
       [in] NW_Uint32 buffsize
hgs
parents:
diff changeset
   897
                  The size of the buffer.
hgs
parents:
diff changeset
   898
hgs
parents:
diff changeset
   899
    @description: Reset the parser buffer without resetting the doc.  
hgs
parents:
diff changeset
   900
                  This is more efficient when, for example, the buffer 
hgs
parents:
diff changeset
   901
                  gets resized due to a reallocation.
hgs
parents:
diff changeset
   902
hgs
parents:
diff changeset
   903
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   904
                  Status of operation.
hgs
parents:
diff changeset
   905
hgs
parents:
diff changeset
   906
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   907
                  Always returns success.
hgs
parents:
diff changeset
   908
hgs
parents:
diff changeset
   909
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   910
NW_Status_t
hgs
parents:
diff changeset
   911
NW_WBXML_Parser_resetBuffer(NW_WBXML_Parser_t* parser, 
hgs
parents:
diff changeset
   912
                            NW_Byte* buff, 
hgs
parents:
diff changeset
   913
                            NW_Uint32 buffsize);
hgs
parents:
diff changeset
   914
hgs
parents:
diff changeset
   915
/* ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   916
   TODO: Move to parser buffer header?
hgs
parents:
diff changeset
   917
** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   918
hgs
parents:
diff changeset
   919
hgs
parents:
diff changeset
   920
/** ----------------------------------------------------------------------- **
hgs
parents:
diff changeset
   921
    @function:    NW_WBXML_Parser_parseBuffer
hgs
parents:
diff changeset
   922
hgs
parents:
diff changeset
   923
    @synopsis:    Parse buffer.
hgs
parents:
diff changeset
   924
hgs
parents:
diff changeset
   925
    @scope:       public
hgs
parents:
diff changeset
   926
hgs
parents:
diff changeset
   927
    @parameters:
hgs
parents:
diff changeset
   928
       [in-out] NW_WBXML_Parser_t* parser
hgs
parents:
diff changeset
   929
                  The parser.
hgs
parents:
diff changeset
   930
hgs
parents:
diff changeset
   931
       [in] NW_WBXML_Document_t* doc
hgs
parents:
diff changeset
   932
                  The document.
hgs
parents:
diff changeset
   933
hgs
parents:
diff changeset
   934
       [in] NW_Byte* buf
hgs
parents:
diff changeset
   935
                  The buffer.
hgs
parents:
diff changeset
   936
hgs
parents:
diff changeset
   937
       [in] NW_Uint32 bufsize
hgs
parents:
diff changeset
   938
                  The size of the buffer.
hgs
parents:
diff changeset
   939
hgs
parents:
diff changeset
   940
    @description: Parse document from a buffer.  
hgs
parents:
diff changeset
   941
hgs
parents:
diff changeset
   942
    @returns:     NW_Status_t
hgs
parents:
diff changeset
   943
                  Status of the operation.
hgs
parents:
diff changeset
   944
hgs
parents:
diff changeset
   945
       [NW_STAT_SUCCESS]
hgs
parents:
diff changeset
   946
                  Done.
hgs
parents:
diff changeset
   947
hgs
parents:
diff changeset
   948
       [NW_STAT_WBXML_ERROR_BYTECODE]
hgs
parents:
diff changeset
   949
                  Parse error.
hgs
parents:
diff changeset
   950
hgs
parents:
diff changeset
   951
       [NW_STAT_OUT_OF_MEMORY]
hgs
parents:
diff changeset
   952
                  Out of memory.
hgs
parents:
diff changeset
   953
hgs
parents:
diff changeset
   954
       [NW_STAT_BAD_INPUT_PARAM]
hgs
parents:
diff changeset
   955
                  Requird parameter is NULL.
hgs
parents:
diff changeset
   956
hgs
parents:
diff changeset
   957
       [NW_STAT_WBXML_ERROR_CHARSET_UNSUPPORTED]
hgs
parents:
diff changeset
   958
                  Invalid character set.
hgs
parents:
diff changeset
   959
hgs
parents:
diff changeset
   960
 ** ----------------------------------------------------------------------- **/
hgs
parents:
diff changeset
   961
IMPORT_C NW_Status_t 
hgs
parents:
diff changeset
   962
NW_WBXML_Parser_parseBuffer (NW_WBXML_Parser_t* parser,
hgs
parents:
diff changeset
   963
                             NW_WBXML_Document_t* doc,
hgs
parents:
diff changeset
   964
                             NW_Byte* buf,
hgs
parents:
diff changeset
   965
                             NW_Uint32 bufsize);
hgs
parents:
diff changeset
   966
hgs
parents:
diff changeset
   967
#ifdef __cplusplus
hgs
parents:
diff changeset
   968
} /* extern "C" { */
hgs
parents:
diff changeset
   969
#endif /* __cplusplus */
hgs
parents:
diff changeset
   970
hgs
parents:
diff changeset
   971
#endif  /* NW_PARSER_WBXML_PARSE_H */