summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVenetia <venetiarosita@gmail.com>2024-02-26 09:18:18 -0700
committerStephan Bergmann <stephan.bergmann@allotropia.de>2024-05-15 08:26:57 +0200
commita82aaae3686daa7f40b4ba41e837d2e47408153c (patch)
treeb0bd1648029d52ac4202c3c0f124c8c3d31ad5ca
parent0cf10e8669c6f40a2187624469682c5bbc0bfb4d (diff)
tdf#70526 Provide start up time measurements
Added support for measuring the start up time between each Splashscreen update. Change-Id: Id38058c89c8524d782bf15cd956c8fba5de056de Reviewed-on: https://gerrit.libreoffice.org/c/core/+/163965 Tested-by: Jenkins Reviewed-by: Stephan Bergmann <stephan.bergmann@allotropia.de>
-rw-r--r--desktop/source/app/app.cxx42
-rw-r--r--include/sal/log-areas.dox1
2 files changed, 42 insertions, 1 deletions
diff --git a/desktop/source/app/app.cxx b/desktop/source/app/app.cxx
index eff8b46d069f..7075d6afcb89 100644
--- a/desktop/source/app/app.cxx
+++ b/desktop/source/app/app.cxx
@@ -1259,9 +1259,29 @@ struct ExecuteGlobals
}
static ExecuteGlobals* pExecGlobals = nullptr;
-
+static std::chrono::high_resolution_clock::time_point startFuncTp;
int Desktop::Main()
{
+ std::chrono::high_resolution_clock::time_point startT;
+
+#ifdef SAL_LOG_INFO
+ startFuncTp = std::chrono::high_resolution_clock::now();
+ startT = std::chrono::high_resolution_clock::now();
+
+ auto recordTime = [](std::chrono::high_resolution_clock::time_point& startTp, const char* message)
+ {
+ const auto endTp = std::chrono::high_resolution_clock::now();
+ auto tMs = std::chrono::duration_cast<std::chrono::milliseconds>(endTp - startTp);
+ SAL_INFO("desktop.startuptime", message << tMs.count() << " ms");
+ startTp = std::chrono::high_resolution_clock::now();
+ };
+#else
+ auto recordTime = [](...)
+ {
+ };
+#endif
+
+
pExecGlobals = new ExecuteGlobals();
// Remember current context object
@@ -1300,6 +1320,7 @@ int Desktop::Main()
#endif
SetSplashScreenProgress(10);
+ recordTime(startT, "SetSplashScreenProgress(10): time = ");
userinstall::Status inst_fin = userinstall::finalize();
if (inst_fin != userinstall::EXISTED && inst_fin != userinstall::CREATED)
@@ -1318,6 +1339,8 @@ int Desktop::Main()
utl::Bootstrap::reloadData();
SetSplashScreenProgress(20);
+ recordTime(startT, "SetSplashScreenProgress(20): time = ");
+
Reference< XComponentContext > xContext = ::comphelper::getProcessComponentContext();
Reference< XRestartManager > xRestartManager( OfficeRestartManager::get(xContext) );
@@ -1328,6 +1351,8 @@ int Desktop::Main()
SetSplashScreenProgress(25);
+ recordTime(startT, "SetSplashScreenProgress(25): time = ");
+
#if HAVE_FEATURE_DESKTOP && !defined(EMSCRIPTEN)
// check user installation directory for lockfile so we can be sure
// there is no other instance using our data files from a remote host
@@ -1363,6 +1388,8 @@ int Desktop::Main()
SetSplashScreenProgress(30);
+ recordTime(startT, "SetSplashScreenProgress(30): time = ");
+
// create title string
OUString aTitle(ReplaceStringHookProc(RID_APPTITLE));
#ifdef DBG_UTIL
@@ -1372,8 +1399,12 @@ int Desktop::Main()
SetDisplayName( aTitle );
SetSplashScreenProgress(35);
+
+ recordTime(startT, "SetSplashScreenProgress(35): time = ");
+
pExecGlobals->pPathOptions.reset( new SvtPathOptions);
SetSplashScreenProgress(40);
+ recordTime(startT, "SetSplashScreenProgress(40): time = ");
xDesktop = css::frame::Desktop::create( xContext );
@@ -1492,6 +1523,7 @@ int Desktop::Main()
pExecGlobals->xGlobalBroadcaster->documentEventOccured(aEvent);
SetSplashScreenProgress(50);
+ recordTime(startT, "SetSplashScreenProgress(50): time = ");
// Backing Component
bool bCrashed = false;
@@ -1546,6 +1578,7 @@ int Desktop::Main()
}
SetSplashScreenProgress(55);
+ recordTime(startT, "SetSplashScreenProgress(55): time = ");
svtools::ApplyFontSubstitutionsToVcl();
@@ -1553,6 +1586,7 @@ int Desktop::Main()
SvtTabAppearanceCfg::SetApplicationDefaults( this );
SvtAccessibilityOptions::SetVCLSettings();
SetSplashScreenProgress(60);
+ recordTime(startT, "SetSplashScreenProgress(60): time = ");
if ( !pExecGlobals->bRestartRequested )
{
@@ -1560,11 +1594,13 @@ int Desktop::Main()
// Preload function depends on an initialized sfx application!
SetSplashScreenProgress(75);
+ recordTime(startT, "SetSplashScreenProgress(75): time = ");
// use system window dialogs
Application::SetSystemWindowMode( SystemWindowFlags::DIALOG );
SetSplashScreenProgress(80);
+ recordTime(startT, "SetSplashScreenProgress(80): time = ");
if ( !rCmdLineArgs.IsInvisible() &&
!rCmdLineArgs.IsNoQuickstart() )
@@ -1573,6 +1609,7 @@ int Desktop::Main()
if ( xDesktop.is() )
xDesktop->addTerminateListener( new RequestHandlerController );
SetSplashScreenProgress(100);
+ recordTime(startT, "SetSplashScreenProgress(100): time = ");
// FIXME: move this somewhere sensible.
#if HAVE_FEATURE_OPENCL
@@ -1937,6 +1974,9 @@ IMPL_LINK_NOARG(Desktop, OpenClients_Impl, void*, void)
const char *pExitPostStartup = getenv ("OOO_EXIT_POST_STARTUP");
if (pExitPostStartup && *pExitPostStartup)
new ExitTimer();
+ const auto endTp = std::chrono::high_resolution_clock::now();
+ auto tMs = std::chrono::duration_cast<std::chrono::milliseconds>(endTp - startFuncTp);
+ SAL_INFO( "desktop.startuptime", "Total Start Up time(ms) = " << tMs.count());
}
void Desktop::OpenClients()
diff --git a/include/sal/log-areas.dox b/include/sal/log-areas.dox
index a2240a89a803..6fffb03d7424 100644
--- a/include/sal/log-areas.dox
+++ b/include/sal/log-areas.dox
@@ -172,6 +172,7 @@ certain functionality.
@li @c desktop.migration
@li @c desktop.offacc
@li @c desktop.splash
+@li @c desktop.startuptime - Log area for start up measurement time
@li @c desktop.test
@li @c desktop.updater