xml/cxmllibrary/src/dom/src/node.c
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
#include "cxml_internal.h"
hgs
parents:
diff changeset
    20
#include <xml/cxml/nw_dom_node.h>
hgs
parents:
diff changeset
    21
#include <xml/cxml/nw_dom_document.h>
hgs
parents:
diff changeset
    22
#include <xml/cxml/nw_dom_element.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
/**
hgs
parents:
diff changeset
    25
 * GENERAL NODE METHODS - applicable to all node types
hgs
parents:
diff changeset
    26
 * These methods will be repeated for other Node types also
hgs
parents:
diff changeset
    27
 **/
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/*
hgs
parents:
diff changeset
    30
 * RETURN 
hgs
parents:
diff changeset
    31
 * NW_STAT_SUCCESS
hgs
parents:
diff changeset
    32
 * NW_STAT_OUT_OF_MEMORY - If memory could not be allocated for storage
hgs
parents:
diff changeset
    33
 * NW_STAT_WBXML_ERROR_CHARSET_UNSUPPORTED - If encoding is not valid
hgs
parents:
diff changeset
    34
 * NW_STAT_DOM_NODE_TYPE_ERR - If node type is not a standard node type
hgs
parents:
diff changeset
    35
 * NW_STAT_DOM_NO_STRING_RETURNED - If the storage was not assigned to NW_DOM_String
hgs
parents:
diff changeset
    36
 *
hgs
parents:
diff changeset
    37
 * MODIFIED nodeName
hgs
parents:
diff changeset
    38
 */
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
EXPORT_C NW_Status_t 
hgs
parents:
diff changeset
    41
NW_DOM_Node_getNodeName(NW_DOM_Node_t *node, NW_String_t *nodeName)
hgs
parents:
diff changeset
    42
{
hgs
parents:
diff changeset
    43
  NW_Uint16 type;
hgs
parents:
diff changeset
    44
  NW_String_UCS2Buff_t *name = NULL;
hgs
parents:
diff changeset
    45
  NW_DOM_DocumentNode_t *docNode;
hgs
parents:
diff changeset
    46
  NW_Uint32 encoding;
hgs
parents:
diff changeset
    47
  
hgs
parents:
diff changeset
    48
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
    49
  NW_ASSERT(nodeName != NULL);  
hgs
parents:
diff changeset
    50
   
hgs
parents:
diff changeset
    51
  type = NW_DOM_Node_getNodeType(node);
hgs
parents:
diff changeset
    52
  if (type == 0){
hgs
parents:
diff changeset
    53
    return NW_STAT_DOM_NODE_TYPE_ERR;
hgs
parents:
diff changeset
    54
  }
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
  switch (type) {
hgs
parents:
diff changeset
    57
    case NW_DOM_ELEMENT_NODE:
hgs
parents:
diff changeset
    58
      return NW_DOM_ElementNode_getTagName(node, nodeName);
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
    case NW_DOM_PROCESSING_INSTRUCTION_NODE:/* Not supported */
hgs
parents:
diff changeset
    61
       return NW_STAT_DOM_NO_STRING_RETURNED;
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
    case NW_DOM_TEXT_NODE:
hgs
parents:
diff changeset
    64
      name = (NW_String_UCS2Buff_t *) L"#text";
hgs
parents:
diff changeset
    65
      break;
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
    case NW_DOM_DOCUMENT_NODE:
hgs
parents:
diff changeset
    68
      name = (NW_String_UCS2Buff_t *) L"#document";
hgs
parents:
diff changeset
    69
      break;
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
    case NW_DOM_COMMENT_NODE:
hgs
parents:
diff changeset
    72
      name = (NW_String_UCS2Buff_t *) L"#comment";
hgs
parents:
diff changeset
    73
      break;
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
    case NW_DOM_CDATA_SECTION_NODE:
hgs
parents:
diff changeset
    76
      name = (NW_String_UCS2Buff_t *) L"#cdata-section";
hgs
parents:
diff changeset
    77
      break;
hgs
parents:
diff changeset
    78
    default: 
hgs
parents:
diff changeset
    79
      return NW_STAT_DOM_NO_STRING_RETURNED;
hgs
parents:
diff changeset
    80
  }
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
  docNode = NW_DOM_Node_getOwnerDocument(node);
hgs
parents:
diff changeset
    83
  if (docNode == NULL) {
hgs
parents:
diff changeset
    84
    return NW_STAT_DOM_NO_STRING_RETURNED;
hgs
parents:
diff changeset
    85
  }
hgs
parents:
diff changeset
    86
  encoding = NW_DOM_DocumentNode_getCharacterEncoding(docNode);
hgs
parents:
diff changeset
    87
    return NW_String_UCS2BuffToString(name, nodeName, encoding);    
hgs
parents:
diff changeset
    88
  }
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
/* 
hgs
parents:
diff changeset
    91
 * returns NW_DOM_NodeType 
hgs
parents:
diff changeset
    92
 * Returns 0 if Node type is not one of the recognized nodes
hgs
parents:
diff changeset
    93
 */
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
EXPORT_C NW_Uint16 
hgs
parents:
diff changeset
    96
NW_DOM_Node_getNodeType(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
    97
{
hgs
parents:
diff changeset
    98
  NW_Uint16 type;
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
  type = (NW_Uint16)(NW_TinyDom_Node_getType(node) & 0x0f);
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
  switch(type) {
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
  case T_DOM_NODE_DOC:
hgs
parents:
diff changeset
   107
    return NW_DOM_DOCUMENT_NODE;
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
  case T_DOM_NODE_TAG:
hgs
parents:
diff changeset
   110
    return NW_DOM_ELEMENT_NODE;
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
  case T_DOM_NODE_TEXT:
hgs
parents:
diff changeset
   113
    return NW_DOM_TEXT_NODE;
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
  case T_DOM_NODE_PI:
hgs
parents:
diff changeset
   116
    return NW_DOM_PROCESSING_INSTRUCTION_NODE;
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
  case T_DOM_NODE_COMMENT:
hgs
parents:
diff changeset
   119
    return NW_DOM_COMMENT_NODE;
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
  case T_DOM_NODE_CDATASECTION:
hgs
parents:
diff changeset
   122
    return NW_DOM_CDATA_SECTION_NODE;
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
  default:
hgs
parents:
diff changeset
   125
  return 0;
hgs
parents:
diff changeset
   126
}
hgs
parents:
diff changeset
   127
}
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
/*  
hgs
parents:
diff changeset
   130
 * Returns fully qualified node token (including dictionary id)
hgs
parents:
diff changeset
   131
 * Returns 0 for invalid node
hgs
parents:
diff changeset
   132
 */
hgs
parents:
diff changeset
   133
EXPORT_C NW_Uint16 
hgs
parents:
diff changeset
   134
NW_DOM_Node_getNodeToken(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   135
{
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
  if (NW_DOM_Node_getNodeType(node) == NW_DOM_ELEMENT_NODE){
hgs
parents:
diff changeset
   140
    return NW_DOM_ElementNode_getTagToken(node);
hgs
parents:
diff changeset
   141
  }
hgs
parents:
diff changeset
   142
  return 0;
hgs
parents:
diff changeset
   143
}
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
/* 
hgs
parents:
diff changeset
   146
 * Returns NW_TRUE if the document is of WBXML type 
hgs
parents:
diff changeset
   147
 * otherwise returns NW_FALSE
hgs
parents:
diff changeset
   148
 */
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
NW_Bool 
hgs
parents:
diff changeset
   151
NW_DOM_Node_isWBXML(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   152
{
hgs
parents:
diff changeset
   153
  NW_Uint16 type;
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
  type = (NW_Uint16)(NW_TinyDom_Node_getType(node) & 0x8000);
hgs
parents:
diff changeset
   158
  
hgs
parents:
diff changeset
   159
  if (type == T_DOM_NODE_XML){
hgs
parents:
diff changeset
   160
    return NW_FALSE;
hgs
parents:
diff changeset
   161
  }
hgs
parents:
diff changeset
   162
  return NW_TRUE;
hgs
parents:
diff changeset
   163
}
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
/* 
hgs
parents:
diff changeset
   166
 * Finds parent node of the given node
hgs
parents:
diff changeset
   167
 * returns NULL for DOCUMENT_NODE 
hgs
parents:
diff changeset
   168
 */
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
EXPORT_C NW_DOM_Node_t * 
hgs
parents:
diff changeset
   171
NW_DOM_Node_getParentNode(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   172
{
hgs
parents:
diff changeset
   173
  NW_ASSERT (node != NULL); 
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
  if (NW_DOM_Node_getNodeType(node) == NW_DOM_DOCUMENT_NODE)
hgs
parents:
diff changeset
   176
    return NULL;
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
  return NW_TinyTree_findParent(node);
hgs
parents:
diff changeset
   179
}
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
/* 
hgs
parents:
diff changeset
   182
 * Following 3 methods return valid values only
hgs
parents:
diff changeset
   183
 * for ELEMENT_NODE and DOCUMENT_NODE, since these are the 
hgs
parents:
diff changeset
   184
 * only nodes that have children. For other nodes, the value is
hgs
parents:
diff changeset
   185
 * either NULL or 0
hgs
parents:
diff changeset
   186
 */
hgs
parents:
diff changeset
   187
hgs
parents:
diff changeset
   188
EXPORT_C NW_DOM_Node_t * 
hgs
parents:
diff changeset
   189
NW_DOM_Node_getFirstChild(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   190
{
hgs
parents:
diff changeset
   191
  NW_DOM_Node_t *child;
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
  child = NW_TinyTree_findFirstChild(node);
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
  if(child)
hgs
parents:
diff changeset
   198
  {
hgs
parents:
diff changeset
   199
      if(NW_TinyDom_Node_getType(child) == T_DOM_NODE_ATTR)
hgs
parents:
diff changeset
   200
        return NW_DOM_Node_getNextSibling(child);
hgs
parents:
diff changeset
   201
      else
hgs
parents:
diff changeset
   202
        return child;
hgs
parents:
diff changeset
   203
  }
hgs
parents:
diff changeset
   204
  return NULL;
hgs
parents:
diff changeset
   205
}
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
EXPORT_C NW_DOM_Node_t * 
hgs
parents:
diff changeset
   208
NW_DOM_Node_getLastChild(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   209
{
hgs
parents:
diff changeset
   210
  NW_DOM_Node_t *currentNode = NULL;
hgs
parents:
diff changeset
   211
  NW_DOM_Node_t *previousNode = NULL;
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
  currentNode = NW_DOM_Node_getFirstChild(node);
hgs
parents:
diff changeset
   216
  while (currentNode != NULL) 
hgs
parents:
diff changeset
   217
    {
hgs
parents:
diff changeset
   218
    previousNode = currentNode;
hgs
parents:
diff changeset
   219
    currentNode = NW_DOM_Node_getNextSibling(currentNode);
hgs
parents:
diff changeset
   220
  }
hgs
parents:
diff changeset
   221
  return previousNode;
hgs
parents:
diff changeset
   222
}
hgs
parents:
diff changeset
   223
hgs
parents:
diff changeset
   224
EXPORT_C NW_Bool 
hgs
parents:
diff changeset
   225
NW_DOM_Node_hasChildNodes(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   226
{
hgs
parents:
diff changeset
   227
  
hgs
parents:
diff changeset
   228
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   229
  
hgs
parents:
diff changeset
   230
  if (NW_DOM_Node_getFirstChild(node))
hgs
parents:
diff changeset
   231
    return NW_TRUE;
hgs
parents:
diff changeset
   232
  return NW_FALSE;
hgs
parents:
diff changeset
   233
}
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
EXPORT_C NW_DOM_Node_t * 
hgs
parents:
diff changeset
   236
NW_DOM_Node_getNextSibling(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   237
{
hgs
parents:
diff changeset
   238
  NW_DOM_Node_t *sibling;
hgs
parents:
diff changeset
   239
  
hgs
parents:
diff changeset
   240
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   241
 
hgs
parents:
diff changeset
   242
  sibling = NW_TinyTree_findNextSibling(node);
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
  if (sibling == NULL){
hgs
parents:
diff changeset
   245
    return NULL;
hgs
parents:
diff changeset
   246
  }
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
  while ((sibling != NULL) && (NW_TinyDom_Node_getType(sibling) == T_DOM_NODE_ATTR)){
hgs
parents:
diff changeset
   249
    sibling = NW_TinyTree_findNextSibling(sibling);
hgs
parents:
diff changeset
   250
  }
hgs
parents:
diff changeset
   251
  return sibling;
hgs
parents:
diff changeset
   252
}
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
EXPORT_C NW_DOM_Node_t * 
hgs
parents:
diff changeset
   255
NW_DOM_Node_getPreviousSibling(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   256
{
hgs
parents:
diff changeset
   257
  NW_DOM_Node_t *sibling;
hgs
parents:
diff changeset
   258
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
  sibling = NW_TinyTree_findPreviousSibling(node);
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
  if (sibling == NULL)
hgs
parents:
diff changeset
   263
    return NULL;
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
  while ((sibling != NULL) && (NW_TinyDom_Node_getType(sibling) == T_DOM_NODE_ATTR)){
hgs
parents:
diff changeset
   266
    sibling = NW_TinyTree_findPreviousSibling(sibling);
hgs
parents:
diff changeset
   267
  }
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
  return sibling;
hgs
parents:
diff changeset
   270
}
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
EXPORT_C NW_DOM_DocumentNode_t * 
hgs
parents:
diff changeset
   273
NW_DOM_Node_getOwnerDocument(NW_DOM_Node_t *node)
hgs
parents:
diff changeset
   274
{
hgs
parents:
diff changeset
   275
  NW_TinyTree_t *tiny_tree;
hgs
parents:
diff changeset
   276
hgs
parents:
diff changeset
   277
  NW_ASSERT(node != NULL);
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
  if (NW_DOM_Node_getNodeType(node) == NW_DOM_DOCUMENT_NODE){
hgs
parents:
diff changeset
   280
    return node;
hgs
parents:
diff changeset
   281
  }
hgs
parents:
diff changeset
   282
hgs
parents:
diff changeset
   283
  tiny_tree = NW_TinyTree_Node_findTree(node);
hgs
parents:
diff changeset
   284
hgs
parents:
diff changeset
   285
  return NW_TinyTree_getRoot(tiny_tree); 
hgs
parents:
diff changeset
   286
}
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
/*********************
hgs
parents:
diff changeset
   289
 * NODE LIST ITERATOR
hgs
parents:
diff changeset
   290
 **********************/
hgs
parents:
diff changeset
   291
hgs
parents:
diff changeset
   292
/*
hgs
parents:
diff changeset
   293
 * Returns NULL if unable to allocate memory
hgs
parents:
diff changeset
   294
 */
hgs
parents:
diff changeset
   295
hgs
parents:
diff changeset
   296
NW_DOM_NodeIterator_t *
hgs
parents:
diff changeset
   297
NW_DOM_NodeIterator_new(void)
hgs
parents:
diff changeset
   298
{
hgs
parents:
diff changeset
   299
  return (NW_DOM_NodeIterator_t *) NW_Mem_Malloc(sizeof (NW_DOM_NodeIterator_t));
hgs
parents:
diff changeset
   300
}
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
/*
hgs
parents:
diff changeset
   303
 * Initializes the Node handle which uses the given node
hgs
parents:
diff changeset
   304
 * as the starting point to iterate down the tree
hgs
parents:
diff changeset
   305
 * Returns NW_STAT_SUCCESS
hgs
parents:
diff changeset
   306
 *         NW_STAT_BAD_INPUT_PARAM
hgs
parents:
diff changeset
   307
 */
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
NW_Status_t
hgs
parents:
diff changeset
   310
NW_DOM_NodeIterator_initialize(NW_DOM_NodeIterator_t *handle, 
hgs
parents:
diff changeset
   311
                               NW_DOM_Node_t *node, 
hgs
parents:
diff changeset
   312
                               NW_Uint16 token)
hgs
parents:
diff changeset
   313
{
hgs
parents:
diff changeset
   314
  NW_ASSERT (handle != NULL);
hgs
parents:
diff changeset
   315
  NW_ASSERT (node != NULL);
hgs
parents:
diff changeset
   316
hgs
parents:
diff changeset
   317
  NW_TinyTree_NodeIterator_init(node, &handle->nodeIter);
hgs
parents:
diff changeset
   318
  handle->token = token;
hgs
parents:
diff changeset
   319
  return NW_STAT_SUCCESS;
hgs
parents:
diff changeset
   320
}
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
/*
hgs
parents:
diff changeset
   323
 * Deletes the handle
hgs
parents:
diff changeset
   324
 * Returns NW_STAT_SUCCESS
hgs
parents:
diff changeset
   325
 */
hgs
parents:
diff changeset
   326
hgs
parents:
diff changeset
   327
NW_Status_t
hgs
parents:
diff changeset
   328
NW_DOM_NodeIterator_delete(NW_DOM_NodeIterator_t *handle)
hgs
parents:
diff changeset
   329
{
hgs
parents:
diff changeset
   330
  
hgs
parents:
diff changeset
   331
  NW_ASSERT(handle != NULL);
hgs
parents:
diff changeset
   332
hgs
parents:
diff changeset
   333
  NW_Mem_Free (handle);
hgs
parents:
diff changeset
   334
hgs
parents:
diff changeset
   335
  return NW_STAT_SUCCESS;
hgs
parents:
diff changeset
   336
}
hgs
parents:
diff changeset
   337
hgs
parents:
diff changeset
   338
/*
hgs
parents:
diff changeset
   339
 * Returns the next node
hgs
parents:
diff changeset
   340
 */
hgs
parents:
diff changeset
   341
hgs
parents:
diff changeset
   342
NW_DOM_Node_t * 
hgs
parents:
diff changeset
   343
NW_DOM_NodeIterator_nextNode(NW_DOM_NodeIterator_t *handle)
hgs
parents:
diff changeset
   344
{
hgs
parents:
diff changeset
   345
  NW_DOM_Node_t* node = NULL;
hgs
parents:
diff changeset
   346
  NW_Uint16 token = 0;
hgs
parents:
diff changeset
   347
hgs
parents:
diff changeset
   348
  NW_ASSERT(handle != NULL);
hgs
parents:
diff changeset
   349
  
hgs
parents:
diff changeset
   350
  do {
hgs
parents:
diff changeset
   351
hgs
parents:
diff changeset
   352
    node = NW_TinyTree_NodeIterator_iterate(&handle->nodeIter);
hgs
parents:
diff changeset
   353
hgs
parents:
diff changeset
   354
    if (node == NULL){
hgs
parents:
diff changeset
   355
      return NULL;
hgs
parents:
diff changeset
   356
    }
hgs
parents:
diff changeset
   357
hgs
parents:
diff changeset
   358
    token = NW_DOM_Node_getNodeToken(node);
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
  } while (token != handle->token);
hgs
parents:
diff changeset
   361
  
hgs
parents:
diff changeset
   362
  return node;
hgs
parents:
diff changeset
   363
}
hgs
parents:
diff changeset
   364
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
hgs
parents:
diff changeset
   367
/**
hgs
parents:
diff changeset
   368
 * Inserts newChild before the refChild
hgs
parents:
diff changeset
   369
 * Returns one of:
hgs
parents:
diff changeset
   370
 *   NW_STAT_BAD_INPUT_PARAM
hgs
parents:
diff changeset
   371
 *   NW_STAT_SUCCESS
hgs
parents:
diff changeset
   372
 *   NW_STAT_NOT_FOUND - If reChild is not a child of given node
hgs
parents:
diff changeset
   373
 *   NW_STAT_DOM_WRONG_DOC_ERR - If newChild was created from a 
hgs
parents:
diff changeset
   374
 *        different document than the one that created the node
hgs
parents:
diff changeset
   375
 *   NW_STAT_DOM_HEIRARCHY_REQ_ERR - If node is of the type that 
hgs
parents:
diff changeset
   376
 *        does not allow children of the type of newChild node
hgs
parents:
diff changeset
   377
 */
hgs
parents:
diff changeset
   378
EXPORT_C NW_Status_t
hgs
parents:
diff changeset
   379
NW_DOM_Node_insertBefore(
hgs
parents:
diff changeset
   380
  NW_DOM_Node_t *node, 
hgs
parents:
diff changeset
   381
  NW_DOM_Node_t *newChild, 
hgs
parents:
diff changeset
   382
  NW_DOM_Node_t *refChild)
hgs
parents:
diff changeset
   383
{
hgs
parents:
diff changeset
   384
  NW_TinyTree_Node_t *child = NULL;
hgs
parents:
diff changeset
   385
  NW_DOM_DocumentNode_t *doc = NULL;
hgs
parents:
diff changeset
   386
  NW_DOM_DocumentNode_t *newDoc = NULL;
hgs
parents:
diff changeset
   387
  
hgs
parents:
diff changeset
   388
  if ((node == NULL) || (newChild == NULL) || (refChild == NULL))
hgs
parents:
diff changeset
   389
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   390
hgs
parents:
diff changeset
   391
  doc = NW_DOM_Node_getOwnerDocument(node);
hgs
parents:
diff changeset
   392
  newDoc = NW_DOM_Node_getOwnerDocument(newChild);
hgs
parents:
diff changeset
   393
hgs
parents:
diff changeset
   394
  if ((doc == NULL) || (newDoc == NULL))
hgs
parents:
diff changeset
   395
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   396
hgs
parents:
diff changeset
   397
  if (doc != newDoc)
hgs
parents:
diff changeset
   398
    return NW_STAT_DOM_WRONG_DOC_ERR;
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
  /* Only Element and Document nodes can have children */
hgs
parents:
diff changeset
   401
  if ((NW_DOM_Node_getNodeType(node) != NW_DOM_ELEMENT_NODE) &&
hgs
parents:
diff changeset
   402
      (NW_DOM_Node_getNodeType(node) != NW_DOM_DOCUMENT_NODE)) {
hgs
parents:
diff changeset
   403
    return NW_STAT_DOM_HEIRARCHY_REQUEST_ERR;
hgs
parents:
diff changeset
   404
  }
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
  child = NW_DOM_Node_getFirstChild (node);
hgs
parents:
diff changeset
   407
  while (child)
hgs
parents:
diff changeset
   408
  {
hgs
parents:
diff changeset
   409
    if (child == refChild)
hgs
parents:
diff changeset
   410
    {
hgs
parents:
diff changeset
   411
      NW_TinyTree_attachBefore(child, newChild);
hgs
parents:
diff changeset
   412
      return NW_STAT_SUCCESS;
hgs
parents:
diff changeset
   413
    }
hgs
parents:
diff changeset
   414
    child = NW_DOM_Node_getNextSibling(child);
hgs
parents:
diff changeset
   415
  }
hgs
parents:
diff changeset
   416
  /* The refChild is not a child of node */
hgs
parents:
diff changeset
   417
  return NW_STAT_NOT_FOUND;
hgs
parents:
diff changeset
   418
}
hgs
parents:
diff changeset
   419
hgs
parents:
diff changeset
   420
/**
hgs
parents:
diff changeset
   421
 * Replaces oldChild with the newChild and removes old child
hgs
parents:
diff changeset
   422
 * Returns one of:
hgs
parents:
diff changeset
   423
 *   NW_STAT_BAD_INPUT_PARAM
hgs
parents:
diff changeset
   424
 *   NW_STAT_SUCCESS
hgs
parents:
diff changeset
   425
 *   NW_STAT_NOT_FOUND - If oldChild is not a child of given node
hgs
parents:
diff changeset
   426
 *   NW_STAT_DOM_WRONG_DOC_ERR - If newChild was created from a 
hgs
parents:
diff changeset
   427
 *        different document than the one that created the node
hgs
parents:
diff changeset
   428
 *   NW_STAT_DOM_HEIRARCHY_REQ_ERR - If node is of the type that 
hgs
parents:
diff changeset
   429
 *        does not allow children of the type of newChild node
hgs
parents:
diff changeset
   430
 */
hgs
parents:
diff changeset
   431
hgs
parents:
diff changeset
   432
EXPORT_C NW_Status_t
hgs
parents:
diff changeset
   433
NW_DOM_Node_replaceChild(NW_DOM_Node_t *node, NW_DOM_Node_t *newChild, NW_DOM_Node_t *oldChild)
hgs
parents:
diff changeset
   434
{
hgs
parents:
diff changeset
   435
  NW_TinyTree_Node_t *child = NULL;
hgs
parents:
diff changeset
   436
  NW_DOM_DocumentNode_t *doc = NULL;
hgs
parents:
diff changeset
   437
  NW_DOM_DocumentNode_t *newDoc = NULL;
hgs
parents:
diff changeset
   438
hgs
parents:
diff changeset
   439
  if ((node == NULL) || (oldChild == NULL) || (newChild == NULL))
hgs
parents:
diff changeset
   440
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   441
hgs
parents:
diff changeset
   442
  doc = NW_DOM_Node_getOwnerDocument(node);
hgs
parents:
diff changeset
   443
  newDoc = NW_DOM_Node_getOwnerDocument(newChild);
hgs
parents:
diff changeset
   444
hgs
parents:
diff changeset
   445
  if ((doc == NULL) || (newDoc == NULL))
hgs
parents:
diff changeset
   446
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   447
hgs
parents:
diff changeset
   448
  if (doc != newDoc)
hgs
parents:
diff changeset
   449
    return NW_STAT_DOM_WRONG_DOC_ERR;
hgs
parents:
diff changeset
   450
hgs
parents:
diff changeset
   451
  /* Only Element and Document nodes can have children */
hgs
parents:
diff changeset
   452
  if ((NW_DOM_Node_getNodeType(node) != NW_DOM_ELEMENT_NODE) &&
hgs
parents:
diff changeset
   453
      (NW_DOM_Node_getNodeType(node) != NW_DOM_DOCUMENT_NODE)) {
hgs
parents:
diff changeset
   454
    return NW_STAT_DOM_HEIRARCHY_REQUEST_ERR;
hgs
parents:
diff changeset
   455
  }
hgs
parents:
diff changeset
   456
hgs
parents:
diff changeset
   457
  child = NW_DOM_Node_getFirstChild (node);
hgs
parents:
diff changeset
   458
  while (child)
hgs
parents:
diff changeset
   459
  {
hgs
parents:
diff changeset
   460
    if (child == oldChild)
hgs
parents:
diff changeset
   461
    {
hgs
parents:
diff changeset
   462
      NW_TinyTree_attachBefore(oldChild, newChild);
hgs
parents:
diff changeset
   463
      return NW_DOM_Node_removeChild(node, oldChild);
hgs
parents:
diff changeset
   464
    }
hgs
parents:
diff changeset
   465
    child = NW_DOM_Node_getNextSibling(child);
hgs
parents:
diff changeset
   466
  }
hgs
parents:
diff changeset
   467
  /* The refChild is not a child of node */
hgs
parents:
diff changeset
   468
  return NW_STAT_NOT_FOUND;  
hgs
parents:
diff changeset
   469
}
hgs
parents:
diff changeset
   470
hgs
parents:
diff changeset
   471
/*
hgs
parents:
diff changeset
   472
 * Removes the oldChild
hgs
parents:
diff changeset
   473
 * Returns one of:
hgs
parents:
diff changeset
   474
 *   NW_STAT_BAD_INPUT_PARAM
hgs
parents:
diff changeset
   475
 *   NW_STAT_SUCCESS
hgs
parents:
diff changeset
   476
 *   NW_STAT_NOT_FOUND - If oldChild is not a child of given node
hgs
parents:
diff changeset
   477
 */
hgs
parents:
diff changeset
   478
EXPORT_C NW_Status_t
hgs
parents:
diff changeset
   479
NW_DOM_Node_removeChild(NW_DOM_Node_t *node, NW_DOM_Node_t *oldChild)
hgs
parents:
diff changeset
   480
{
hgs
parents:
diff changeset
   481
  NW_TinyTree_Node_t *child = NULL;
hgs
parents:
diff changeset
   482
hgs
parents:
diff changeset
   483
  if ((node == NULL) || (oldChild == NULL))
hgs
parents:
diff changeset
   484
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   485
hgs
parents:
diff changeset
   486
  child = NW_DOM_Node_getFirstChild (node);
hgs
parents:
diff changeset
   487
  while (child)
hgs
parents:
diff changeset
   488
  {
hgs
parents:
diff changeset
   489
    if (child == oldChild)
hgs
parents:
diff changeset
   490
    {
hgs
parents:
diff changeset
   491
      NW_TinyTree_deleteNode(oldChild);
hgs
parents:
diff changeset
   492
      return NW_STAT_SUCCESS;
hgs
parents:
diff changeset
   493
    }
hgs
parents:
diff changeset
   494
    child = NW_DOM_Node_getNextSibling(child);
hgs
parents:
diff changeset
   495
  }
hgs
parents:
diff changeset
   496
hgs
parents:
diff changeset
   497
  /* The refChild is not a child of node */
hgs
parents:
diff changeset
   498
  return NW_STAT_NOT_FOUND;  
hgs
parents:
diff changeset
   499
}
hgs
parents:
diff changeset
   500
hgs
parents:
diff changeset
   501
/*
hgs
parents:
diff changeset
   502
 * Appends a new child
hgs
parents:
diff changeset
   503
 * Returns one of:
hgs
parents:
diff changeset
   504
 *   NW_STAT_BAD_INPUT_PARAM
hgs
parents:
diff changeset
   505
 *   NW_STAT_SUCCESS
hgs
parents:
diff changeset
   506
 *   NW_STAT_DOM_WRONG_DOC_ERR - If newChild was created from a 
hgs
parents:
diff changeset
   507
 *        different document than the one that created the node
hgs
parents:
diff changeset
   508
 *   NW_STAT_DOM_HEIRARCHY_REQ_ERR - If node is of the type that 
hgs
parents:
diff changeset
   509
 *        does not allow children of the type of newChild node
hgs
parents:
diff changeset
   510
 */
hgs
parents:
diff changeset
   511
EXPORT_C NW_Status_t
hgs
parents:
diff changeset
   512
NW_DOM_Node_appendChild(NW_DOM_Node_t *node, NW_DOM_Node_t *newChild)
hgs
parents:
diff changeset
   513
{
hgs
parents:
diff changeset
   514
  NW_DOM_DocumentNode_t *doc = NULL;
hgs
parents:
diff changeset
   515
  NW_DOM_DocumentNode_t *newDoc = NULL;
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
  if (( node == NULL) || (newChild == NULL))
hgs
parents:
diff changeset
   518
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   519
hgs
parents:
diff changeset
   520
  doc = NW_DOM_Node_getOwnerDocument(node);
hgs
parents:
diff changeset
   521
  newDoc = NW_DOM_Node_getOwnerDocument(newChild);
hgs
parents:
diff changeset
   522
hgs
parents:
diff changeset
   523
 if ((doc == NULL) || (newDoc == NULL))
hgs
parents:
diff changeset
   524
    return NW_STAT_BAD_INPUT_PARAM;
hgs
parents:
diff changeset
   525
hgs
parents:
diff changeset
   526
  if (doc != newDoc)
hgs
parents:
diff changeset
   527
    return NW_STAT_DOM_WRONG_DOC_ERR;
hgs
parents:
diff changeset
   528
hgs
parents:
diff changeset
   529
  /* Only Element and Document nodes can have children */
hgs
parents:
diff changeset
   530
  if ((NW_DOM_Node_getNodeType(node) != NW_DOM_ELEMENT_NODE) &&
hgs
parents:
diff changeset
   531
      (NW_DOM_Node_getNodeType(node) != NW_DOM_DOCUMENT_NODE)) {
hgs
parents:
diff changeset
   532
    return NW_STAT_DOM_HEIRARCHY_REQUEST_ERR;
hgs
parents:
diff changeset
   533
  }
hgs
parents:
diff changeset
   534
hgs
parents:
diff changeset
   535
  return(NW_TinyTree_attachChild(node, newChild));
hgs
parents:
diff changeset
   536
}
hgs
parents:
diff changeset
   537
hgs
parents:
diff changeset
   538