summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordas <das>2004-11-13 03:41:47 (GMT)
committerdas <das>2004-11-13 03:41:47 (GMT)
commita0c629af7cd340602be0486a9a2cef3351fc004b (patch)
tree94500bf0aa924483381d9fc791b2b80b7fc24cf6
parent062f5f6c0b950f3fd3ce98e48e5bd6b94703f30b (diff)
downloadtk-a0c629af7cd340602be0486a9a2cef3351fc004b.zip
tk-a0c629af7cd340602be0486a9a2cef3351fc004b.tar.gz
tk-a0c629af7cd340602be0486a9a2cef3351fc004b.tar.bz2
* macosx/tkMacOSXXStubs.c: implemented XGetGeometry().
-rw-r--r--ChangeLog4
-rw-r--r--macosx/tkMacOSXXStubs.c28
2 files changed, 28 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 049cef7..46a25b4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2004-11-12 Daniel Steffen <das@users.sourceforge.net>
+
+ * macosx/tkMacOSXXStubs.c: implemented XGetGeometry().
+
2004-11-12 Jeff Hobbs <jeffh@ActiveState.com>
* generic/tkCmds.c (Tk_TkObjCmd): use correct screen data when
diff --git a/macosx/tkMacOSXXStubs.c b/macosx/tkMacOSXXStubs.c
index 666d524..e43f1ab 100644
--- a/macosx/tkMacOSXXStubs.c
+++ b/macosx/tkMacOSXXStubs.c
@@ -12,7 +12,7 @@
* See the file "license.terms" for information on usage and redistribution
* of this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tkMacOSXXStubs.c,v 1.6 2004/05/03 22:28:45 hobbs Exp $
+ * RCS: @(#) $Id: tkMacOSXXStubs.c,v 1.7 2004/11/13 03:41:47 das Exp $
*/
#include "tkInt.h"
@@ -419,9 +419,29 @@ XGetGeometry(display, d, root_return, x_return, y_return, width_return,
unsigned int* border_width_return;
unsigned int* depth_return;
{
- /* Used in tkCanvPs.c & wm code */
- Debugger();
- return 0;
+ TkWindow *winPtr = ((MacDrawable *) d)->winPtr;
+
+ display->request++;
+ *root_return = ROOT_ID;
+ if (winPtr) {
+ *x_return = Tk_X(winPtr);
+ *y_return = Tk_Y(winPtr);
+ *width_return = Tk_Width(winPtr);
+ *height_return = Tk_Height(winPtr);
+ *border_width_return = winPtr->changes.border_width;
+ *depth_return = Tk_Depth(winPtr);
+ } else {
+ Rect boundsRect;
+ CGrafPtr destPort = TkMacOSXGetDrawablePort(d);
+ GetPortBounds(destPort,&boundsRect);
+ *x_return = boundsRect.left;
+ *y_return = boundsRect.top;
+ *width_return = boundsRect.right - boundsRect.left;
+ *height_return = boundsRect.bottom - boundsRect.top;
+ *border_width_return = 0;
+ *depth_return = 32;
+ }
+ return 1;
}
void