From: miker Date: Fri, 11 Apr 2008 14:03:27 +0000 (+0000) Subject: Patch from Scott McKellar (with commentary on future plans): X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=f43270c24570fbeff290035ad5d5316f6ebc962f;p=working%2FOpenSRF.git Patch from Scott McKellar (with commentary on future plans): This patch applies the const qualifier to several variables, each of them a copy of the "current" member of an osrfHashIterator. ********************** While this patch is pretty inconsequential on its own, it is part of a larger plan to streamline the use of osrfHashIterators. The "current" member points to a dynamically allocated string. Every time we advance the iterator, we free the string and allocate another one to replace it. My plan is to reuse the buffer whenever possible so as to reduce the churning of memory through malloc() and free(). This approach will require an additional member to keep track of the current capacity of the buffer, rather like the "size" member of a growing_buffer. It will also require that all code using osrfHashIterators treat the "current" member as read-only. If somebody frees and replaces the buffer outside of the proper interface, then buffer management will get very confused. I doubt that any code does anything so perfidious, but I'm going through the files to make sure. Adding the const qualifier is an easy way not only to verify that nothing bad is happening, but also to make it less likely that something bad will happen in the future. git-svn-id: svn://svn.open-ils.org/OpenSRF/trunk@1303 9efc2488-bf62-4759-914b-345cdb29e865 --- diff --git a/src/router/osrf_router.c b/src/router/osrf_router.c index 5a50041..dbeea1f 100644 --- a/src/router/osrf_router.c +++ b/src/router/osrf_router.c @@ -128,7 +128,7 @@ void osrfRouterRun( osrfRouter* router ) { while( (class = osrfHashIteratorNext(itr)) ) { - char* classname = itr->current; + const char* classname = itr->current; if( classname && (class = osrfRouterFindClass( router, classname )) ) { @@ -574,7 +574,7 @@ static int _osrfRouterFillFDSet( osrfRouter* router, fd_set* set ) { osrfHashIterator* itr = osrfNewHashIterator(router->classes); while( (class = osrfHashIteratorNext(itr)) ) { - char* classname = itr->current; + const char* classname = itr->current; if( classname && (class = osrfRouterFindClass( router, classname )) ) { sockid = class->ROUTER_SOCKFD; @@ -732,7 +732,7 @@ static int osrfRouterProcessAppRequest( osrfRouter* router, transport_message* m while( (class = osrfHashIteratorNext(class_itr)) ) { jsonObject* class_res = jsonNewObjectType(JSON_HASH); - char* classname = class_itr->current; + const char* classname = class_itr->current; osrfHashIterator* node_itr = osrfNewHashIterator(class->nodes); while( (node = osrfHashIteratorNext(node_itr)) ) { @@ -756,7 +756,7 @@ static int osrfRouterProcessAppRequest( osrfRouter* router, transport_message* m while( (class = osrfHashIteratorNext(class_itr)) ) { count = 0; - char* classname = class_itr->current; + const char* classname = class_itr->current; osrfHashIterator* node_itr = osrfNewHashIterator(class->nodes); while( (node = osrfHashIteratorNext(node_itr)) ) {