# -*- coding: utf-8 -*- # Copyright © 2005 Lateef Alabi-Oki # # This file is part of Scribes. # # Scribes is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # Scribes 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 General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Scribes; if not, write to the Free Software # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 # USA """ This module documents a class that creates a triggers to perform case changing manipulations. @author: Lateef Alabi-Oki @organization: The Scribes Project @copyright: Copyright © 2005 Lateef Alabi-Oki @license: GNU GPLv2 or Later @contact: mystilleef@gmail.com """ from gobject import GObject, SIGNAL_RUN_LAST, TYPE_NONE class CaseTrigger(GObject): """ This class implements triggers to perform case changing manipulations. """ __gsignals__ = { "destroy": (SIGNAL_RUN_LAST, TYPE_NONE, ()), } def __init__(self, editor): """ Initialize the trigger. @param self: Reference to the CaseTrigger instance. @type self: An CaseTrigger object. @param editor: Reference to the text editor. @type editor: An Editor object. """ GObject.__init__(self) self.__init_attributes(editor) self.__create_triggers() self.__signal_id_1 = self.__uppercase_trigger.connect("activate", self.__uppercase_trigger_cb) self.__signal_id_2 = self.__lowercase_trigger.connect("activate", self.__lowercase_trigger_cb) self.__signal_id_3 = self.__titlecase_trigger.connect("activate", self.__titlecase_trigger_cb) self.__signal_id_4 = self.__swapcase_trigger.connect("activate", self.__swapcase_trigger_cb) self.__signal_id_5 = self.connect("destroy", self.__destroy_cb) self.__signal_id_6 = self.__editor.textview.connect_after("populate-popup", self.__popup_cb) def __init_attributes(self, editor): """ Initialize the trigger's attributes. @param self: Reference to the CaseTrigger instance. @type self: A CaseTrigger object. @param editor: Reference to the text editor. @type editor: An Editor object. """ self.__editor = editor self.__case_processor = None self.__uppercase_trigger = None self.__lowercase_trigger = None self.__titlecase_trigger = None self.__swapcase_trigger = None self.__signal_id_1 = None self.__signal_id_2 = None self.__signal_id_3 = None self.__signal_id_4 = None self.__signal_id_5 = None self.__signal_id_6 = None return def __create_triggers(self): """ Create the trigger. @param self: Reference to the CaseTrigger instance. @type self: A CaseTrigger object. """ from SCRIBES.trigger import Trigger # Trigger to convert selected text to uppercase. self.__uppercase_trigger = Trigger("uppercase") self.__editor.triggermanager.add_trigger(self.__uppercase_trigger, "alt - u") # Trigger to convert selected text to lowercase. self.__lowercase_trigger = Trigger("lowercase") self.__editor.triggermanager.add_trigger(self.__lowercase_trigger) # Trigger to title the case of selected text. self.__titlecase_trigger = Trigger("titlecase") self.__editor.triggermanager.add_trigger(self.__titlecase_trigger, "alt - U") # Trigger to swap the case of selected text. self.__swapcase_trigger = Trigger("swapcase") self.__editor.triggermanager.add_trigger(self.__swapcase_trigger, "alt - L") return def __uppercase_trigger_cb(self, trigger): """ Handles callback when the "activate" signal is emitted. @param self: Reference to the CaseTrigger instance. @type self: A CaseTrigger object. @param trigger: An object to show the document browser. @type trigger: A Trigger object. """ try: self.__case_processor.upper() except AttributeError: from case import CaseProcessor self.__case_processor = CaseProcessor(self.__editor) self.__case_processor.upper() return def __lowercase_trigger_cb(self, trigger): """ Handles callback when the "activate" signal is emitted. @param self: Reference to the CaseTrigger instance. @type self: A CaseTrigger object. @param trigger: An object to show the document browser. @type trigger: A Trigger object. """ try: self.__case_processor.lower() except AttributeError: from case import CaseProcessor self.__case_processor = CaseProcessor(self.__editor) self.__case_processor.lower() return def __titlecase_trigger_cb(self, trigger): """ Handles callback when the "activate" signal is emitted. @param self: Reference to the CaseTrigger instance. @type self: A CaseTrigger object. @param trigger: An object to show the document browser. @type trigger: A Trigger object. """ try: self.__case_processor.title() except AttributeError: from case import CaseProcessor self.__case_processor = CaseProcessor(self.__editor) self.__case_processor.title() return def __swapcase_trigger_cb(self, trigger): """ Handles callback when the "activate" signal is emitted. @param self: Reference to the CaseTrigger instance. @type self: A CaseTrigger object. @param trigger: An object to show the document browser. @type trigger: A Trigger object. """ try: self.__case_processor.swapcase() except AttributeError: from case import CaseProcessor self.__case_processor = CaseProcessor(self.__editor) self.__case_processor.swapcase() return def __destroy_cb(self, trigger): """ Handles callback when the "activate" signal is emitted. @param self: Reference to the CaseTrigger instance. @type self: An CaseTrigger object. @param trigger: Reference to the FullScreenTrigger instance. @type trigger: A FullScreenTrigger object. """ remove_triggers = self.__editor.triggermanager.remove_triggers remove_triggers([self.__uppercase_trigger, self.__lowercase_trigger, self.__titlecase_trigger, self.__swapcase_trigger]) if self.__case_processor: self.__case_processor.emit("destroy") if self.__signal_id_1 and self.__uppercase_trigger.handler_is_connected(self.__signal_id_1): self.__uppercase_trigger.disconnect(self.__signal_id_1) if self.__signal_id_2 and self.__lowercase_trigger.handler_is_connected(self.__signal_id_2): self.__lowercase_trigger.disconnect(self.__signal_id_2) if self.__signal_id_3 and self.__titlecase_trigger.handler_is_connected(self.__signal_id_3): self.__titlecase_trigger.disconnect(self.__signal_id_3) if self.__signal_id_4 and self.__swapcase_trigger.handler_is_connected(self.__signal_id_4): self.__swapcase_trigger.disconnect(self.__signal_id_4) if self.__signal_id_5 and self.handler_is_connected(self.__signal_id_5): self.disconnect(self.__signal_id_5) if self.__signal_id_6 and self.__editor.textview.handler_is_connected(self.__signal_id_6): self.__editor.textview.disconnect(self.__signal_id_6) from SCRIBES.utils import delete_attributes delete_attributes(self) del self self = None return def __popup_cb(self, textview, menu): """ Handles callback when the "populate-popup" signal is emitted. @param self: Reference to the SelectionTrigger instance. @type self: An SelectionTrigger object. @param textview: Reference to the editor's textview. @type textview: A ScribesTextView object. @param menu: Reference to the editor's popup menu. @type menu: A gtk.Menu object. """ from PopupMenuItem import CasePopupMenuItem menu.prepend(CasePopupMenuItem(self.__editor)) menu.show_all() return False