diff options
author | Eric S. Raymond <esr@thyrsus.com> | 1998-06-30 14:33:10 +0000 |
---|---|---|
committer | Eric S. Raymond <esr@thyrsus.com> | 1998-06-30 14:33:10 +0000 |
commit | 528319ee63f91b4e1e282850c888a9fff2e394e4 (patch) | |
tree | 2101d76910a6fcf1cc79c66c272246242727c0ab | |
parent | c4f55a5661e726abcdefd32b478a33d3ac8b8ab4 (diff) | |
download | fetchmail-528319ee63f91b4e1e282850c888a9fff2e394e4.tar.gz fetchmail-528319ee63f91b4e1e282850c888a9fff2e394e4.tar.bz2 fetchmail-528319ee63f91b4e1e282850c888a9fff2e394e4.zip |
All the windows now have icons.
svn path=/trunk/; revision=1951
-rwxr-xr-x | fetchmailconf | 30 |
1 files changed, 22 insertions, 8 deletions
diff --git a/fetchmailconf b/fetchmailconf index ac41880d..7b829571 100755 --- a/fetchmailconf +++ b/fetchmailconf @@ -358,6 +358,20 @@ def helpwin(helpdict): command=lambda x=helpwin: Widget.destroy(x), relief=SUNKEN, bd=2).pack() +def make_icon_window(base, image): + try: + # Some older pythons will error out on this + icon_image = PhotoImage(data=image) + icon_window = Toplevel() + Label(icon_window, image=icon_image, bg='black').pack() + base.master.iconwindow(icon_window) + # Avoid TkInter brain death. PhotoImage objects go out of + # scope when the enclosing function returns. Therefore + # we have to explicitly link them to something. + base.keepalive.append(icon_image) + except: + pass + class ListEdit(Frame): # edit a list of values (duplicates not allowed) with a supplied editor hook def __init__(self, newlegend, list, editor, master, helptxt): @@ -566,6 +580,8 @@ class ConfigurationEdit(Frame, MyWidget): Frame.__init__(self, self.container) self.master.title('fetchmail ' + self.mode + ' configurator'); self.master.iconname('fetchmail ' + self.mode + ' configurator'); + self.keepalive = [] # Use this to anchor the PhotoImage object + make_icon_window(self, fetchmail_gif) Pack.config(self) self.post(Configuration, 'configuration') @@ -792,6 +808,8 @@ class ServerEdit(Frame, MyWidget): self.master.iconname('Fetchmail host ' + self.server.pollname); self.post(Server, 'server') self.makeWidgets(self.server.pollname, mode) + self.keepalive = [] # Use this to anchor the PhotoImage object + make_icon_window(self, fetchmail_gif) # self.grab_set() # self.focus_set() # self.wait_window() @@ -1072,6 +1090,8 @@ class UserEdit(Frame, MyWidget): self.master.iconname('Fetchmail user ' + self.user.remote); self.post(User, 'user') self.makeWidgets(mode, self.server.pollname) + self.keepalive = [] # Use this to anchor the PhotoImage object + make_icon_window(self, fetchmail_gif) # self.grab_set() # self.focus_set() # self.wait_window() @@ -1191,6 +1211,8 @@ class MainWindow(Frame): Label(self, text='Fetchmailconf ' + version, bd=2).pack(side=TOP, pady=10) + self.keepalive = [] # Use this to anchor the PhotoImage object + make_icon_window(self, fetchmail_gif) Message(self, text=""" Use `Novice Configuration' for basic fetchmail setup; @@ -1373,14 +1395,6 @@ if __name__ == '__main__': # OK, now run the configuration edit root = MainWindow(rcfile) - try: - # Some older pythons will error out on this - icon_image = PhotoImage(data=fetchmail_gif) - icon_window = Toplevel() - Label(icon_window, image=icon_image, bg='black').pack() - root.master.iconwindow(icon_window) - except: - pass root.mainloop() # The following sets edit modes for GNU EMACS |