mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 03:44:55 +00:00 
			
		
		
		
	set_colordb(): Call Viewers' colordb_changed() method if they have them. Notifies them of changes to the color name database.
		
			
				
	
	
		
			138 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
"""Switchboard class.
 | 
						|
 | 
						|
This class is used to coordinate updates among all Viewers.  Every Viewer must
 | 
						|
conform to the following interface:
 | 
						|
 | 
						|
    - it must include a method called update_yourself() which takes three
 | 
						|
      arguments; the red, green, and blue values of the selected color.
 | 
						|
 | 
						|
    - When a Viewer selects a color and wishes to update all other Views, it
 | 
						|
      should call update_views() on the Switchboard object.  Not that the
 | 
						|
      Viewer typically does *not* update itself before calling update_views(), 
 | 
						|
      since this would cause it to get updated twice.
 | 
						|
 | 
						|
Optionally, Viewers can also implement:
 | 
						|
 | 
						|
    - save_options() which takes an optiondb (a dictionary).  Store into this
 | 
						|
      dictionary any values the Viewer wants to save in the persistent
 | 
						|
      ~/.pynche file.  This dictionary is saved using marshal.  The namespace
 | 
						|
      for the keys is ad-hoc; make sure you don't clobber some other Viewer's
 | 
						|
      keys!
 | 
						|
 | 
						|
    - withdraw() which takes no arguments.  This is called when Pynche is
 | 
						|
      unmapped.  All Viewers should implement this.
 | 
						|
 | 
						|
    - colordb_changed() which takes a single argument, an instance of
 | 
						|
      ColorDB.  This is called whenever the color name database is changed and 
 | 
						|
      gives a chance for the Viewers to do something on those events.  See
 | 
						|
      ListViewer for details.
 | 
						|
 | 
						|
External Viewers are found dynamically.  Viewer modules should have names such 
 | 
						|
as FooViewer.py.  If such a named module has a module global variable called
 | 
						|
ADDTOVIEW and this variable is true, the Viewer will be added dynamically to
 | 
						|
the `View' menu.  ADDTOVIEW contains a string which is used as the menu item
 | 
						|
to display the Viewer (one kludge: if the string contains a `%', this is used
 | 
						|
to indicate that the next character will get an underline in the menu,
 | 
						|
otherwise the first character is underlined).
 | 
						|
 | 
						|
FooViewer.py should contain a class called FooViewer, and its constructor
 | 
						|
should take two arguments, an instance of Switchboard, and optionally a Tk
 | 
						|
master window.
 | 
						|
 | 
						|
"""
 | 
						|
 | 
						|
import sys
 | 
						|
from types import DictType
 | 
						|
import marshal
 | 
						|
 | 
						|
class Switchboard:
 | 
						|
    def __init__(self, initfile):
 | 
						|
        self.__initfile = initfile
 | 
						|
        self.__colordb = None
 | 
						|
        self.__optiondb = {}
 | 
						|
        self.__views = []
 | 
						|
        self.__red = 0
 | 
						|
        self.__green = 0
 | 
						|
        self.__blue = 0
 | 
						|
        self.__canceled = 0
 | 
						|
        # read the initialization file
 | 
						|
        fp = None
 | 
						|
        if initfile:
 | 
						|
            try:
 | 
						|
                try:
 | 
						|
                    fp = open(initfile)
 | 
						|
                    self.__optiondb = marshal.load(fp)
 | 
						|
                    if type(self.__optiondb) <> DictType:
 | 
						|
                        sys.stderr.write(
 | 
						|
                            'Problem reading options from file: %s\n' %
 | 
						|
                            initfile)
 | 
						|
                        self.__optiondb = {}
 | 
						|
                except (IOError, EOFError):
 | 
						|
                    pass
 | 
						|
            finally:
 | 
						|
                if fp:
 | 
						|
                    fp.close()
 | 
						|
 | 
						|
    def add_view(self, view):
 | 
						|
        self.__views.append(view)
 | 
						|
 | 
						|
    def update_views(self, red, green, blue):
 | 
						|
        self.__red = red
 | 
						|
        self.__green = green
 | 
						|
        self.__blue = blue
 | 
						|
        for v in self.__views:
 | 
						|
            v.update_yourself(red, green, blue)
 | 
						|
 | 
						|
    def update_views_current(self):
 | 
						|
        self.update_views(self.__red, self.__green, self.__blue)
 | 
						|
 | 
						|
    def current_rgb(self):
 | 
						|
        return self.__red, self.__green, self.__blue
 | 
						|
 | 
						|
    def colordb(self):
 | 
						|
        return self.__colordb
 | 
						|
 | 
						|
    def set_colordb(self, colordb):
 | 
						|
        self.__colordb = colordb
 | 
						|
        for v in self.__views:
 | 
						|
            if hasattr(v, 'colordb_changed'):
 | 
						|
                v.colordb_changed(colordb)
 | 
						|
        self.update_views_current()
 | 
						|
 | 
						|
    def optiondb(self):
 | 
						|
        return self.__optiondb
 | 
						|
 | 
						|
    def save_views(self):
 | 
						|
        # save the current color
 | 
						|
        self.__optiondb['RED'] = self.__red
 | 
						|
        self.__optiondb['GREEN'] = self.__green
 | 
						|
        self.__optiondb['BLUE'] = self.__blue
 | 
						|
        for v in self.__views:
 | 
						|
            if hasattr(v, 'save_options'):
 | 
						|
                v.save_options(self.__optiondb)
 | 
						|
        # save the name of the file used for the color database.  we'll try to
 | 
						|
        # load this first.
 | 
						|
        self.__optiondb['DBFILE'] = self.__colordb.filename()
 | 
						|
        fp = None
 | 
						|
        try:
 | 
						|
            try:
 | 
						|
                fp = open(self.__initfile, 'w')
 | 
						|
            except IOError:
 | 
						|
                sys.stderr.write('Cannot write options to file: %s\n' %
 | 
						|
                                 self.__initfile)
 | 
						|
            else:
 | 
						|
                marshal.dump(self.__optiondb, fp)
 | 
						|
        finally:
 | 
						|
            if fp:
 | 
						|
                fp.close()
 | 
						|
 | 
						|
    def withdraw_views(self):
 | 
						|
        for v in self.__views:
 | 
						|
            if hasattr(v, 'withdraw'):
 | 
						|
                v.withdraw()
 | 
						|
 | 
						|
    def canceled(self, flag=1):
 | 
						|
        self.__canceled = flag
 | 
						|
 | 
						|
    def canceled_p(self):
 | 
						|
        return self.__canceled
 |