]> granicus.if.org Git - postgresql/commitdiff
Slight refactoring and optimization of some code in WaitOnLock().
authorNeil Conway <neilc@samurai.com>
Fri, 11 Mar 2005 03:52:06 +0000 (03:52 +0000)
committerNeil Conway <neilc@samurai.com>
Fri, 11 Mar 2005 03:52:06 +0000 (03:52 +0000)
src/backend/storage/lmgr/lock.c

index a651033352bba67fe12d558c18d82b3bd8a8bf89..0073666216ff58f2f7f57fff7e87b87cb58ee294 100644 (file)
@@ -8,7 +8,7 @@
  *
  *
  * IDENTIFICATION
- *       $PostgreSQL: pgsql/src/backend/storage/lmgr/lock.c,v 1.147 2005/03/01 21:14:59 tgl Exp $
+ *       $PostgreSQL: pgsql/src/backend/storage/lmgr/lock.c,v 1.148 2005/03/11 03:52:06 neilc Exp $
  *
  * NOTES
  *       Outside modules can create a lock table and acquire/release
@@ -1076,6 +1076,7 @@ WaitOnLock(LOCKMETHODID lockmethodid, LOCALLOCK *locallock,
        LockMethod      lockMethodTable = LockMethods[lockmethodid];
        char       *new_status,
                           *old_status;
+       size_t          len;
 
        Assert(lockmethodid < NumLockMethods);
 
@@ -1083,9 +1084,10 @@ WaitOnLock(LOCKMETHODID lockmethodid, LOCALLOCK *locallock,
                           locallock->lock, locallock->tag.mode);
 
        old_status = pstrdup(get_ps_display());
-       new_status = (char *) palloc(strlen(old_status) + 10);
-       strcpy(new_status, old_status);
-       strcat(new_status, " waiting");
+       len = strlen(old_status);
+       new_status = (char *) palloc(len + 8 + 1);
+       memcpy(new_status, old_status, len);
+       strcpy(new_status + len, " waiting");
        set_ps_display(new_status);
 
        awaitedLock = locallock;