mirror of https://github.com/python/cpython.git
612 lines
16 KiB
Python
612 lines
16 KiB
Python
|
import Qd
|
|||
|
import Win
|
|||
|
import Evt
|
|||
|
import Fm
|
|||
|
import FrameWork
|
|||
|
import Windows
|
|||
|
import Events
|
|||
|
import Wbase
|
|||
|
import Dlg
|
|||
|
import MacOS
|
|||
|
import Menu
|
|||
|
import struct
|
|||
|
import traceback
|
|||
|
|
|||
|
from types import *
|
|||
|
|
|||
|
|
|||
|
class Window(FrameWork.Window, Wbase.SelectableWidget):
|
|||
|
|
|||
|
windowkind = Windows.documentProc
|
|||
|
|
|||
|
def __init__(self, possize, title = "", minsize = None, maxsize = None, tabbable = 1, show = 1):
|
|||
|
import W
|
|||
|
W.SelectableWidget.__init__(self, possize)
|
|||
|
self._globalbounds = l, t, r, b = self.getwindowbounds(possize, minsize)
|
|||
|
self._bounds = (0, 0, r - l, b - t)
|
|||
|
self._tabchain = []
|
|||
|
self._currentwidget = None
|
|||
|
self.title = title
|
|||
|
self._parentwindow = self
|
|||
|
self._tabbable = tabbable
|
|||
|
self._defaultbutton = None
|
|||
|
self._drawwidgetbounds = 0
|
|||
|
self._show = show
|
|||
|
self._lastrollover = None
|
|||
|
# XXX the following is not really compatible with the
|
|||
|
# new (system >= 7.5) window procs.
|
|||
|
if minsize:
|
|||
|
self._hasgrowbox = 1
|
|||
|
self.windowkind = self.windowkind | 8
|
|||
|
l, t = minsize
|
|||
|
if maxsize:
|
|||
|
r, b = maxsize[0] + 1, maxsize[1] + 1
|
|||
|
else:
|
|||
|
r, b = 32000, 32000
|
|||
|
self.growlimit = (l, t, r, b)
|
|||
|
else:
|
|||
|
self._hasgrowbox = 0
|
|||
|
if (self.windowkind == 0 or self.windowkind >= 8) and self.windowkind < 1000:
|
|||
|
self.windowkind = self.windowkind | 4
|
|||
|
FrameWork.Window.__init__(self, W.getapplication())
|
|||
|
|
|||
|
def gettitle(self):
|
|||
|
return self.title
|
|||
|
|
|||
|
def settitle(self, title):
|
|||
|
self.title = title
|
|||
|
if self.wid:
|
|||
|
self.wid.SetWTitle(title)
|
|||
|
|
|||
|
def getwindowbounds(self, size, minsize = None):
|
|||
|
return windowbounds(size, minsize)
|
|||
|
|
|||
|
def getcurrentwidget(self):
|
|||
|
return self._currentwidget
|
|||
|
|
|||
|
def show(self, onoff):
|
|||
|
if onoff:
|
|||
|
self.wid.ShowWindow()
|
|||
|
else:
|
|||
|
self.wid.HideWindow()
|
|||
|
|
|||
|
def isvisible(self):
|
|||
|
return self.wid.IsWindowVisible()
|
|||
|
|
|||
|
def getbounds(self):
|
|||
|
if 0: #self.isvisible():
|
|||
|
self.wid.GetWindowContentRgn(scratchRegion)
|
|||
|
self._globalbounds = GetRgnBounds(scratchRegion)
|
|||
|
return self._globalbounds
|
|||
|
|
|||
|
def select(self):
|
|||
|
self.wid.SelectWindow()
|
|||
|
# not sure if this is the best place, I need it when
|
|||
|
# an editor gets selected, and immediately scrolled
|
|||
|
# to a certain line, waste scroll assumes everything
|
|||
|
# to be in tact.
|
|||
|
self.do_rawupdate(self.wid, "DummyEvent")
|
|||
|
|
|||
|
def open(self):
|
|||
|
self.wid = Win.NewCWindow(self._globalbounds, self.title, self._show,
|
|||
|
self.windowkind, -1, 1, 0)
|
|||
|
self.SetPort()
|
|||
|
fnum = Fm.GetFNum("Python-Sans")
|
|||
|
if fnum == 0:
|
|||
|
fnum = Fm.GetFNum("Geneva")
|
|||
|
Qd.TextFont(fnum) # XXX font&size from a function?
|
|||
|
Qd.TextSize(9) # XXX font&size from a function?
|
|||
|
if self._bindings.has_key("<open>"):
|
|||
|
callback = self._bindings["<open>"]
|
|||
|
callback()
|
|||
|
for w in self._widgets:
|
|||
|
w.forall_frombottom("open")
|
|||
|
self._maketabchain()
|
|||
|
if self._tabchain:
|
|||
|
self._tabchain[0].select(1)
|
|||
|
if self._tabbable:
|
|||
|
self.bind('tab', self.nextwidget)
|
|||
|
self.bind('shifttab', self.previouswidget)
|
|||
|
self.do_postopen()
|
|||
|
|
|||
|
def close(self):
|
|||
|
if not self.wid:
|
|||
|
return # we are already closed
|
|||
|
if self._bindings.has_key("<close>"):
|
|||
|
callback = self._bindings["<close>"]
|
|||
|
try:
|
|||
|
rv = callback()
|
|||
|
except:
|
|||
|
print 'error in <close> callback'
|
|||
|
traceback.print_exc()
|
|||
|
else:
|
|||
|
if rv:
|
|||
|
return rv
|
|||
|
#for key in self._widgetsdict.keys():
|
|||
|
# self._removewidget(key)
|
|||
|
self.forall_butself("close")
|
|||
|
Wbase.SelectableWidget.close(self)
|
|||
|
self._tabchain = []
|
|||
|
self._currentwidget = None
|
|||
|
self.wid.HideWindow()
|
|||
|
self.do_postclose()
|
|||
|
|
|||
|
def domenu_close(self, *args):
|
|||
|
self.close()
|
|||
|
|
|||
|
def move(self, x, y = None):
|
|||
|
"""absolute move"""
|
|||
|
if y == None:
|
|||
|
x, y = x
|
|||
|
self.wid.MoveWindow(x, y, 0)
|
|||
|
|
|||
|
def resize(self, x, y = None):
|
|||
|
if y == None:
|
|||
|
x, y = x
|
|||
|
if self._hasgrowbox:
|
|||
|
self.SetPort()
|
|||
|
Win.InvalRect(self.getgrowrect())
|
|||
|
self.wid.SizeWindow(x, y, 1)
|
|||
|
self._calcbounds()
|
|||
|
|
|||
|
def test(self, point):
|
|||
|
return 1
|
|||
|
|
|||
|
def draw(self, visRgn = None):
|
|||
|
if self._hasgrowbox:
|
|||
|
self.tempcliprect(self.getgrowrect())
|
|||
|
self.wid.DrawGrowIcon()
|
|||
|
self.restoreclip()
|
|||
|
|
|||
|
def idle(self, *args):
|
|||
|
self.SetPort()
|
|||
|
point = Evt.GetMouse()
|
|||
|
widget = self.findwidget(point, 0)
|
|||
|
if self._bindings.has_key("<idle>"):
|
|||
|
callback = self._bindings["<idle>"]
|
|||
|
if callback():
|
|||
|
return
|
|||
|
if self._currentwidget is not None and hasattr(self._currentwidget, "idle"):
|
|||
|
if self._currentwidget._bindings.has_key("<idle>"):
|
|||
|
callback = self._currentwidget._bindings["<idle>"]
|
|||
|
if callback():
|
|||
|
return
|
|||
|
if self._currentwidget.idle():
|
|||
|
return
|
|||
|
if widget is not None and hasattr(widget, "rollover"):
|
|||
|
if 1: #self._lastrollover <> widget:
|
|||
|
if self._lastrollover:
|
|||
|
self._lastrollover.rollover(point, 0)
|
|||
|
self._lastrollover = widget
|
|||
|
self._lastrollover.rollover(point, 1)
|
|||
|
else:
|
|||
|
if self._lastrollover:
|
|||
|
self._lastrollover.rollover(point, 0)
|
|||
|
self._lastrollover = None
|
|||
|
Wbase.SetCursor("arrow")
|
|||
|
|
|||
|
def xxx___select(self, widget):
|
|||
|
if self._currentwidget == widget:
|
|||
|
return
|
|||
|
if self._bindings.has_key("<select>"):
|
|||
|
callback = self._bindings["<select>"]
|
|||
|
if callback(widget):
|
|||
|
return
|
|||
|
if widget is None:
|
|||
|
if self._currentwidget is not None:
|
|||
|
self._currentwidget.select(0)
|
|||
|
elif type(widget) == InstanceType and widget._selectable:
|
|||
|
widget.select(1)
|
|||
|
elif widget == -1 or widget == 1:
|
|||
|
if len(self._tabchain) <= 1:
|
|||
|
return
|
|||
|
temp = self._tabchain[(self._tabchain.index(self._currentwidget) + widget) % len(self._tabchain)]
|
|||
|
temp.select(1)
|
|||
|
else:
|
|||
|
raise TypeError, "Widget is not selectable"
|
|||
|
|
|||
|
def setdefaultbutton(self, newdefaultbutton = None, *keys):
|
|||
|
if newdefaultbutton == self._defaultbutton:
|
|||
|
return
|
|||
|
if self._defaultbutton:
|
|||
|
self._defaultbutton._setdefault(0)
|
|||
|
if not newdefaultbutton:
|
|||
|
self.bind("return", None)
|
|||
|
self.bind("enter", None)
|
|||
|
return
|
|||
|
import Wcontrols
|
|||
|
if not isinstance(newdefaultbutton, Wcontrols.Button):
|
|||
|
raise TypeError, "widget is not a button"
|
|||
|
self._defaultbutton = newdefaultbutton
|
|||
|
self._defaultbutton._setdefault(1)
|
|||
|
if not keys:
|
|||
|
self.bind("return", self._defaultbutton.push)
|
|||
|
self.bind("enter", self._defaultbutton.push)
|
|||
|
else:
|
|||
|
for key in keys:
|
|||
|
self.bind(key, self._defaultbutton.push)
|
|||
|
|
|||
|
def nextwidget(self):
|
|||
|
self.xxx___select(1)
|
|||
|
|
|||
|
def previouswidget(self):
|
|||
|
self.xxx___select(-1)
|
|||
|
|
|||
|
def drawwidgetbounds(self, onoff):
|
|||
|
self._drawwidgetbounds = onoff
|
|||
|
self.SetPort()
|
|||
|
Win.InvalRect(self._bounds)
|
|||
|
|
|||
|
def _drawbounds(self):
|
|||
|
pass
|
|||
|
|
|||
|
def _maketabchain(self):
|
|||
|
# XXX This has to change, it's no good when we are adding or deleting widgets.
|
|||
|
# XXX Perhaps we shouldn't keep a "tabchain" at all.
|
|||
|
self._hasselframes = 0
|
|||
|
self._collectselectablewidgets(self._widgets)
|
|||
|
if self._hasselframes and len(self._tabchain) > 1:
|
|||
|
self._hasselframes = 1
|
|||
|
else:
|
|||
|
self._hasselframes = 0
|
|||
|
|
|||
|
def _collectselectablewidgets(self, widgets):
|
|||
|
import W
|
|||
|
for w in widgets:
|
|||
|
if w._selectable:
|
|||
|
self._tabchain.append(w)
|
|||
|
if isinstance(w, W.List):
|
|||
|
self._hasselframes = 1
|
|||
|
self._collectselectablewidgets(w._widgets)
|
|||
|
|
|||
|
def _calcbounds(self):
|
|||
|
self._possize = self.wid.GetWindowPort().portRect[2:]
|
|||
|
w, h = self._possize
|
|||
|
self._bounds = (0, 0, w, h)
|
|||
|
self.wid.GetWindowContentRgn(scratchRegion)
|
|||
|
l, t, r, b = GetRgnBounds(scratchRegion)
|
|||
|
self._globalbounds = l, t, l + w, t + h
|
|||
|
for w in self._widgets:
|
|||
|
w._calcbounds()
|
|||
|
|
|||
|
# FrameWork override methods
|
|||
|
def do_inDrag(self, partcode, window, event):
|
|||
|
where = event[3]
|
|||
|
self.wid.GetWindowContentRgn(scratchRegion)
|
|||
|
was_l, was_t, r, b = GetRgnBounds(scratchRegion)
|
|||
|
window.DragWindow(where, self.draglimit)
|
|||
|
self.wid.GetWindowContentRgn(scratchRegion)
|
|||
|
is_l, is_t, r, b = GetRgnBounds(scratchRegion)
|
|||
|
self._globalbounds = Qd.OffsetRect(self._globalbounds,
|
|||
|
is_l - was_l, is_t - was_t)
|
|||
|
|
|||
|
def do_char(self, char, event):
|
|||
|
import Wkeys
|
|||
|
(what, message, when, where, modifiers) = event
|
|||
|
key = char
|
|||
|
if Wkeys.keynames.has_key(key):
|
|||
|
key = Wkeys.keynames[char]
|
|||
|
if modifiers & Events.shiftKey:
|
|||
|
key = 'shift' + key
|
|||
|
if modifiers & Events.cmdKey:
|
|||
|
key = 'cmd' + key
|
|||
|
if modifiers & Events.controlKey:
|
|||
|
key = 'control' + key
|
|||
|
if self._bindings.has_key("<key>"):
|
|||
|
callback = self._bindings["<key>"]
|
|||
|
if Wbase.CallbackCall(callback, 0, char, event):
|
|||
|
return
|
|||
|
if self._bindings.has_key(key):
|
|||
|
callback = self._bindings[key]
|
|||
|
Wbase.CallbackCall(callback, 0, char, event)
|
|||
|
elif self._currentwidget is not None:
|
|||
|
if self._currentwidget._bindings.has_key(key):
|
|||
|
callback = self._currentwidget._bindings[key]
|
|||
|
Wbase.CallbackCall(callback, 0, char, event)
|
|||
|
else:
|
|||
|
if self._currentwidget._bindings.has_key("<key>"):
|
|||
|
callback = self._currentwidget._bindings["<key>"]
|
|||
|
if Wbase.CallbackCall(callback, 0, char, event):
|
|||
|
return
|
|||
|
self._currentwidget.key(char, event)
|
|||
|
|
|||
|
def do_contentclick(self, point, modifiers, event):
|
|||
|
widget = self.findwidget(point)
|
|||
|
if widget is not None:
|
|||
|
if self._bindings.has_key("<click>"):
|
|||
|
callback = self._bindings["<click>"]
|
|||
|
if Wbase.CallbackCall(callback, 0, point, modifiers):
|
|||
|
return
|
|||
|
if widget._bindings.has_key("<click>"):
|
|||
|
callback = widget._bindings["<click>"]
|
|||
|
if Wbase.CallbackCall(callback, 0, point, modifiers):
|
|||
|
return
|
|||
|
if widget._selectable:
|
|||
|
widget.select(1, 1)
|
|||
|
widget.click(point, modifiers)
|
|||
|
|
|||
|
def do_update(self, window, event):
|
|||
|
Qd.EraseRgn(window.GetWindowPort().visRgn)
|
|||
|
self.forall_frombottom("draw", window.GetWindowPort().visRgn)
|
|||
|
if self._drawwidgetbounds:
|
|||
|
self.forall_frombottom("_drawbounds")
|
|||
|
|
|||
|
def do_activate(self, onoff, event):
|
|||
|
if not onoff:
|
|||
|
if self._lastrollover:
|
|||
|
self._lastrollover.rollover((0, 0), 0)
|
|||
|
self._lastrollover = None
|
|||
|
self.SetPort()
|
|||
|
self.forall("activate", onoff)
|
|||
|
self.draw()
|
|||
|
|
|||
|
def do_postresize(self, width, height, window):
|
|||
|
Win.InvalRect(self.getgrowrect())
|
|||
|
self._calcbounds()
|
|||
|
|
|||
|
def do_inGoAway(self, partcode, window, event):
|
|||
|
where = event[3]
|
|||
|
closeall = event[4] & Events.optionKey
|
|||
|
if window.TrackGoAway(where):
|
|||
|
if not closeall:
|
|||
|
self.close()
|
|||
|
else:
|
|||
|
for window in self.parent._windows.values():
|
|||
|
rv = window.close()
|
|||
|
if rv and rv > 0:
|
|||
|
return
|
|||
|
|
|||
|
# utilities
|
|||
|
def tempcliprect(self, tempcliprect):
|
|||
|
tempclip = Qd.NewRgn()
|
|||
|
Qd.RectRgn(tempclip, tempcliprect)
|
|||
|
self.tempclip(tempclip)
|
|||
|
Qd.DisposeRgn(tempclip)
|
|||
|
|
|||
|
def tempclip(self, tempclip):
|
|||
|
if not hasattr(self, "saveclip"):
|
|||
|
self.saveclip = []
|
|||
|
saveclip = Qd.NewRgn()
|
|||
|
Qd.GetClip(saveclip)
|
|||
|
self.saveclip.append(saveclip)
|
|||
|
Qd.SetClip(tempclip)
|
|||
|
|
|||
|
def restoreclip(self):
|
|||
|
Qd.SetClip(self.saveclip[-1])
|
|||
|
Qd.DisposeRgn(self.saveclip[-1])
|
|||
|
del self.saveclip[-1]
|
|||
|
|
|||
|
def getgrowrect(self):
|
|||
|
l, t, r, b = self.wid.GetWindowPort().portRect
|
|||
|
return (r - 15, b - 15, r, b)
|
|||
|
|
|||
|
def has_key(self, key):
|
|||
|
return self._widgetsdict.has_key(key)
|
|||
|
|
|||
|
def __getattr__(self, attr):
|
|||
|
global _successcount, _failcount, _magiccount
|
|||
|
if self._widgetsdict.has_key(attr):
|
|||
|
_successcount = _successcount + 1
|
|||
|
return self._widgetsdict[attr]
|
|||
|
if self._currentwidget is None or (attr[:7] <> 'domenu_' and
|
|||
|
attr[:4] <> 'can_' and attr <> 'insert'):
|
|||
|
_failcount = _failcount + 1
|
|||
|
raise AttributeError, attr
|
|||
|
# special case: if a domenu_xxx, can_xxx or insert method is asked for,
|
|||
|
# see if the active widget supports it
|
|||
|
_magiccount = _magiccount + 1
|
|||
|
return getattr(self._currentwidget, attr)
|
|||
|
|
|||
|
_successcount = 0
|
|||
|
_failcount = 0
|
|||
|
_magiccount = 0
|
|||
|
|
|||
|
class Dialog(Window):
|
|||
|
|
|||
|
windowkind = Windows.movableDBoxProc
|
|||
|
|
|||
|
# this __init__ seems redundant, but it's not: it has less args
|
|||
|
def __init__(self, possize, title = ""):
|
|||
|
Window.__init__(self, possize, title)
|
|||
|
|
|||
|
def can_close(self, *args):
|
|||
|
return 0
|
|||
|
|
|||
|
def getwindowbounds(self, size, minsize = None):
|
|||
|
screenbounds = sl, st, sr, sb = Qd.qd.screenBits.bounds
|
|||
|
w, h = size
|
|||
|
l = sl + (sr - sl - w) / 2
|
|||
|
t = st + (sb - st - h) / 3
|
|||
|
return l, t, l + w, t + h
|
|||
|
|
|||
|
|
|||
|
class ModalDialog(Dialog):
|
|||
|
|
|||
|
def __init__(self, possize, title = ""):
|
|||
|
Dialog.__init__(self, possize, title)
|
|||
|
if title:
|
|||
|
self.windowkind = Windows.movableDBoxProc
|
|||
|
else:
|
|||
|
self.windowkind = Windows.dBoxProc
|
|||
|
|
|||
|
def open(self):
|
|||
|
import W
|
|||
|
Dialog.open(self)
|
|||
|
self.app = W.getapplication()
|
|||
|
self.done = 0
|
|||
|
Menu.HiliteMenu(0)
|
|||
|
app = self.parent
|
|||
|
app.enablemenubar(0)
|
|||
|
try:
|
|||
|
self.mainloop()
|
|||
|
finally:
|
|||
|
app.enablemenubar(1)
|
|||
|
|
|||
|
def close(self):
|
|||
|
if not self.wid:
|
|||
|
return # we are already closed
|
|||
|
self.done = 1
|
|||
|
del self.app
|
|||
|
Dialog.close(self)
|
|||
|
|
|||
|
def mainloop(self):
|
|||
|
saveyield = MacOS.EnableAppswitch(-1)
|
|||
|
while not self.done:
|
|||
|
#self.do1event()
|
|||
|
self.do1event( Events.keyDownMask +
|
|||
|
Events.autoKeyMask +
|
|||
|
Events.activMask +
|
|||
|
Events.updateMask +
|
|||
|
Events.mDownMask +
|
|||
|
Events.mUpMask,
|
|||
|
10)
|
|||
|
MacOS.EnableAppswitch(saveyield)
|
|||
|
|
|||
|
def do1event(self, mask = Events.everyEvent, wait = 0):
|
|||
|
ok, event = self.app.getevent(mask, wait)
|
|||
|
if Dlg.IsDialogEvent(event):
|
|||
|
if self.app.do_dialogevent(event):
|
|||
|
return
|
|||
|
if ok:
|
|||
|
self.dispatch(event)
|
|||
|
else:
|
|||
|
self.app.idle(event)
|
|||
|
|
|||
|
def do_keyDown(self, event):
|
|||
|
self.do_key(event)
|
|||
|
|
|||
|
def do_autoKey(self, event):
|
|||
|
if not event[-1] & Events.cmdKey:
|
|||
|
self.do_key(event)
|
|||
|
|
|||
|
def do_key(self, event):
|
|||
|
(what, message, when, where, modifiers) = event
|
|||
|
w = Win.FrontWindow()
|
|||
|
if w <> self.wid:
|
|||
|
return
|
|||
|
c = chr(message & Events.charCodeMask)
|
|||
|
if modifiers & Events.cmdKey:
|
|||
|
self.app.checkmenus(self)
|
|||
|
result = Menu.MenuKey(ord(c))
|
|||
|
id = (result>>16) & 0xffff # Hi word
|
|||
|
item = result & 0xffff # Lo word
|
|||
|
if id:
|
|||
|
self.app.do_rawmenu(id, item, None, event)
|
|||
|
return
|
|||
|
self.do_char(c, event)
|
|||
|
|
|||
|
def do_mouseDown(self, event):
|
|||
|
(what, message, when, where, modifiers) = event
|
|||
|
partcode, wid = Win.FindWindow(where)
|
|||
|
#
|
|||
|
# Find the correct name.
|
|||
|
#
|
|||
|
if FrameWork.partname.has_key(partcode):
|
|||
|
name = "do_" + FrameWork.partname[partcode]
|
|||
|
else:
|
|||
|
name = "do_%d" % partcode
|
|||
|
|
|||
|
if name == "do_inDesk":
|
|||
|
MacOS.HandleEvent(event)
|
|||
|
return
|
|||
|
if wid == self.wid:
|
|||
|
try:
|
|||
|
handler = getattr(self, name)
|
|||
|
except AttributeError:
|
|||
|
handler = self.app.do_unknownpartcode
|
|||
|
else:
|
|||
|
#MacOS.HandleEvent(event)
|
|||
|
if name == 'do_inMenuBar':
|
|||
|
handler = getattr(self.parent, name)
|
|||
|
else:
|
|||
|
return
|
|||
|
handler(partcode, wid, event)
|
|||
|
|
|||
|
def dispatch(self, event):
|
|||
|
(what, message, when, where, modifiers) = event
|
|||
|
if FrameWork.eventname.has_key(what):
|
|||
|
name = "do_" + FrameWork.eventname[what]
|
|||
|
else:
|
|||
|
name = "do_%d" % what
|
|||
|
try:
|
|||
|
handler = getattr(self, name)
|
|||
|
except AttributeError:
|
|||
|
try:
|
|||
|
handler = getattr(self.app, name)
|
|||
|
except AttributeError:
|
|||
|
handler = self.app.do_unknownevent
|
|||
|
handler(event)
|
|||
|
|
|||
|
|
|||
|
def FrontWindowInsert(stuff):
|
|||
|
if not stuff:
|
|||
|
return
|
|||
|
if type(stuff) <> StringType:
|
|||
|
raise TypeError, 'string expected'
|
|||
|
import W
|
|||
|
app = W.getapplication()
|
|||
|
wid = Win.FrontWindow()
|
|||
|
if wid and app._windows.has_key(wid):
|
|||
|
window = app._windows[wid]
|
|||
|
if hasattr(window, "insert"):
|
|||
|
try:
|
|||
|
window.insert(stuff)
|
|||
|
return
|
|||
|
except:
|
|||
|
pass
|
|||
|
import EasyDialogs
|
|||
|
if EasyDialogs.AskYesNoCancel(
|
|||
|
"Can<EFBFBD>t find window or widget to insert text into; copy to clipboard instead?",
|
|||
|
1) == 1:
|
|||
|
import Scrap
|
|||
|
Scrap.ZeroScrap()
|
|||
|
Scrap.PutScrap('TEXT', stuff)
|
|||
|
|
|||
|
|
|||
|
# not quite based on the same function in FrameWork
|
|||
|
_windowcounter = 0
|
|||
|
|
|||
|
def getnextwindowpos():
|
|||
|
global _windowcounter
|
|||
|
rows = 8
|
|||
|
l = 4 * (rows + 1 - (_windowcounter % rows) + _windowcounter / rows)
|
|||
|
t = 44 + 20 * (_windowcounter % rows)
|
|||
|
_windowcounter = _windowcounter + 1
|
|||
|
return l, t
|
|||
|
|
|||
|
def windowbounds(preferredsize, minsize = None):
|
|||
|
"Return sensible window bounds"
|
|||
|
|
|||
|
global _windowcounter
|
|||
|
if len(preferredsize) == 4:
|
|||
|
bounds = l, t, r, b = preferredsize
|
|||
|
union = Qd.UnionRect(bounds, Qd.qd.screenBits.bounds)
|
|||
|
if union == Qd.qd.screenBits.bounds:
|
|||
|
return bounds
|
|||
|
else:
|
|||
|
preferredsize = r - l, b - t
|
|||
|
if not minsize:
|
|||
|
minsize = preferredsize
|
|||
|
minwidth, minheight = minsize
|
|||
|
width, height = preferredsize
|
|||
|
|
|||
|
sl, st, sr, sb = screenbounds = Qd.InsetRect(Qd.qd.screenBits.bounds, 4, 4)
|
|||
|
l, t = getnextwindowpos()
|
|||
|
if (l + width) > sr:
|
|||
|
_windowcounter = 0
|
|||
|
l, t = getnextwindowpos()
|
|||
|
r = l + width
|
|||
|
b = t + height
|
|||
|
if (t + height) > sb:
|
|||
|
b = sb
|
|||
|
if (b - t) < minheight:
|
|||
|
b = t + minheight
|
|||
|
return l, t, r, b
|
|||
|
|
|||
|
scratchRegion = Qd.NewRgn()
|
|||
|
|
|||
|
# util -- move somewhere convenient???
|
|||
|
def GetRgnBounds(the_Rgn):
|
|||
|
(t, l, b, r) = struct.unpack("hhhh", the_Rgn.data[2:10])
|
|||
|
return (l, t, r, b)
|