7411085dcf17f054fb8059ed56fca2c8202f9ac3 max Wed Dec 17 09:18:49 2014 -0800 adding a measuretiming for the bottleneck, refs #14539 diff --git src/hg/hgTracks/hgTracks.c src/hg/hgTracks/hgTracks.c index 2d737b7f..7331804 100644 --- src/hg/hgTracks/hgTracks.c +++ src/hg/hgTracks/hgTracks.c @@ -5741,38 +5741,43 @@ /* Reset vars except for position and database. */ { static char *except[] = {"db", "position", NULL}; char *cookieName = hUserCookie(); char *sessionId = cgiOptionalString(cartSessionVarName()); char *userId = findCookieData(cookieName); struct cart *oldCart = cartNew(userId, sessionId, NULL, NULL); cartRemoveExcept(oldCart, except); cartCheckout(&oldCart); cgiVarExcludeExcept(except); } void doMiddle(struct cart *theCart) /* Print the body of an html file. */ { +cart = theCart; +measureTiming = hPrintStatus() && isNotEmpty(cartOptionalString(cart, "measureTiming")); +if (measureTiming) + measureTime("Startup"); + hgBotDelay(); +if (measureTiming) + measureTime("Bottleneck delay"); + char *debugTmp = NULL; /* Uncomment this to see parameters for debugging. */ /* struct dyString *state = NULL; */ /* Initialize layout and database. */ -cart = theCart; - -measureTiming = hPrintStatus() && isNotEmpty(cartOptionalString(cart, "measureTiming")); if (measureTiming) measureTime("Get cart of %d for user:%u session:%u", theCart->hash->elCount, theCart->userId, theCart->sessionId); /* #if 1 this to see parameters for debugging. */ /* Be careful though, it breaks if custom track * is more than 4k */ #if 0 state = cgiUrlString(); printf("State: %s\n", state->string); #endif getDbAndGenome(cart, &database, &organism, oldVars); protDbName = hPdbFromGdb(database); debugTmp = cartUsualString(cart, "hgDebug", "off");