summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTor Lillqvist <tml@collabora.com>2018-06-20 20:11:55 +0300
committerTor Lillqvist <tml@collabora.com>2018-06-20 20:51:06 +0200
commit2d8dd0af877de8494ca9c2c027eba4a42bbc09eb (patch)
tree8a3757d2eba5f4b725bedd1b4b652c9a45fe7c48
parent6c85a19c887b6147ec7d3a600b51cb2a44284fa2 (diff)
tdf#104332 (and others): Speed up Lightproof initialisation
Delay import of the the heavy lightproof_impl_pt_BR to when actually needed. Shaves several hundred milliseconds (on my machine, about 300 ms) from the time needed to just get a list of what grammars checkers are available. It's silly to load the heavy pt-BR impl module even if no Brazilian Portuguese proof reading is being performed. Sure, the same change could be done to the other Lightproof dictionaries, too, but they are much smaller, so importing them unconditionally always does not hurt so much. Change-Id: I3c3f64e80bd9519f188905abda7c25337c81462d Reviewed-on: https://gerrit.libreoffice.org/56176 Reviewed-by: László Németh <nemeth@numbertext.org> Tested-by: Tor Lillqvist <tml@collabora.com>
-rw-r--r--pt_BR/Lightproof.py17
-rw-r--r--pt_BR/pythonpath/lightproof_handler_pt_BR.py2
2 files changed, 10 insertions, 9 deletions
diff --git a/pt_BR/Lightproof.py b/pt_BR/Lightproof.py
index 8064fee..cf0247d 100644
--- a/pt_BR/Lightproof.py
+++ b/pt_BR/Lightproof.py
@@ -3,9 +3,8 @@
# 2009-2012 (c) Laszlo Nemeth (nemeth at numbertext org), license: MPL 1.1 / GPLv3+ / LGPLv3+
import uno, unohelper, os, sys, traceback
-from lightproof_impl_pt_BR import locales
-from lightproof_impl_pt_BR import pkg
-import lightproof_impl_pt_BR
+locales = {'pt-BR': ['pt', 'BR', '']}
+pkg = "pt_BR"
import lightproof_handler_pt_BR
from com.sun.star.linguistic2 import XProofreader, XSupportedLocales
@@ -30,11 +29,6 @@ class Lightproof( unohelper.Base, XProofreader, XServiceInfo, XServiceName, XSer
l = locales[i]
self.locales += [Locale(l[0], l[1], l[2])]
self.locales = tuple(self.locales)
- currentContext = uno.getComponentContext()
- lightproof_impl_pt_BR.SMGR = currentContext.ServiceManager
- lightproof_impl_pt_BR.spellchecker = \
- lightproof_impl_pt_BR.SMGR.createInstanceWithContext("com.sun.star.linguistic2.SpellChecker", currentContext)
- lightproof_handler_pt_BR.load(currentContext)
# XServiceName method implementations
def getServiceName(self):
@@ -68,6 +62,13 @@ class Lightproof( unohelper.Base, XProofreader, XServiceInfo, XServiceName, XSer
def doProofreading(self, nDocId, rText, rLocale, nStartOfSentencePos, \
nSuggestedSentenceEndPos, rProperties):
+ import lightproof_impl_pt_BR
+ currentContext = uno.getComponentContext()
+ if lightproof_impl_pt_BR.SMGR == None:
+ lightproof_impl_pt_BR.SMGR = currentContext.ServiceManager
+ lightproof_impl_pt_BR.spellchecker = \
+ lightproof_impl_en.SMGR.createInstanceWithContext("com.sun.star.linguistic2.SpellChecker", currentContext)
+ lightproof_handler_pt_BR.load(currentContext)
aRes = uno.createUnoStruct( "com.sun.star.linguistic2.ProofreadingResult" )
aRes.aDocumentIdentifier = nDocId
aRes.aText = rText
diff --git a/pt_BR/pythonpath/lightproof_handler_pt_BR.py b/pt_BR/pythonpath/lightproof_handler_pt_BR.py
index 406971a..e80e320 100644
--- a/pt_BR/pythonpath/lightproof_handler_pt_BR.py
+++ b/pt_BR/pythonpath/lightproof_handler_pt_BR.py
@@ -1,7 +1,7 @@
import uno
import unohelper
import lightproof_opts_pt_BR
-from lightproof_impl_pt_BR import pkg
+pkg = "pt_BR"
from com.sun.star.lang import XServiceInfo
from com.sun.star.awt import XContainerWindowEventHandler