[orca] Work on bgo#491756 - Performance Metabug
- From: William Walker <wwalker src gnome org>
- To: svn-commits-list gnome org
- Subject: [orca] Work on bgo#491756 - Performance Metabug
- Date: Mon, 22 Jun 2009 22:49:10 -0400 (EDT)
commit aa9e32114555fe5478af86ac3d7e327364207251
Author: Willie Walker <william walker sun com>
Date: Mon Jun 22 22:47:17 2009 -0400
Work on bgo#491756 - Performance Metabug
Cache displayedText and displayedLabel in script.generatorCache
src/orca/default.py | 29 ++++++++++++++++++++++++-----
1 files changed, 24 insertions(+), 5 deletions(-)
---
diff --git a/src/orca/default.py b/src/orca/default.py
index e6efbd3..a16a302 100644
--- a/src/orca/default.py
+++ b/src/orca/default.py
@@ -5991,13 +5991,22 @@ class Script(script.Script):
if there is nothing of interest here.
"""
- labelString = None
+ DISPLAYED_LABEL = 'displayedLabel'
+
+ try:
+ return self.generatorCache[DISPLAYED_LABEL][obj]
+ except:
+ if not self.generatorCache.has_key(DISPLAYED_LABEL):
+ self.generatorCache[DISPLAYED_LABEL] = {}
+ labelString = None
+
labels = self.findDisplayedLabel(obj)
for label in labels:
labelString = self.appendString(labelString,
self.getDisplayedText(label))
- return labelString
+ self.generatorCache[DISPLAYED_LABEL][obj] = labelString
+ return self.generatorCache[DISPLAYED_LABEL][obj]
def __getDisplayedTextInComboBox(self, combo):
@@ -6074,11 +6083,20 @@ class Script(script.Script):
any text being shown.
"""
- displayedText = None
+ DISPLAYED_TEXT = 'displayedText'
+
+ try:
+ return self.generatorCache[DISPLAYED_TEXT][obj]
+ except:
+ if not self.generatorCache.has_key(DISPLAYED_TEXT):
+ self.generatorCache[DISPLAYED_TEXT] = {}
+ displayedText = None
role = obj.getRole()
if role == pyatspi.ROLE_COMBO_BOX:
- return self.__getDisplayedTextInComboBox(obj)
+ displayedText = self.__getDisplayedTextInComboBox(obj)
+ self.generatorCache[DISPLAYED_TEXT][obj] = displayedText
+ return self.generatorCache[DISPLAYED_TEXT][obj]
# The accessible text of an object is used to represent what is
# drawn on the screen.
@@ -6132,7 +6150,8 @@ class Script(script.Script):
displayedText = self.appendString(displayedText,
childText)
- return displayedText
+ self.generatorCache[DISPLAYED_TEXT][obj] = displayedText
+ return self.generatorCache['displayedText'][obj]
def getTextForValue(self, obj):
"""Returns the text to be displayed for the object's current value.
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]