| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  | """Pynche -- The PYthon Natural Color and Hue Editor.
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  | Contact: %(AUTHNAME)s | 
					
						
							|  |  |  |  | Email:   %(AUTHEMAIL)s | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  | Version: %(__version__)s | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | Pynche is based largely on a similar color editor I wrote years ago for the | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  | SunView window system.  That editor was called ICE: the Interactive Color | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  | Editor.  I'd always wanted to port the editor to X but didn't feel like | 
					
						
							|  |  |  |  | hacking X and C code to do it.  Fast forward many years, to where Python + | 
					
						
							| 
									
										
										
										
											1998-09-28 16:28:04 +00:00
										 |  |  |  | Tkinter provides such a nice programming environment, with enough power, that | 
					
						
							|  |  |  |  | I finally buckled down and implemented it.  I changed the name because these | 
					
						
							|  |  |  |  | days, too many other systems have the acronym `ICE'. | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  | This program currently requires Python 2.2 with Tkinter. | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  | Usage: %(PROGRAM)s [-d file] [-i file] [-X] [-v] [-h] [initialcolor] | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | Where: | 
					
						
							| 
									
										
										
										
											1998-09-28 16:28:04 +00:00
										 |  |  |  |     --database file | 
					
						
							|  |  |  |  |     -d file | 
					
						
							|  |  |  |  |         Alternate location of a color database file | 
					
						
							| 
									
										
										
										
											1998-02-11 18:56:13 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-10-20 20:45:46 +00:00
										 |  |  |  |     --initfile file | 
					
						
							|  |  |  |  |     -i file | 
					
						
							|  |  |  |  |         Alternate location of the initialization file.  This file contains a | 
					
						
							|  |  |  |  |         persistent database of the current Pynche options and color.  This | 
					
						
							|  |  |  |  |         means that Pynche restores its option settings and current color when | 
					
						
							|  |  |  |  |         it restarts, using this file (unless the -X option is used).  The | 
					
						
							|  |  |  |  |         default is ~/.pynche | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     --ignore | 
					
						
							|  |  |  |  |     -X | 
					
						
							|  |  |  |  |         Ignore the initialization file when starting up.  Pynche will still | 
					
						
							|  |  |  |  |         write the current option settings to this file when it quits. | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  |     --version | 
					
						
							|  |  |  |  |     -v | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         print the version number and exit | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  |     --help | 
					
						
							|  |  |  |  |     -h | 
					
						
							|  |  |  |  |         print this message | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-09-28 16:28:04 +00:00
										 |  |  |  |     initialcolor | 
					
						
							|  |  |  |  |         initial color, as a color name or #RRGGBB format | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  | """
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-03 03:15:50 +00:00
										 |  |  |  | __version__ = '1.4.1' | 
					
						
							| 
									
										
										
										
											1998-01-27 03:19:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | import sys | 
					
						
							| 
									
										
										
										
											1998-10-06 20:44:14 +00:00
										 |  |  |  | import os | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | import getopt | 
					
						
							|  |  |  |  | import ColorDB | 
					
						
							| 
									
										
										
										
											2001-07-10 21:42:04 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | from PyncheWidget import PyncheWidget | 
					
						
							| 
									
										
										
										
											1998-09-28 16:28:04 +00:00
										 |  |  |  | from Switchboard import Switchboard | 
					
						
							| 
									
										
										
										
											1998-09-28 23:41:53 +00:00
										 |  |  |  | from StripViewer import StripViewer | 
					
						
							| 
									
										
										
										
											1998-10-01 16:47:06 +00:00
										 |  |  |  | from ChipViewer import ChipViewer | 
					
						
							|  |  |  |  | from TypeinViewer import TypeinViewer | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |  | 
					
						
							|  |  |  |  | PROGRAM = sys.argv[0] | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  | AUTHNAME = 'Barry Warsaw' | 
					
						
							|  |  |  |  | AUTHEMAIL = 'barry@python.org' | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | # Default locations of rgb.txt or other textual color database | 
					
						
							|  |  |  |  | RGB_TXT = [ | 
					
						
							|  |  |  |  |     # Solaris OpenWindows | 
					
						
							|  |  |  |  |     '/usr/openwin/lib/rgb.txt', | 
					
						
							| 
									
										
										
										
											1999-04-23 16:24:00 +00:00
										 |  |  |  |     # Linux | 
					
						
							|  |  |  |  |     '/usr/lib/X11/rgb.txt', | 
					
						
							| 
									
										
										
										
											1998-10-06 20:44:14 +00:00
										 |  |  |  |     # The X11R6.4 rgb.txt file | 
					
						
							| 
									
										
										
										
											1998-10-20 20:45:46 +00:00
										 |  |  |  |     os.path.join(sys.path[0], 'X/rgb.txt'), | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  |     # add more here | 
					
						
							|  |  |  |  |     ] | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |  | 
					
						
							| 
									
										
										
										
											2001-07-10 21:42:04 +00:00
										 |  |  |  | # Do this because PyncheWidget.py wants to get at the interpolated docstring | 
					
						
							|  |  |  |  | # too, for its Help menu. | 
					
						
							| 
									
										
										
										
											1998-12-03 19:49:13 +00:00
										 |  |  |  | def docstring(): | 
					
						
							| 
									
										
										
										
											2001-07-10 21:42:04 +00:00
										 |  |  |  |     return __doc__ % globals() | 
					
						
							| 
									
										
										
										
											1998-12-03 19:49:13 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-10 21:42:04 +00:00
										 |  |  |  | def usage(code, msg=''): | 
					
						
							| 
									
										
										
										
											2007-08-03 17:06:41 +00:00
										 |  |  |  |     print(docstring()) | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  |     if msg: | 
					
						
							| 
									
										
										
										
											2007-08-03 17:06:41 +00:00
										 |  |  |  |         print(msg) | 
					
						
							| 
									
										
										
										
											2001-07-10 21:42:04 +00:00
										 |  |  |  |     sys.exit(code) | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-10-06 19:50:33 +00:00
										 |  |  |  |  | 
					
						
							|  |  |  |  | def initial_color(s, colordb): | 
					
						
							|  |  |  |  |     # function called on every color | 
					
						
							|  |  |  |  |     def scan_color(s, colordb=colordb): | 
					
						
							|  |  |  |  |         try: | 
					
						
							|  |  |  |  |             r, g, b = colordb.find_byname(s) | 
					
						
							|  |  |  |  |         except ColorDB.BadColor: | 
					
						
							|  |  |  |  |             try: | 
					
						
							|  |  |  |  |                 r, g, b = ColorDB.rrggbb_to_triplet(s) | 
					
						
							|  |  |  |  |             except ColorDB.BadColor: | 
					
						
							|  |  |  |  |                 return None, None, None | 
					
						
							|  |  |  |  |         return r, g, b | 
					
						
							|  |  |  |  |     # | 
					
						
							|  |  |  |  |     # First try the passed in color | 
					
						
							|  |  |  |  |     r, g, b = scan_color(s) | 
					
						
							|  |  |  |  |     if r is None: | 
					
						
							|  |  |  |  |         # try the same color with '#' prepended, since some shells require | 
					
						
							|  |  |  |  |         # this to be escaped, which is a pain | 
					
						
							|  |  |  |  |         r, g, b = scan_color('#' + s) | 
					
						
							|  |  |  |  |     if r is None: | 
					
						
							| 
									
										
										
										
											2007-08-03 17:06:41 +00:00
										 |  |  |  |         print('Bad initial color, using gray50:', s) | 
					
						
							| 
									
										
										
										
											1998-10-06 19:50:33 +00:00
										 |  |  |  |         r, g, b = scan_color('gray50') | 
					
						
							|  |  |  |  |     if r is None: | 
					
						
							|  |  |  |  |         usage(1, 'Cannot find an initial color to use') | 
					
						
							|  |  |  |  |         # does not return | 
					
						
							|  |  |  |  |     return r, g, b | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  |  | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  | def build(master=None, initialcolor=None, initfile=None, ignore=None, | 
					
						
							|  |  |  |  |           dbfile=None): | 
					
						
							| 
									
										
										
										
											1998-09-28 23:41:53 +00:00
										 |  |  |  |     # create all output widgets | 
					
						
							| 
									
										
										
										
											1999-04-26 23:17:16 +00:00
										 |  |  |  |     s = Switchboard(not ignore and initfile) | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |     # defer to the command line chosen color database, falling back to the one | 
					
						
							|  |  |  |  |     # in the .pynche file. | 
					
						
							|  |  |  |  |     if dbfile is None: | 
					
						
							| 
									
										
										
										
											2003-09-03 03:15:50 +00:00
										 |  |  |  |         dbfile = s.optiondb().get('DBFILE') | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |     # find a parseable color database | 
					
						
							|  |  |  |  |     colordb = None | 
					
						
							|  |  |  |  |     files = RGB_TXT[:] | 
					
						
							| 
									
										
										
										
											2003-09-03 03:15:50 +00:00
										 |  |  |  |     if dbfile is None: | 
					
						
							|  |  |  |  |         dbfile = files.pop() | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |     while colordb is None: | 
					
						
							|  |  |  |  |         try: | 
					
						
							|  |  |  |  |             colordb = ColorDB.get_colordb(dbfile) | 
					
						
							|  |  |  |  |         except (KeyError, IOError): | 
					
						
							|  |  |  |  |             pass | 
					
						
							|  |  |  |  |         if colordb is None: | 
					
						
							|  |  |  |  |             if not files: | 
					
						
							|  |  |  |  |                 break | 
					
						
							|  |  |  |  |             dbfile = files.pop(0) | 
					
						
							| 
									
										
										
										
											1999-04-26 23:17:16 +00:00
										 |  |  |  |     if not colordb: | 
					
						
							|  |  |  |  |         usage(1, 'No color database file found, see the -d option.') | 
					
						
							|  |  |  |  |     s.set_colordb(colordb) | 
					
						
							| 
									
										
										
										
											1998-10-01 16:47:06 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     # create the application window decorations | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |     app = PyncheWidget(__version__, s, master=master) | 
					
						
							|  |  |  |  |     w = app.window() | 
					
						
							| 
									
										
										
										
											1998-10-01 16:47:06 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-04-27 18:43:47 +00:00
										 |  |  |  |     # these built-in viewers live inside the main Pynche window | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |     s.add_view(StripViewer(s, w)) | 
					
						
							|  |  |  |  |     s.add_view(ChipViewer(s, w)) | 
					
						
							|  |  |  |  |     s.add_view(TypeinViewer(s, w)) | 
					
						
							| 
									
										
										
										
											1998-10-20 20:45:46 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     # get the initial color as components and set the color on all views.  if | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |     # there was no initial color given on the command line, use the one that's | 
					
						
							| 
									
										
										
										
											1998-10-20 20:45:46 +00:00
										 |  |  |  |     # stored in the option database | 
					
						
							|  |  |  |  |     if initialcolor is None: | 
					
						
							|  |  |  |  |         optiondb = s.optiondb() | 
					
						
							|  |  |  |  |         red = optiondb.get('RED') | 
					
						
							|  |  |  |  |         green = optiondb.get('GREEN') | 
					
						
							|  |  |  |  |         blue = optiondb.get('BLUE') | 
					
						
							|  |  |  |  |         # but if there wasn't any stored in the database, use grey50 | 
					
						
							|  |  |  |  |         if red is None or blue is None or green is None: | 
					
						
							|  |  |  |  |             red, green, blue = initial_color('grey50', colordb) | 
					
						
							|  |  |  |  |     else: | 
					
						
							|  |  |  |  |         red, green, blue = initial_color(initialcolor, colordb) | 
					
						
							| 
									
										
										
										
											1998-09-28 23:41:53 +00:00
										 |  |  |  |     s.update_views(red, green, blue) | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |     return app, s | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-09-28 23:41:53 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  | def run(app, s): | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  |     try: | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         app.start() | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  |     except KeyboardInterrupt: | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         pass | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |  | 
					
						
							|  |  |  |  | def main(): | 
					
						
							|  |  |  |  |     try: | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         opts, args = getopt.getopt( | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |             sys.argv[1:], | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  |             'hd:i:Xv', | 
					
						
							|  |  |  |  |             ['database=', 'initfile=', 'ignore', 'help', 'version']) | 
					
						
							| 
									
										
										
										
											2007-01-10 16:19:56 +00:00
										 |  |  |  |     except getopt.error as msg: | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         usage(1, msg) | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     if len(args) == 0: | 
					
						
							|  |  |  |  |         initialcolor = None | 
					
						
							|  |  |  |  |     elif len(args) == 1: | 
					
						
							|  |  |  |  |         initialcolor = args[0] | 
					
						
							|  |  |  |  |     else: | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         usage(1) | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |     ignore = False | 
					
						
							|  |  |  |  |     dbfile = None | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |     initfile = os.path.expanduser('~/.pynche') | 
					
						
							|  |  |  |  |     for opt, arg in opts: | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         if opt in ('-h', '--help'): | 
					
						
							|  |  |  |  |             usage(0) | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  |         elif opt in ('-v', '--version'): | 
					
						
							| 
									
										
										
										
											2007-08-03 17:06:41 +00:00
										 |  |  |  |             print("""\
 | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  | Pynche -- The PYthon Natural Color and Hue Editor. | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  | Contact: %(AUTHNAME)s | 
					
						
							|  |  |  |  | Email:   %(AUTHEMAIL)s | 
					
						
							| 
									
										
										
										
											2007-08-03 17:06:41 +00:00
										 |  |  |  | Version: %(__version__)s""" % globals())
 | 
					
						
							| 
									
										
										
										
											1998-11-18 03:45:09 +00:00
										 |  |  |  |             sys.exit(0) | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |         elif opt in ('-d', '--database'): | 
					
						
							|  |  |  |  |             dbfile = arg | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |         elif opt in ('-X', '--ignore'): | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |             ignore = True | 
					
						
							| 
									
										
											  
											
												Many changes to support a second mode of operation.  Pynche can now be
run either as a standalone application (by running pynche or
pynche.pyw), or as a modal dialog inside another application.  This
can be done by importing pyColorChooser and running askcolor().  The
API for this is the same as the tkColorChooser.askcolor() API, namely:
    When `Okay' is hit, askcolor() returns ((r, g, b), "name").  When
    `Cancel' is hit, askcolor() returns (None, None).
Note the following differences:
    1. pyColorChooser.askcolor() takes an optional keyword `master'
       which if set tells Pynche to run as a modal dialog.  `master'
       is a Tkinter parent window.  Without the `master' keyword
       Pynche runs standalone.
    2. in pyColorChooser.askcolor() will return a Tk/X11 color name as
       "name" if there is an exact match, otherwise it will return a
       color spec, e.g. "#rrggbb".  tkColorChooser can't return a
       color name.
There are also some UI differences when running standalone vs. modal.
When modal, there is no "File" menu, but instead there are "Okay" and
"Cancel" buttons.
The implementation of all this is a bit of a hack, but it seems to
work moderately well.  I'm not guaranteeing the pyColorChooser.Chooser
class has the same semantics as the tkColorChooser.Chooser class.
											
										 
											1998-10-22 03:25:59 +00:00
										 |  |  |  |         elif opt in ('-i', '--initfile'): | 
					
						
							|  |  |  |  |             initfile = arg | 
					
						
							| 
									
										
										
										
											1998-10-20 20:45:46 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-10-22 18:45:52 +00:00
										 |  |  |  |     app, sb = build(initialcolor=initialcolor, | 
					
						
							|  |  |  |  |                     initfile=initfile, | 
					
						
							| 
									
										
										
										
											2002-10-21 14:23:48 +00:00
										 |  |  |  |                     ignore=ignore, | 
					
						
							|  |  |  |  |                     dbfile=dbfile) | 
					
						
							| 
									
										
										
										
											1998-10-22 18:45:52 +00:00
										 |  |  |  |     run(app, sb) | 
					
						
							|  |  |  |  |     sb.save_views() | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-10 21:42:04 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-31 23:39:28 +00:00
										 |  |  |  |  | 
					
						
							|  |  |  |  | if __name__ == '__main__': | 
					
						
							|  |  |  |  |     main() |