14887Schin /*********************************************************************** 24887Schin * * 34887Schin * This software is part of the ast package * 4*12068SRoger.Faulkner@Oracle.COM * Copyright (c) 1985-2010 AT&T Intellectual Property * 54887Schin * and is licensed under the * 64887Schin * Common Public License, Version 1.0 * 78462SApril.Chin@Sun.COM * by AT&T Intellectual Property * 84887Schin * * 94887Schin * A copy of the License is available at * 104887Schin * http://www.opensource.org/licenses/cpl1.0.txt * 114887Schin * (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9) * 124887Schin * * 134887Schin * Information and Software Systems Research * 144887Schin * AT&T Research * 154887Schin * Florham Park NJ * 164887Schin * * 174887Schin * Glenn Fowler <gsf@research.att.com> * 184887Schin * David Korn <dgk@research.att.com> * 194887Schin * Phong Vo <kpv@research.att.com> * 204887Schin * * 214887Schin ***********************************************************************/ 224887Schin #include "dthdr.h" 234887Schin 244887Schin /* Return the # of objects in the dictionary 254887Schin ** 264887Schin ** Written by Kiem-Phong Vo (5/25/96) 274887Schin */ 284887Schin 294887Schin #if __STD_C treecount(reg Dtlink_t * e)304887Schinstatic int treecount(reg Dtlink_t* e) 314887Schin #else 324887Schin static int treecount(e) 334887Schin reg Dtlink_t* e; 344887Schin #endif 354887Schin { return e ? treecount(e->left) + treecount(e->right) + 1 : 0; 364887Schin } 374887Schin 384887Schin #if __STD_C dtsize(Dt_t * dt)394887Schinint dtsize(Dt_t* dt) 404887Schin #else 414887Schin int dtsize(dt) 424887Schin Dt_t* dt; 434887Schin #endif 444887Schin { 454887Schin reg Dtlink_t* t; 464887Schin reg int size; 474887Schin 484887Schin UNFLATTEN(dt); 494887Schin 504887Schin if(dt->data->size < 0) /* !(dt->data->type&(DT_SET|DT_BAG)) */ 514887Schin { if(dt->data->type&(DT_OSET|DT_OBAG)) 524887Schin dt->data->size = treecount(dt->data->here); 534887Schin else if(dt->data->type&(DT_LIST|DT_STACK|DT_QUEUE)) 544887Schin { for(size = 0, t = dt->data->head; t; t = t->right) 554887Schin size += 1; 564887Schin dt->data->size = size; 574887Schin } 584887Schin } 594887Schin 604887Schin return dt->data->size; 614887Schin } 62