Kaydet (Commit) db0e131d authored tarafından Andreas Schlüns's avatar Andreas Schlüns

#118074# handle non existing accelerator configs gracefully

üst 82e69e95
......@@ -2,9 +2,9 @@
*
* $RCSfile: documentacceleratorconfiguration.cxx,v $
*
* $Revision: 1.2 $
* $Revision: 1.3 $
*
* last change: $Author: rt $ $Date: 2004-09-20 10:05:46 $
* last change: $Author: as $ $Date: 2004-10-14 09:26:21 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
......@@ -150,11 +150,6 @@ void SAL_CALL DocumentAcceleratorConfiguration::initialize(const css::uno::Seque
::rtl::OUString::createFromAscii("DocumentRoot"),
css::uno::Reference< css::embed::XStorage >());
if (!m_xDocumentRoot.is())
throw css::uno::RuntimeException(
::rtl::OUString::createFromAscii("The document dependend accelerator configuration was initialized with an invalid roo storage!"),
static_cast< ::cppu::OWeakObject* >(this));
aWriteLock.unlock();
// <- SAFE ----------------------------------
......@@ -170,11 +165,20 @@ void DocumentAcceleratorConfiguration::impl_ts_fillCache()
aReadLock.unlock();
// <- SAFE ----------------------------------
// Sometimes we must live without a document root.
// E.g. if the document is readonly ...
if (!xDocumentRoot.is())
return;
// get current office locale ... but dont cache it.
// Otherwise we must be listener on the configuration layer
// which seems to superflous for this small implementation .-)
::comphelper::Locale aLocale = impl_ts_getLocale();
// May be the current document does not contain any
// accelerator config? Handle it gracefully :-)
try
{
// Note: The used preset class is threadsafe by itself ... and live if we live!
// We do not need any mutex here.
......@@ -188,6 +192,11 @@ void DocumentAcceleratorConfiguration::impl_ts_fillCache()
AcceleratorConfiguration::reload();
m_aPresetHandler.addStorageListener(this);
}
catch(const css::uno::RuntimeException& exRun)
{ throw exRun; }
catch(const css::uno::Exception&)
{}
}
} // namespace framework
......@@ -2,9 +2,9 @@
*
* $RCSfile: globalacceleratorconfiguration.cxx,v $
*
* $Revision: 1.2 $
* $Revision: 1.3 $
*
* last change: $Author: rt $ $Date: 2004-09-20 10:05:55 $
* last change: $Author: as $ $Date: 2004-10-14 09:26:21 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
......@@ -159,6 +159,9 @@ void GlobalAcceleratorConfiguration::impl_ts_fillCache()
// which seems to superflous for this small implementation .-)
::comphelper::Locale aLocale = impl_ts_getLocale();
// May be there exists no accelerator config? Handle it gracefully :-)
try
{
// Note: The used preset class is threadsafe by itself ... and live if we live!
// We do not need any mutex here.
......@@ -178,6 +181,11 @@ void GlobalAcceleratorConfiguration::impl_ts_fillCache()
AcceleratorConfiguration::reload();
m_aPresetHandler.addStorageListener(this);
}
catch(const css::uno::RuntimeException& exRun)
{ throw exRun; }
catch(const css::uno::Exception&)
{}
}
} // namespace framework
......@@ -2,9 +2,9 @@
*
* $RCSfile: moduleacceleratorconfiguration.cxx,v $
*
* $Revision: 1.2 $
* $Revision: 1.3 $
*
* last change: $Author: rt $ $Date: 2004-09-20 10:06:24 $
* last change: $Author: as $ $Date: 2004-10-14 09:26:22 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
......@@ -189,6 +189,10 @@ void ModuleAcceleratorConfiguration::impl_ts_fillCache()
// which seems to superflous for this small implementation .-)
::comphelper::Locale aLocale = impl_ts_getLocale();
// May be the current app module does not have any
// accelerator config? Handle it gracefully :-)
try
{
// Note: The used preset class is threadsafe by itself ... and live if we live!
// We do not need any mutex here.
......@@ -208,6 +212,11 @@ void ModuleAcceleratorConfiguration::impl_ts_fillCache()
AcceleratorConfiguration::reload();
m_aPresetHandler.addStorageListener(this);
}
catch(const css::uno::RuntimeException& exRun)
{ throw exRun; }
catch(const css::uno::Exception&)
{}
}
} // namespace framework
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment