__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
# Orca
#
# Copyright 2005-2008 Sun Microsystems Inc.
# Copyright 2016-2023 Igalia, S.L.
#
# 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.
"""Module for commands related to the current accessible object."""
# This has to be the first non-docstring line in the module to make linters happy.
from __future__ import annotations
__id__ = "$Id$"
__version__ = "$Revision$"
__date__ = "$Date$"
__copyright__ = "Copyright (c) 2005-2008 Sun Microsystems Inc." \
"Copyright (c) 2016-2023 Igalia, S.L."
__license__ = "LGPL"
from typing import Optional, TYPE_CHECKING
from . import cmdnames
from . import debug
from . import focus_manager
from . import input_event
from . import keybindings
from . import messages
from . import settings_manager
from .ax_component import AXComponent
from .ax_object import AXObject
from .ax_text import AXText, AXTextAttribute
from .ax_utilities import AXUtilities
if TYPE_CHECKING:
import gi
gi.require_version("Atspi", "2.0")
from gi.repository import Atspi
from .scripts import default
class WhereAmIPresenter:
"""Module for commands related to the current accessible object."""
def __init__(self) -> None:
self._handlers: dict[str, input_event.InputEventHandler] = self.get_handlers(True)
self._desktop_bindings: keybindings.KeyBindings = keybindings.KeyBindings()
self._laptop_bindings: keybindings.KeyBindings = keybindings.KeyBindings()
def get_bindings(
self, refresh: bool = False, is_desktop: bool = True
) -> keybindings.KeyBindings:
"""Returns the where-am-i-presenter keybindings."""
if refresh:
msg = "WHERE AM I PRESENTER: Refreshing bindings."
debug.print_message(debug.LEVEL_INFO, msg, True)
self._setup_bindings()
elif is_desktop and self._desktop_bindings.is_empty():
self._setup_bindings()
elif not is_desktop and self._laptop_bindings.is_empty():
self._setup_bindings()
if is_desktop:
return self._desktop_bindings
return self._laptop_bindings
def get_handlers(self, refresh: bool = False) -> dict[str, input_event.InputEventHandler]:
"""Returns the where-am-i-presenter handlers."""
if refresh:
msg = "WHERE AM I PRESENTER: Refreshing handlers."
debug.print_message(debug.LEVEL_INFO, msg, True)
self._setup_handlers()
return self._handlers
def _setup_bindings(self) -> None:
"""Sets up the where-am-i-presenter key bindings."""
self._setup_desktop_bindings()
self._setup_laptop_bindings()
def _setup_handlers(self) -> None:
"""Sets up the where-am-i-presenter input event handlers."""
self._handlers = {}
self._handlers["readCharAttributesHandler"] = \
input_event.InputEventHandler(
self.present_character_attributes,
cmdnames.READ_CHAR_ATTRIBUTES)
self._handlers["presentSizeAndPositionHandler"] = \
input_event.InputEventHandler(
self.present_size_and_position,
cmdnames.PRESENT_SIZE_AND_POSITION)
self._handlers["getTitleHandler"] = \
input_event.InputEventHandler(
self.present_title,
cmdnames.PRESENT_TITLE)
self._handlers["getStatusBarHandler"] = \
input_event.InputEventHandler(
self.present_status_bar,
cmdnames.PRESENT_STATUS_BAR)
self._handlers["present_default_button"] = \
input_event.InputEventHandler(
self.present_default_button,
cmdnames.PRESENT_DEFAULT_BUTTON)
self._handlers["whereAmIBasicHandler"] = \
input_event.InputEventHandler(
self.where_am_i_basic,
cmdnames.WHERE_AM_I_BASIC)
self._handlers["whereAmIDetailedHandler"] = \
input_event.InputEventHandler(
self.where_am_i_detailed,
cmdnames.WHERE_AM_I_DETAILED)
self._handlers["whereAmILinkHandler"] = \
input_event.InputEventHandler(
self.present_link,
cmdnames.WHERE_AM_I_LINK)
self._handlers["whereAmISelectionHandler"] = \
input_event.InputEventHandler(
self.present_selection,
cmdnames.WHERE_AM_I_SELECTION)
msg = "WHERE AM I PRESENTER: Handlers set up."
debug.print_message(debug.LEVEL_INFO, msg, True)
def _setup_desktop_bindings(self) -> None:
"""Sets up the where-am-i-presenter desktop key bindings."""
self._desktop_bindings = keybindings.KeyBindings()
self._desktop_bindings.add(
keybindings.KeyBinding(
"f",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["readCharAttributesHandler"]))
self._desktop_bindings.add(
keybindings.KeyBinding(
"e",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["present_default_button"]))
self._desktop_bindings.add(
keybindings.KeyBinding(
"",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.NO_MODIFIER_MASK,
self._handlers["presentSizeAndPositionHandler"]))
self._desktop_bindings.add(
keybindings.KeyBinding(
"KP_Enter",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["getTitleHandler"],
1))
self._desktop_bindings.add(
keybindings.KeyBinding(
"KP_Enter",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["getStatusBarHandler"],
2))
self._desktop_bindings.add(
keybindings.KeyBinding(
"KP_Enter",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.NO_MODIFIER_MASK,
self._handlers["whereAmIBasicHandler"],
1))
self._desktop_bindings.add(
keybindings.KeyBinding(
"KP_Enter",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.NO_MODIFIER_MASK,
self._handlers["whereAmIDetailedHandler"],
2))
self._desktop_bindings.add(
keybindings.KeyBinding(
"",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.NO_MODIFIER_MASK,
self._handlers["whereAmILinkHandler"]))
self._desktop_bindings.add(
keybindings.KeyBinding(
"Up",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_SHIFT_MODIFIER_MASK,
self._handlers["whereAmISelectionHandler"]))
msg = "WHERE AM I PRESENTER: Desktop bindings set up."
debug.print_message(debug.LEVEL_INFO, msg, True)
def _setup_laptop_bindings(self) -> None:
"""Sets up the where-am-i-presenter laptop key bindings."""
self._laptop_bindings = keybindings.KeyBindings()
self._laptop_bindings.add(
keybindings.KeyBinding(
"f",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["readCharAttributesHandler"]))
self._laptop_bindings.add(
keybindings.KeyBinding(
"e",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["present_default_button"]))
self._laptop_bindings.add(
keybindings.KeyBinding(
"",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.NO_MODIFIER_MASK,
self._handlers["presentSizeAndPositionHandler"]))
self._laptop_bindings.add(
keybindings.KeyBinding(
"slash",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["getTitleHandler"],
1))
self._laptop_bindings.add(
keybindings.KeyBinding(
"slash",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["getStatusBarHandler"],
2))
self._laptop_bindings.add(
keybindings.KeyBinding(
"Return",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["whereAmIBasicHandler"],
1))
self._laptop_bindings.add(
keybindings.KeyBinding(
"Return",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_MODIFIER_MASK,
self._handlers["whereAmIDetailedHandler"],
2))
self._laptop_bindings.add(
keybindings.KeyBinding(
"",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.NO_MODIFIER_MASK,
self._handlers["whereAmILinkHandler"]))
self._laptop_bindings.add(
keybindings.KeyBinding(
"Up",
keybindings.DEFAULT_MODIFIER_MASK,
keybindings.ORCA_SHIFT_MODIFIER_MASK,
self._handlers["whereAmISelectionHandler"]))
msg = "WHERE AM I PRESENTER: Laptop bindings set up."
debug.print_message(debug.LEVEL_INFO, msg, True)
def _localize_text_attribute(self, key, value):
if value is None:
return ""
if key == "weight" and (value == "bold" or int(value) > 400):
return messages.BOLD
if key.endswith("spelling") or value == "spelling":
return messages.MISSPELLED
ax_text_attribute = AXTextAttribute.from_string(key)
localized_key = ax_text_attribute.get_localized_name()
localized_value = ax_text_attribute.get_localized_value(value)
return f"{localized_key}: {localized_value}"
def present_character_attributes(
self, script: default.Script, _event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents the font and formatting details for the current character."""
focus = focus_manager.get_manager().get_locus_of_focus()
attrs = AXText.get_text_attributes_at_offset(focus)[0]
# Get a dictionary of text attributes that the user cares about, falling back on the
# default presentable attributes if the user has not specified any.
attr_list = list(filter(None, map(
AXTextAttribute.from_string,
settings_manager.get_manager().get_setting("textAttributesToSpeak"))))
if not attr_list:
attr_list = AXText.get_all_supported_text_attributes()
for ax_text_attr in attr_list:
key = ax_text_attr.get_attribute_name()
value = attrs.get(key)
if not ax_text_attr.value_is_default(value):
script.speakMessage(self._localize_text_attribute(key, value))
return True
def present_size_and_position(
self, script: default.Script, event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents the size and position of the current object."""
if script.get_flat_review_presenter().is_active():
obj = script.get_flat_review_presenter().get_current_object(script, event)
else:
obj = focus_manager.get_manager().get_locus_of_focus()
rect = AXComponent.get_rect(obj)
if AXComponent.is_empty_rect(rect):
full = messages.LOCATION_NOT_FOUND_FULL
brief = messages.LOCATION_NOT_FOUND_BRIEF
script.presentMessage(full, brief)
return True
full = messages.SIZE_AND_POSITION_FULL % (rect.width, rect.height, rect.x, rect.y)
brief = messages.SIZE_AND_POSITION_BRIEF % (rect.width, rect.height, rect.x, rect.y)
script.presentMessage(full, brief)
return True
def present_title(
self, script: default.Script, _event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents the title of the current window."""
obj = focus_manager.get_manager().get_locus_of_focus()
if AXObject.is_dead(obj):
obj = focus_manager.get_manager().get_active_window()
if obj is None or AXObject.is_dead(obj):
script.presentMessage(messages.LOCATION_NOT_FOUND_FULL)
return True
title = script.speech_generator.generate_window_title(obj)
for (string, voice) in title:
script.presentMessage(string, voice=voice)
return True
def _present_default_button(
self,
script: default.Script,
_event: Optional[input_event.InputEvent] = None,
dialog: Optional[Atspi.Accessible] = None,
error_messages: bool = True
) -> bool:
"""Presents the default button of the current dialog."""
obj = focus_manager.get_manager().get_locus_of_focus()
if dialog is None:
_frame, dialog = script.utilities.frameAndDialog(obj)
if dialog is None:
if error_messages:
script.presentMessage(messages.DIALOG_NOT_IN_A)
return True
button = AXUtilities.get_default_button(dialog)
if button is None:
if error_messages:
script.presentMessage(messages.DEFAULT_BUTTON_NOT_FOUND)
return True
name = AXObject.get_name(button)
if not AXUtilities.is_sensitive(button):
script.presentMessage(messages.DEFAULT_BUTTON_IS_GRAYED % name)
return True
script.presentMessage(messages.DEFAULT_BUTTON_IS % name)
return True
def present_status_bar(
self, script: default.Script, event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents the status bar of the current window."""
obj = focus_manager.get_manager().get_locus_of_focus()
frame, dialog = script.utilities.frameAndDialog(obj)
if frame:
statusbar = AXUtilities.get_status_bar(frame)
if statusbar:
script.presentObject(statusbar, interrupt=True)
else:
full = messages.STATUS_BAR_NOT_FOUND_FULL
brief = messages.STATUS_BAR_NOT_FOUND_BRIEF
script.presentMessage(full, brief)
infobar = script.utilities.infoBar(frame)
if infobar:
script.presentObject(infobar, interrupt=statusbar is None)
# TODO - JD: Pending user feedback, this should be removed.
if dialog:
self._present_default_button(script, event, dialog, False)
return True
def present_default_button(
self, script: default.Script, event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents the default button of the current window."""
return self._present_default_button(script, event)
def present_link(
self,
script: default.Script,
event: Optional[input_event.InputEvent] = None,
link: Optional[Atspi.Accessible] = None
) -> bool:
"""Presents details about the current link."""
link = link or focus_manager.get_manager().get_locus_of_focus()
if not script.utilities.isLink(link):
script.presentMessage(messages.NOT_ON_A_LINK)
return True
return self._do_where_am_i(script, event, True, link)
def _get_all_selected_text(self, script: default.Script, obj: Atspi.Accessible) -> str:
"""Returns the selected text of obj plus any adjacent text objects."""
string = AXText.get_selected_text(obj)[0]
if script.utilities.isSpreadSheetCell(obj):
return string
prev_obj = script.utilities.findPreviousObject(obj)
while prev_obj:
selection = AXText.get_selected_text(prev_obj)[0]
if not selection:
break
string = f"{selection} {string}"
prev_obj = script.utilities.findPreviousObject(prev_obj)
next_obj = script.utilities.findNextObject(obj)
while next_obj:
selection = AXText.get_selected_text(next_obj)[0]
if not selection:
break
string = f"{string} {selection}"
next_obj = script.utilities.findNextObject(next_obj)
return string
def present_selected_text(
self,
script: default.Script,
_event: Optional[input_event.InputEvent] = None,
obj: Optional[Atspi.Accessible] = None
) -> bool:
"""Presents the selected text."""
obj = obj or focus_manager.get_manager().get_locus_of_focus()
if obj is None:
script.speakMessage(messages.LOCATION_NOT_FOUND_FULL)
return True
text = self._get_all_selected_text(script, obj)
if not text:
script.speakMessage(messages.NO_SELECTED_TEXT)
return True
if script.utilities.shouldVerbalizeAllPunctuation(obj):
text = script.utilities.verbalizeAllPunctuation(text)
msg = messages.SELECTED_TEXT_IS % text
script.speakMessage(msg)
return True
def present_selection(
self,
script: default.Script,
event: Optional[input_event.InputEvent] = None,
obj: Optional[Atspi.Accessible] = None
) -> bool:
"""Presents the selected text or selected objects."""
obj = obj or focus_manager.get_manager().get_locus_of_focus()
if obj is None:
script.speakMessage(messages.LOCATION_NOT_FOUND_FULL)
return True
tokens = ["WHERE AM I PRESENTER: presenting selection for", obj]
debug.print_tokens(debug.LEVEL_INFO, tokens, True)
spreadsheet = AXObject.find_ancestor(obj, script.utilities.isSpreadSheetTable)
if spreadsheet is not None and script.utilities.speakSelectedCellRange(spreadsheet):
return True
container = script.utilities.getSelectionContainer(obj)
if container is None:
tokens = ["WHERE AM I PRESENTER: Selection container not found for", obj]
debug.print_tokens(debug.LEVEL_INFO, tokens, True)
return self.present_selected_text(script, event, obj)
selected_count = script.utilities.selectedChildCount(container)
child_count = script.utilities.selectableChildCount(container)
script.presentMessage(messages.selectedItemsCount(selected_count, child_count))
if not selected_count:
return True
selected_items = script.utilities.selectedChildren(container)
item_names = ",".join(map(AXObject.get_name, selected_items))
script.speakMessage(item_names)
return True
def _do_where_am_i(
self,
script: default.Script,
_event: Optional[input_event.InputEvent] = None,
basic_only: bool = True,
obj: Optional[Atspi.Accessible] = None
) -> bool:
"""Presents details about the current location at the specified level."""
if script.spellcheck and script.spellcheck.is_active():
script.spellcheck.present_error_details(not basic_only)
if obj is None:
obj = focus_manager.get_manager().get_locus_of_focus()
if AXObject.is_dead(obj):
obj = focus_manager.get_manager().get_active_window()
if obj is None or AXObject.is_dead(obj):
script.presentMessage(messages.LOCATION_NOT_FOUND_FULL)
return True
if basic_only:
format_type = 'basicWhereAmI'
else:
format_type = 'detailedWhereAmI'
script.presentObject(
script.utilities.realActiveAncestor(obj),
alreadyFocused=True,
formatType=format_type,
forceMnemonic=True,
forceList=True,
forceTutorial=True,
speechOnly=True)
return True
def where_am_i_basic(
self, script: default.Script, event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents basic information about the current location."""
return self._do_where_am_i(script, event)
def where_am_i_detailed(
self, script: default.Script, event: Optional[input_event.InputEvent] = None
) -> bool:
"""Presents detailed information about the current location."""
# TODO - JD: For some reason, we are starting the basic where am I
# in response to the first click. Then we do the detailed one in
# response to the second click. Until that's fixed, interrupt the
# first one.
script.presentationInterrupt()
return self._do_where_am_i(script, event, False)
_presenter = WhereAmIPresenter()
def get_presenter() -> WhereAmIPresenter:
"""Returns the Where Am I Presenter"""
return _presenter
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| backends | Folder | 0755 |
|
|
| scripts | Folder | 0755 |
|
|
| __init__.py | File | 115 B | 0644 |
|
| acss.py | File | 3.85 KB | 0644 |
|
| action_presenter.py | File | 8.65 KB | 0644 |
|
| ax_collection.py | File | 6.16 KB | 0644 |
|
| ax_component.py | File | 14.93 KB | 0644 |
|
| ax_document.py | File | 9.36 KB | 0644 |
|
| ax_event_synthesizer.py | File | 17.39 KB | 0644 |
|
| ax_hypertext.py | File | 8.36 KB | 0644 |
|
| ax_object.py | File | 47.84 KB | 0644 |
|
| ax_selection.py | File | 4.54 KB | 0644 |
|
| ax_table.py | File | 47.98 KB | 0644 |
|
| ax_text.py | File | 45.13 KB | 0644 |
|
| ax_utilities.py | File | 28.24 KB | 0644 |
|
| ax_utilities_application.py | File | 7.17 KB | 0644 |
|
| ax_utilities_collection.py | File | 86.79 KB | 0644 |
|
| ax_utilities_debugging.py | File | 10.12 KB | 0644 |
|
| ax_utilities_event.py | File | 32.78 KB | 0644 |
|
| ax_utilities_relation.py | File | 15.2 KB | 0644 |
|
| ax_utilities_role.py | File | 91.79 KB | 0644 |
|
| ax_utilities_state.py | File | 11.63 KB | 0644 |
|
| ax_value.py | File | 6.83 KB | 0644 |
|
| bookmarks.py | File | 11.95 KB | 0644 |
|
| braille.py | File | 74.03 KB | 0644 |
|
| braille_generator.py | File | 55.79 KB | 0644 |
|
| braille_rolenames.py | File | 10.23 KB | 0644 |
|
| brlmon.py | File | 6.53 KB | 0644 |
|
| brltablenames.py | File | 7.3 KB | 0644 |
|
| bypass_mode_manager.py | File | 4.79 KB | 0644 |
|
| caret_navigation.py | File | 19.51 KB | 0644 |
|
| chat.py | File | 32.03 KB | 0644 |
|
| clipboard.py | File | 20.45 KB | 0644 |
|
| cmdnames.py | File | 61.77 KB | 0644 |
|
| colornames.py | File | 39.22 KB | 0644 |
|
| debug.py | File | 3.95 KB | 0644 |
|
| debugging_tools_manager.py | File | 10.69 KB | 0644 |
|
| event_manager.py | File | 36.07 KB | 0644 |
|
| flat_review.py | File | 48.89 KB | 0644 |
|
| flat_review_finder.py | File | 20.2 KB | 0644 |
|
| flat_review_presenter.py | File | 45.94 KB | 0644 |
|
| focus_manager.py | File | 11.52 KB | 0644 |
|
| generator.py | File | 67.07 KB | 0644 |
|
| guilabels.py | File | 56.38 KB | 0644 |
|
| highlighter.py | File | 6.95 KB | 0644 |
|
| input_event.py | File | 30.05 KB | 0644 |
|
| input_event_manager.py | File | 35.66 KB | 0644 |
|
| keybindings.py | File | 24.87 KB | 0644 |
|
| keynames.py | File | 9.55 KB | 0644 |
|
| label_inference.py | File | 19.77 KB | 0644 |
|
| learn_mode_presenter.py | File | 14.72 KB | 0644 |
|
| liveregions.py | File | 25.77 KB | 0644 |
|
| mathsymbols.py | File | 88.65 KB | 0644 |
|
| messages.py | File | 152.28 KB | 0644 |
|
| mouse_review.py | File | 23.34 KB | 0644 |
|
| notification_presenter.py | File | 14.17 KB | 0644 |
|
| object_navigator.py | File | 13.24 KB | 0644 |
|
| object_properties.py | File | 33.86 KB | 0644 |
|
| orca.py | File | 9.83 KB | 0644 |
|
| orca_gtkbuilder.py | File | 5.42 KB | 0644 |
|
| orca_gui_navlist.py | File | 6.51 KB | 0644 |
|
| orca_gui_prefs.py | File | 141.9 KB | 0644 |
|
| orca_gui_profile.py | File | 3.98 KB | 0644 |
|
| orca_i18n.py | File | 3.13 KB | 0644 |
|
| orca_modifier_manager.py | File | 13.76 KB | 0644 |
|
| orca_platform.py | File | 1.43 KB | 0644 |
|
| phonnames.py | File | 2.76 KB | 0644 |
|
| pronunciation_dict.py | File | 2.55 KB | 0644 |
|
| script.py | File | 11.11 KB | 0644 |
|
| script_manager.py | File | 14.68 KB | 0644 |
|
| script_utilities.py | File | 64.21 KB | 0644 |
|
| settings.py | File | 10.66 KB | 0644 |
|
| settings_manager.py | File | 27.13 KB | 0644 |
|
| sleep_mode_manager.py | File | 5.04 KB | 0644 |
|
| sound.py | File | 5.51 KB | 0644 |
|
| sound_generator.py | File | 48.88 KB | 0644 |
|
| speech.py | File | 8.87 KB | 0644 |
|
| speech_and_verbosity_manager.py | File | 27.71 KB | 0644 |
|
| speech_generator.py | File | 163.53 KB | 0644 |
|
| speechdispatcherfactory.py | File | 24.68 KB | 0644 |
|
| speechserver.py | File | 8 KB | 0644 |
|
| spellcheck.py | File | 18.11 KB | 0644 |
|
| spiel.py | File | 25.59 KB | 0644 |
|
| ssml.py | File | 6.71 KB | 0644 |
|
| structural_navigation.py | File | 77.63 KB | 0644 |
|
| system_information_presenter.py | File | 7.44 KB | 0644 |
|
| table_navigator.py | File | 29.78 KB | 0644 |
|
| text_attribute_names.py | File | 27.31 KB | 0644 |
|
| where_am_i_presenter.py | File | 21.59 KB | 0644 |
|