# Orca # # Copyright 2005-2008 Sun Microsystems Inc. # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 2.1 of the License, or (at your option) any later version. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; if not, write to the # Free Software Foundation, Inc., Franklin Street, Fifth Floor, # Boston MA 02110-1301 USA. """Provides the default implementation for bookmarks in Orca.""" import pickle import pyatspi import os import urllib.parse from . import messages from . import orca_state from . import settings_manager _settingsManager = settings_manager.getManager() class Bookmarks: """Represents a default bookmark handler.""" def __init__(self, script): self._script = script self._bookmarks = {} self._saveObservers = [] self._loadObservers = [] self._loadBookmarks() self._currentbookmarkindex = None def addSaveObserver(self, observer): self._saveObservers.append(observer) def addLoadObserver(self, observer): self._loadObservers.append(observer) def goToBookmark(self, inputEvent, index=None): """ Go to the bookmark indexed by inputEvent.hw_code """ # establish the _bookmarks index index = index or inputEvent.hw_code try: context = self._script.getFlatReviewContext() context_info = self._bookmarks[index] context.setCurrent(context_info['line'], context_info['zone'], \ context_info['word'], context_info['char']) self._bookmarks[index] = context_info except KeyError: self._script.systemBeep() return self._script.flatReviewContext = context self._script.reviewCurrentItem(inputEvent) # update the currentbookmark self._currentbookmarkindex = index def addBookmark(self, inputEvent): """ Add an in-page accessible object bookmark for this key. """ context = self._script.getFlatReviewContext() self._bookmarks[inputEvent.hw_code] = self._contextToBookmark(context) self._script.presentMessage(messages.BOOKMARK_ENTERED) def saveBookmarks(self, inputEvent): """ Save the bookmarks for this script. """ try: self.saveBookmarksToDisk(self._bookmarks) self._script.presentMessage(messages.BOOKMARKS_SAVED) except IOError: self._script.presentMessage(messages.BOOKMARKS_SAVED_FAILURE) # Notify the observers for o in self._saveObservers: o() def goToNextBookmark(self, inputEvent): """ Go to the next bookmark location. If no bookmark has yet to be selected, the first bookmark will be used. """ # get the hardware keys that have registered bookmarks hwkeys = sorted(self._bookmarks.keys()) # no bookmarks have been entered if len(hwkeys) == 0: self._script.systemBeep() return # only 1 bookmark or we are just starting out elif len(hwkeys) == 1 or self._currentbookmarkindex is None: self.goToBookmark(None, index=hwkeys[0]) return # find current bookmark hw_code in our sorted list. # Go to next one if possible try: index = hwkeys.index(self._currentbookmarkindex) self.goToBookmark(None, index=hwkeys[index+1]) except (ValueError, KeyError, IndexError): self.goToBookmark(None, index=hwkeys[0]) def goToPrevBookmark(self, inputEvent): # get the hardware keys that have registered bookmarks hwkeys = sorted(self._bookmarks.keys()) # no bookmarks have been entered if len(hwkeys) == 0: self._script.systemBeep() return # only 1 bookmark or we are just starting out elif len(hwkeys) == 1 or self._currentbookmarkindex is None: self.goToBookmark(None, index=hwkeys[0]) return # find current bookmark hw_code in our sorted list. # Go to previous one if possible try: index = hwkeys.index(self._currentbookmarkindex) self.goToBookmark(None, index=hwkeys[index-1]) except (ValueError, KeyError, IndexError): self.goToBookmark(None, index=hwkeys[0]) def _loadBookmarks(self): """ Load this scripts saved bookmarks.""" self._bookmarks = self.readBookmarksFromDisk() or {} # notify the observers for o in self._loadObservers: o() def readBookmarksFromDisk(self, filename=None): """ Read saved bookmarks from disk. Currently an unpickled object that represents a bookmark """ filename = filename or self._script.name.split(' ')[0] orcaDir = _settingsManager.getPrefsDir() if not orcaDir: return orcaBookmarksDir = os.path.join(orcaDir, "bookmarks") try: inputFile = open( os.path.join( orcaBookmarksDir, \ '%s.pkl' %filename), "r") bookmarks = pickle.load(inputFile.buffer) inputFile.close() return bookmarks except (IOError, EOFError, OSError): return None def saveBookmarksToDisk(self, bookmarksObj, filename=None): """ Write bookmarks to disk. bookmarksObj must be a pickleable object. """ filename = filename or self._script.name.split(' ')[0] orcaDir = _settingsManager.getPrefsDir() orcaBookmarksDir = os.path.join(orcaDir, "bookmarks") # create directory if it does not exist. correct place?? try: os.stat(orcaBookmarksDir) except OSError: os.mkdir(orcaBookmarksDir) output = open( os.path.join( orcaBookmarksDir, \ '%s.pkl' %filename), "w", os.O_CREAT) pickle.dump(bookmarksObj, output.buffer) output.close() def _contextToBookmark(self, context): """Converts a flat_review.Context object into a bookmark.""" context_info = {} context_info['zone'] = context.zoneIndex context_info['char'] = context.charIndex context_info['word'] = context.wordIndex context_info['line'] = context.lineIndex return context_info def _bookmarkToContext(self, bookmark): """Converts a bookmark into a flat_review.Context object.""" context = self._script.getFlatReviewContext() context.setCurrent(bookmark['line'], bookmark['zone'], \ bookmark['word'], bookmark['char']) return context def getURIKey(self): """Returns the URI key for a given page as a URI stripped of parameters?query#fragment as seen in urlparse.""" uri = self._script.utilities.documentFrameURI() if uri: parsed_uri = urllib.parse.urlparse(uri) return ''.join(parsed_uri[0:3]) else: return None def pathToObj(self, path): """Return the object with the given path (relative to the document frame). """ returnobj = self._script.utilities.documentFrame() for childnumber in path: try: returnobj = returnobj[childnumber] except IndexError: return None return returnobj def _objToPath(self, start_obj=None): """Given an object, return it's path from the root accessible. If obj is not provided, the current caret context is used. """ if not start_obj: [start_obj, characterOffset] = self._script.utilities.getCaretContext() if not start_obj: return [] if self._script.utilities.isDocument(start_obj): return [] path = [] path.append(start_obj.getIndexInParent()) p = start_obj.parent while p: if self._script.utilities.isDocument(p): path.reverse() return path path.append(p.getIndexInParent()) p = p.parent return []
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__pycache__ | Folder | 0755 |
|
|
backends | Folder | 0755 |
|
|
scripts | Folder | 0755 |
|
|
__init__.py | File | 115 B | 0644 |
|
acss.py | File | 3.49 KB | 0644 |
|
bookmarks.py | File | 8.37 KB | 0644 |
|
braille.py | File | 59.87 KB | 0644 |
|
braille_generator.py | File | 20.5 KB | 0644 |
|
braille_rolenames.py | File | 10.33 KB | 0644 |
|
brlmon.py | File | 6.45 KB | 0644 |
|
brltablenames.py | File | 7.15 KB | 0644 |
|
caret_navigation.py | File | 13.67 KB | 0644 |
|
chat.py | File | 33.63 KB | 0644 |
|
chnames.py | File | 23.03 KB | 0644 |
|
cmdnames.py | File | 55.65 KB | 0644 |
|
colornames.py | File | 38.13 KB | 0644 |
|
common_keyboardmap.py | File | 6.64 KB | 0644 |
|
debug.py | File | 17.16 KB | 0644 |
|
desktop_keyboardmap.py | File | 4.62 KB | 0644 |
|
event_manager.py | File | 31.81 KB | 0644 |
|
eventsynthesizer.py | File | 17.82 KB | 0644 |
|
find.py | File | 12.77 KB | 0644 |
|
flat_review.py | File | 51.84 KB | 0644 |
|
formatting.py | File | 53.94 KB | 0644 |
|
generator.py | File | 59.09 KB | 0644 |
|
guilabels.py | File | 45.78 KB | 0644 |
|
input_event.py | File | 36.41 KB | 0644 |
|
keybindings.py | File | 16.39 KB | 0644 |
|
keynames.py | File | 9.71 KB | 0644 |
|
label_inference.py | File | 19.38 KB | 0644 |
|
laptop_keyboardmap.py | File | 4.61 KB | 0644 |
|
liveregions.py | File | 21.55 KB | 0644 |
|
logger.py | File | 1.97 KB | 0644 |
|
mathsymbols.py | File | 88.14 KB | 0644 |
|
messages.py | File | 140.32 KB | 0644 |
|
mouse_review.py | File | 18.91 KB | 0644 |
|
notification_messages.py | File | 6.18 KB | 0644 |
|
object_properties.py | File | 32.74 KB | 0644 |
|
orca.py | File | 25 KB | 0644 |
|
orca_gtkbuilder.py | File | 5.35 KB | 0644 |
|
orca_gui_commandlist.py | File | 4.19 KB | 0644 |
|
orca_gui_find.py | File | 8.12 KB | 0644 |
|
orca_gui_navlist.py | File | 6.66 KB | 0644 |
|
orca_gui_prefs.py | File | 139.07 KB | 0644 |
|
orca_gui_profile.py | File | 4.06 KB | 0644 |
|
orca_i18n.py | File | 3.18 KB | 0644 |
|
orca_platform.py | File | 1.41 KB | 0644 |
|
orca_state.py | File | 2.1 KB | 0644 |
|
phonnames.py | File | 2.76 KB | 0644 |
|
pronunciation_dict.py | File | 2.61 KB | 0644 |
|
punctuation_settings.py | File | 13.64 KB | 0644 |
|
script.py | File | 19.04 KB | 0644 |
|
script_manager.py | File | 13.31 KB | 0644 |
|
script_utilities.py | File | 183.59 KB | 0644 |
|
settings.py | File | 12.82 KB | 0644 |
|
settings_manager.py | File | 20.73 KB | 0644 |
|
sound.py | File | 5.17 KB | 0644 |
|
sound_generator.py | File | 11.99 KB | 0644 |
|
speech.py | File | 11.4 KB | 0644 |
|
speech_generator.py | File | 108.24 KB | 0644 |
|
speechdispatcherfactory.py | File | 24.54 KB | 0644 |
|
speechserver.py | File | 7.41 KB | 0644 |
|
spellcheck.py | File | 10.07 KB | 0644 |
|
structural_navigation.py | File | 122.53 KB | 0644 |
|
text_attribute_names.py | File | 28.62 KB | 0644 |
|
tutorialgenerator.py | File | 30.41 KB | 0644 |
|