1/** \file 2 * This is the standard tree adaptor used by the C runtime unless the grammar 3 * source file says to use anything different. It embeds a BASE_TREE to which 4 * it adds its own implementation of anything that the base tree is not 5 * good for, plus a number of methods that any other adaptor type 6 * needs to implement too. 7 * \ingroup pANTLR3_COMMON_TREE_ADAPTOR 8 */ 9 10// [The "BSD licence"] 11// Copyright (c) 2005-2009 Jim Idle, Temporal Wave LLC 12// http://www.temporal-wave.com 13// http://www.linkedin.com/in/jimidle 14// 15// All rights reserved. 16// 17// Redistribution and use in source and binary forms, with or without 18// modification, are permitted provided that the following conditions 19// are met: 20// 1. Redistributions of source code must retain the above copyright 21// notice, this list of conditions and the following disclaimer. 22// 2. Redistributions in binary form must reproduce the above copyright 23// notice, this list of conditions and the following disclaimer in the 24// documentation and/or other materials provided with the distribution. 25// 3. The name of the author may not be used to endorse or promote products 26// derived from this software without specific prior written permission. 27// 28// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 29// IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 30// OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 31// IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 32// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 33// NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 34// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 35// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 36// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 37// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 38 39#include <antlr3commontreeadaptor.h> 40 41#ifdef ANTLR3_WINDOWS 42#pragma warning( disable : 4100 ) 43#endif 44 45/* BASE_TREE_ADAPTOR overrides... */ 46static pANTLR3_BASE_TREE dupNode (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE treeNode); 47static pANTLR3_BASE_TREE create (pANTLR3_BASE_TREE_ADAPTOR adpator, pANTLR3_COMMON_TOKEN payload); 48static pANTLR3_BASE_TREE dbgCreate (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_COMMON_TOKEN payload); 49static pANTLR3_COMMON_TOKEN createToken (pANTLR3_BASE_TREE_ADAPTOR adaptor, ANTLR3_UINT32 tokenType, pANTLR3_UINT8 text); 50static pANTLR3_COMMON_TOKEN createTokenFromToken (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_COMMON_TOKEN fromToken); 51static pANTLR3_COMMON_TOKEN getToken (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 52static pANTLR3_STRING getText (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 53static ANTLR3_UINT32 getType (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 54static pANTLR3_BASE_TREE getChild (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_UINT32 i); 55static ANTLR3_UINT32 getChildCount (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 56static void replaceChildren (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE parent, ANTLR3_INT32 startChildIndex, ANTLR3_INT32 stopChildIndex, pANTLR3_BASE_TREE t); 57static void setDebugEventListener (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_DEBUG_EVENT_LISTENER debugger); 58static void setChildIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_INT32 i); 59static ANTLR3_INT32 getChildIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 60static void setParent (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE child, pANTLR3_BASE_TREE parent); 61static pANTLR3_BASE_TREE getParent (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE child); 62static void setChild (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_UINT32 i, pANTLR3_BASE_TREE child); 63static void deleteChild (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_UINT32 i); 64static pANTLR3_BASE_TREE errorNode (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_TOKEN_STREAM ctnstream, pANTLR3_COMMON_TOKEN startToken, pANTLR3_COMMON_TOKEN stopToken, pANTLR3_EXCEPTION e); 65/* Methods specific to each tree adaptor 66 */ 67static void setTokenBoundaries (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, pANTLR3_COMMON_TOKEN startToken, pANTLR3_COMMON_TOKEN stopToken); 68static void dbgSetTokenBoundaries (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, pANTLR3_COMMON_TOKEN startToken, pANTLR3_COMMON_TOKEN stopToken); 69static ANTLR3_MARKER getTokenStartIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 70static ANTLR3_MARKER getTokenStopIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t); 71 72static void ctaFree (pANTLR3_BASE_TREE_ADAPTOR adaptor); 73 74/** Create a new tree adaptor. Note that despite the fact that this is 75 * creating a new COMMON_TREE adaptor, we return the address of the 76 * BASE_TREE interface, as should any other adaptor that wishes to be 77 * used as the tree element of a tree parse/build. It needs to be given the 78 * address of a valid string factory as we do not know what the originating 79 * input stream encoding type was. This way we can rely on just using 80 * the original input stream's string factory or one of the correct type 81 * which the user supplies us. 82 */ 83ANTLR3_API pANTLR3_BASE_TREE_ADAPTOR 84ANTLR3_TREE_ADAPTORNew(pANTLR3_STRING_FACTORY strFactory) 85{ 86 pANTLR3_COMMON_TREE_ADAPTOR cta; 87 88 // First job is to create the memory we need for the tree adaptor interface. 89 // 90 cta = (pANTLR3_COMMON_TREE_ADAPTOR) ANTLR3_MALLOC((size_t)(sizeof(ANTLR3_COMMON_TREE_ADAPTOR))); 91 92 if (cta == NULL) 93 { 94 return NULL; 95 } 96 97 // Memory is initialized, so initialize the base tree adaptor 98 // 99 antlr3BaseTreeAdaptorInit(&(cta->baseAdaptor), NULL); 100 101 // Install our interface overrides. Strangeness is to allow generated code to treat them 102 // as returning void * 103 // 104 cta->baseAdaptor.dupNode = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 105 dupNode; 106 cta->baseAdaptor.create = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, pANTLR3_COMMON_TOKEN)) 107 create; 108 cta->baseAdaptor.createToken = 109 createToken; 110 cta->baseAdaptor.createTokenFromToken = 111 createTokenFromToken; 112 cta->baseAdaptor.setTokenBoundaries = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, pANTLR3_COMMON_TOKEN, pANTLR3_COMMON_TOKEN)) 113 setTokenBoundaries; 114 cta->baseAdaptor.getTokenStartIndex = (ANTLR3_MARKER (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 115 getTokenStartIndex; 116 cta->baseAdaptor.getTokenStopIndex = (ANTLR3_MARKER (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 117 getTokenStopIndex; 118 cta->baseAdaptor.getText = (pANTLR3_STRING (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 119 getText; 120 cta->baseAdaptor.getType = (ANTLR3_UINT32 (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 121 getType; 122 cta->baseAdaptor.getChild = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, ANTLR3_UINT32)) 123 getChild; 124 cta->baseAdaptor.setChild = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, ANTLR3_UINT32, void *)) 125 setChild; 126 cta->baseAdaptor.setParent = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, void *)) 127 setParent; 128 cta->baseAdaptor.getParent = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 129 getParent; 130 cta->baseAdaptor.setChildIndex = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, ANTLR3_UINT32)) 131 setChildIndex; 132 cta->baseAdaptor.deleteChild = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, ANTLR3_UINT32)) 133 deleteChild; 134 cta->baseAdaptor.getChildCount = (ANTLR3_UINT32 (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 135 getChildCount; 136 cta->baseAdaptor.getChildIndex = (ANTLR3_INT32 (*) (pANTLR3_BASE_TREE_ADAPTOR, void *)) 137 getChildIndex; 138 cta->baseAdaptor.free = (void (*) (pANTLR3_BASE_TREE_ADAPTOR)) 139 ctaFree; 140 cta->baseAdaptor.setDebugEventListener = 141 setDebugEventListener; 142 cta->baseAdaptor.replaceChildren = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, ANTLR3_INT32, ANTLR3_INT32, void *)) 143 replaceChildren; 144 cta->baseAdaptor.errorNode = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, pANTLR3_TOKEN_STREAM, pANTLR3_COMMON_TOKEN, pANTLR3_COMMON_TOKEN, pANTLR3_EXCEPTION)) 145 errorNode; 146 147 // Install the super class pointer 148 // 149 cta->baseAdaptor.super = cta; 150 151 // Install a tree factory for creating new tree nodes 152 // 153 cta->arboretum = antlr3ArboretumNew(strFactory); 154 155 // Install a token factory for imaginary tokens, these imaginary 156 // tokens do not require access to the input stream so we can 157 // dummy the creation of it, but they will need a string factory. 158 // 159 cta->baseAdaptor.tokenFactory = antlr3TokenFactoryNew(NULL); 160 cta->baseAdaptor.tokenFactory->unTruc.strFactory = strFactory; 161 162 // Allow the base tree adaptor to share the tree factory's string factory. 163 // 164 cta->baseAdaptor.strFactory = strFactory; 165 166 // Return the address of the base adaptor interface. 167 // 168 return &(cta->baseAdaptor); 169} 170 171/// Debugging version of the tree adaptor (not normally called as generated code 172/// calls setDebugEventListener instead which changes a normal token stream to 173/// a debugging stream and means that a user's instantiation code does not need 174/// to be changed just to debug with AW. 175/// 176ANTLR3_API pANTLR3_BASE_TREE_ADAPTOR 177ANTLR3_TREE_ADAPTORDebugNew(pANTLR3_STRING_FACTORY strFactory, pANTLR3_DEBUG_EVENT_LISTENER debugger) 178{ 179 pANTLR3_BASE_TREE_ADAPTOR ta; 180 181 // Create a normal one first 182 // 183 ta = ANTLR3_TREE_ADAPTORNew(strFactory); 184 185 if (ta != NULL) 186 { 187 // Reinitialize as a debug version 188 // 189 antlr3BaseTreeAdaptorInit(ta, debugger); 190 ta->create = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, pANTLR3_COMMON_TOKEN)) 191 dbgCreate; 192 ta->setTokenBoundaries = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, pANTLR3_COMMON_TOKEN, pANTLR3_COMMON_TOKEN)) 193 dbgSetTokenBoundaries; 194 } 195 196 return ta; 197} 198 199/// Causes an existing common tree adaptor to become a debug version 200/// 201static void 202setDebugEventListener (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_DEBUG_EVENT_LISTENER debugger) 203{ 204 // Reinitialize as a debug version 205 // 206 antlr3BaseTreeAdaptorInit(adaptor, debugger); 207 208 adaptor->create = (void * (*) (pANTLR3_BASE_TREE_ADAPTOR, pANTLR3_COMMON_TOKEN)) 209 dbgCreate; 210 adaptor->setTokenBoundaries = (void (*) (pANTLR3_BASE_TREE_ADAPTOR, void *, pANTLR3_COMMON_TOKEN, pANTLR3_COMMON_TOKEN)) 211 dbgSetTokenBoundaries; 212 213} 214 215static void 216ctaFree(pANTLR3_BASE_TREE_ADAPTOR adaptor) 217{ 218 pANTLR3_COMMON_TREE_ADAPTOR cta; 219 220 cta = (pANTLR3_COMMON_TREE_ADAPTOR)(adaptor->super); 221 222 /* Free the tree factory we created 223 */ 224 cta->arboretum->close(((pANTLR3_COMMON_TREE_ADAPTOR)(adaptor->super))->arboretum); 225 226 /* Free the token factory we created 227 */ 228 adaptor->tokenFactory->close(adaptor->tokenFactory); 229 230 /* Free the super pointer, as it is this that was allocated 231 * and is the common tree structure. 232 */ 233 ANTLR3_FREE(adaptor->super); 234} 235 236/* BASE_TREE_ADAPTOR overrides */ 237 238static pANTLR3_BASE_TREE 239errorNode (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_TOKEN_STREAM ctnstream, pANTLR3_COMMON_TOKEN startToken, pANTLR3_COMMON_TOKEN stopToken, pANTLR3_EXCEPTION e) 240{ 241 // Use the supplied common tree node stream to get another tree from the factory 242 // TODO: Look at creating the erronode as in Java, but this is complicated by the 243 // need to track and free the memory allocated to it, so for now, we just 244 // want something in the tree that isn't a NULL pointer. 245 // 246 return adaptor->createTypeText(adaptor, ANTLR3_TOKEN_INVALID, (pANTLR3_UINT8)"Tree Error Node"); 247 248} 249 250/** Duplicate the supplied node. 251 */ 252static pANTLR3_BASE_TREE 253dupNode (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE treeNode) 254{ 255 return treeNode == NULL ? NULL : treeNode->dupNode(treeNode); 256} 257 258static pANTLR3_BASE_TREE 259create (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_COMMON_TOKEN payload) 260{ 261 pANTLR3_BASE_TREE ct; 262 263 /* Create a new common tree as this is what this adaptor deals with 264 */ 265 ct = ((pANTLR3_COMMON_TREE_ADAPTOR)(adaptor->super))->arboretum->newFromToken(((pANTLR3_COMMON_TREE_ADAPTOR)(adaptor->super))->arboretum, payload); 266 267 /* But all adaptors return the pointer to the base interface. 268 */ 269 return ct; 270} 271static pANTLR3_BASE_TREE 272dbgCreate (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_COMMON_TOKEN payload) 273{ 274 pANTLR3_BASE_TREE ct; 275 276 ct = create(adaptor, payload); 277 adaptor->debugger->createNode(adaptor->debugger, ct); 278 279 return ct; 280} 281 282/** Tell me how to create a token for use with imaginary token nodes. 283 * For example, there is probably no input symbol associated with imaginary 284 * token DECL, but you need to create it as a payload or whatever for 285 * the DECL node as in ^(DECL type ID). 286 * 287 * If you care what the token payload objects' type is, you should 288 * override this method and any other createToken variant. 289 */ 290static pANTLR3_COMMON_TOKEN 291createToken (pANTLR3_BASE_TREE_ADAPTOR adaptor, ANTLR3_UINT32 tokenType, pANTLR3_UINT8 text) 292{ 293 pANTLR3_COMMON_TOKEN newToken; 294 295 newToken = adaptor->tokenFactory->newToken(adaptor->tokenFactory); 296 297 if (newToken != NULL) 298 { 299 newToken->textState = ANTLR3_TEXT_CHARP; 300 newToken->tokText.chars = (pANTLR3_UCHAR)text; 301 newToken->setType(newToken, tokenType); 302 newToken->input = adaptor->tokenFactory->input; 303 newToken->strFactory = adaptor->strFactory; 304 } 305 return newToken; 306} 307 308/** Tell me how to create a token for use with imaginary token nodes. 309 * For example, there is probably no input symbol associated with imaginary 310 * token DECL, but you need to create it as a payload or whatever for 311 * the DECL node as in ^(DECL type ID). 312 * 313 * This is a variant of createToken where the new token is derived from 314 * an actual real input token. Typically this is for converting '{' 315 * tokens to BLOCK etc... You'll see 316 * 317 * r : lc='{' ID+ '}' -> ^(BLOCK[$lc] ID+) ; 318 * 319 * If you care what the token payload objects' type is, you should 320 * override this method and any other createToken variant. 321 * 322 * NB: this being C it is not so easy to extend the types of creaeteToken. 323 * We will have to see if anyone needs to do this and add any variants to 324 * this interface. 325 */ 326static pANTLR3_COMMON_TOKEN 327createTokenFromToken (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_COMMON_TOKEN fromToken) 328{ 329 pANTLR3_COMMON_TOKEN newToken; 330 331 newToken = adaptor->tokenFactory->newToken(adaptor->tokenFactory); 332 333 if (newToken != NULL) 334 { 335 // Create the text using our own string factory to avoid complicating 336 // commontoken. 337 // 338 pANTLR3_STRING text; 339 340 newToken->toString = fromToken->toString; 341 342 if (fromToken->textState == ANTLR3_TEXT_CHARP) 343 { 344 newToken->textState = ANTLR3_TEXT_CHARP; 345 newToken->tokText.chars = fromToken->tokText.chars; 346 } 347 else 348 { 349 text = fromToken->getText(fromToken); 350 newToken->textState = ANTLR3_TEXT_STRING; 351 newToken->tokText.text = adaptor->strFactory->newPtr(adaptor->strFactory, text->chars, text->len); 352 } 353 354 newToken->setLine (newToken, fromToken->getLine(fromToken)); 355 newToken->setTokenIndex (newToken, fromToken->getTokenIndex(fromToken)); 356 newToken->setCharPositionInLine (newToken, fromToken->getCharPositionInLine(fromToken)); 357 newToken->setChannel (newToken, fromToken->getChannel(fromToken)); 358 newToken->setType (newToken, fromToken->getType(fromToken)); 359 } 360 361 return newToken; 362} 363 364/* Specific methods for a TreeAdaptor */ 365 366/** Track start/stop token for subtree root created for a rule. 367 * Only works with CommonTree nodes. For rules that match nothing, 368 * seems like this will yield start=i and stop=i-1 in a nil node. 369 * Might be useful info so I'll not force to be i..i. 370 */ 371static void 372setTokenBoundaries (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, pANTLR3_COMMON_TOKEN startToken, pANTLR3_COMMON_TOKEN stopToken) 373{ 374 ANTLR3_MARKER start; 375 ANTLR3_MARKER stop; 376 377 pANTLR3_COMMON_TREE ct; 378 379 if (t == NULL) 380 { 381 return; 382 } 383 384 if ( startToken != NULL) 385 { 386 start = startToken->getTokenIndex(startToken); 387 } 388 else 389 { 390 start = 0; 391 } 392 393 if ( stopToken != NULL) 394 { 395 stop = stopToken->getTokenIndex(stopToken); 396 } 397 else 398 { 399 stop = 0; 400 } 401 402 ct = (pANTLR3_COMMON_TREE)(t->super); 403 404 ct->startIndex = start; 405 ct->stopIndex = stop; 406 407} 408static void 409dbgSetTokenBoundaries (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, pANTLR3_COMMON_TOKEN startToken, pANTLR3_COMMON_TOKEN stopToken) 410{ 411 setTokenBoundaries(adaptor, t, startToken, stopToken); 412 413 if (t != NULL && startToken != NULL && stopToken != NULL) 414 { 415 adaptor->debugger->setTokenBoundaries(adaptor->debugger, t, startToken->getTokenIndex(startToken), stopToken->getTokenIndex(stopToken)); 416 } 417} 418 419static ANTLR3_MARKER 420getTokenStartIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t) 421{ 422 return ((pANTLR3_COMMON_TREE)(t->super))->startIndex; 423} 424 425static ANTLR3_MARKER 426getTokenStopIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t) 427{ 428 return ((pANTLR3_COMMON_TREE)(t->super))->stopIndex; 429} 430 431static pANTLR3_STRING 432getText (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t) 433{ 434 return t->getText(t); 435} 436 437static ANTLR3_UINT32 438getType (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t) 439{ 440 return t->getType(t); 441} 442 443static void 444replaceChildren 445(pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE parent, ANTLR3_INT32 startChildIndex, ANTLR3_INT32 stopChildIndex, pANTLR3_BASE_TREE t) 446{ 447 if (parent != NULL) 448 { 449 parent->replaceChildren(parent, startChildIndex, stopChildIndex, t); 450 } 451} 452 453static pANTLR3_BASE_TREE 454getChild (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_UINT32 i) 455{ 456 return t->getChild(t, i); 457} 458static void 459setChild (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_UINT32 i, pANTLR3_BASE_TREE child) 460{ 461 t->setChild(t, i, child); 462} 463 464static void 465deleteChild (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_UINT32 i) 466{ 467 t->deleteChild(t, i); 468} 469 470static ANTLR3_UINT32 471getChildCount (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t) 472{ 473 return t->getChildCount(t); 474} 475 476static void 477setChildIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t, ANTLR3_INT32 i) 478{ 479 t->setChildIndex(t, i); 480} 481 482static ANTLR3_INT32 483getChildIndex (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE t) 484{ 485 return t->getChildIndex(t); 486} 487static void 488setParent (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE child, pANTLR3_BASE_TREE parent) 489{ 490 child->setParent(child, parent); 491} 492static pANTLR3_BASE_TREE 493getParent (pANTLR3_BASE_TREE_ADAPTOR adaptor, pANTLR3_BASE_TREE child) 494{ 495 return child->getParent(child); 496} 497