|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: M T
Length: 6803 (0x1a93)
Types: TextFile
Names: »Move.c«
└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
└─⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z«
└─⟦2109abc41⟧
└─⟦this⟧ »./X.V10R4/uwm/Move.c«
#ifndef lint
static char *rcsid_Move_c = "$Header: Move.c,v 10.4 86/11/19 16:24:03 jg Rel $";
#endif lint
/*
* COPYRIGHT 1985, 1986
* DIGITAL EQUIPMENT CORPORATION
* MAYNARD, MASSACHUSETTS
* ALL RIGHTS RESERVED.
*
* THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE AND
* SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT CORPORATION.
* DIGITAL MAKES NO REPRESENTATIONS ABOUT THE SUITIBILITY OF THIS SOFTWARE FOR
* ANY PURPOSE. IT IS SUPPLIED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY.
*
* IF THE SOFTWARE IS MODIFIED IN A MANNER CREATING DERIVATIVE COPYRIGHT RIGHTS,
* APPROPRIATE LEGENDS MAY BE PLACED ON THE DERIVATIVE WORK IN ADDITION TO THAT
* SET FORTH ABOVE.
*
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose and without fee is hereby granted, provided
* that the above copyright notice appear in all copies and that both that
* copyright notice and this permission notice appear in supporting documentation,
* and that the name of Digital Equipment Corporation not be used in advertising
* or publicity pertaining to distribution of the software without specific,
* written prior permission.
*
*/
/*
* MODIFICATION HISTORY
*
* 000 -- M. Gancarz, DEC Ultrix Engineering Group
*/
#ifndef lint
static char *sccsid = "@(#)Move.c 3.8 1/24/86";
#endif
#include "uwm.h"
Bool Move(window, mask, button, x, y)
Window window; /* Event window. */
int mask; /* Button/key mask. */
short button; /* Button event detail. */
int x, y; /* Event mouse position. */
{
register int prev_x; /* Previous event window X location. */
register int prev_y; /* Previous event window Y location. */
register WindowInfo window_info; /* Event window information. */
int cur_x; /* Current event window X location. */
int cur_y; /* Current event window Y location. */
int ulx, uly; /* Event window upper left X and Y. */
int lrx, lry; /* Event window lower right X and Y. */
int init_ulx, init_uly; /* Init window upper left X and Y. */
int init_lrx, init_lry; /* Init window lower right X and Y. */
int num_vectors; /* Number of vectors in box. */
Window sub_window; /* Query mouse event sub-window. */
XButtonEvent button_event; /* Button event packet. */
Vertex box[MAX_BOX_VECTORS]; /* Box vertex buffer. */
Vertex zap[MAX_ZAP_VECTORS]; /* Zap effect verted buffer. */
/*
* Do not try to move the root window.
*/
if (window == RootWindow)
return(FALSE);
/*
* Change the cursor.
*/
status = XGrabButton(RootWindow, ArrowCrossCursor, mask, EVENTMASK);
if (status == FAILURE)
Error("Move -> Unable to grab button and change cursor.");
/*
* Clear the vector buffers.
*/
bzero(box, sizeof(box));
if (Zap) bzero(zap, sizeof(zap));
/*
* Gather info on the event window.
*/
status = XQueryWindow(window, &window_info);
if (status == FAILURE) return(FALSE);
/*
* Initialize movement variables.
*/
init_ulx = ulx = window_info.x;
init_uly = uly = window_info.y;
init_lrx = lrx = window_info.x + window_info.width +
(window_info.bdrwidth << 1) - 1;
init_lry = lry = window_info.y + window_info.height +
(window_info.bdrwidth << 1) - 1;
/*
* Store the box.
*/
if (Grid)
num_vectors = StoreGridBox(box, ulx, uly, lrx, lry);
else num_vectors = StoreBox(box, ulx, uly, lrx, lry);
/*
* Initialize the previous location variables.
*/
prev_x = x;
prev_y = y;
/*
* Freeze the server, if requested by the user.
* This results in a solid box instead of a flickering one.
*/
if (Freeze) XGrabServer();
/*
* Process any pending exposure events before drawing the box.
*/
while (QLength() > 0) {
XPeekEvent(&button_event);
if (button_event.window == RootWindow)
break;
GetButton(&button_event);
}
/*
* Now draw the box.
*/
DrawBox();
Frozen = window;
/*
* Main loop.
*/
while (TRUE) {
/*
* Check to see if we have a change in mouse button status.
* This is how we get out of this "while" loop.
*/
if (XPending() && GetButton(&button_event)) {
/*
* Process the pending events, this sequence is the only
* way out of the loop and the routine.
*/
/*
* If we froze the server, then erase the last lines drawn.
*/
if (Freeze) {
DrawBox();
Frozen = (Window)0;
XUngrabServer();
}
if ((button_event.type == ButtonReleased) &&
((button_event.detail & ValueMask) == button)) {
/*
* The button was released, so reset the cursor and
* move the window.
*/
Grab(mask);
if (Zap) {
num_vectors = StoreZap(zap,
init_ulx, init_uly,
init_lrx, init_lry,
ulx, uly,
lrx, lry);
DrawZap();
DrawZap();
}
XMoveWindow(window, ulx, uly);
return(TRUE);
}
else {
/*
* Some other button event occured, this aborts the
* current operation.
*/
/*
* Reset the cursor.
*/
Grab(mask);
return(TRUE);
}
}
/*
* Take care of all the little things that have changed.
*/
XUpdateMouse(RootWindow, &cur_x, &cur_y, &sub_window);
if ((cur_x != prev_x) || (cur_y != prev_y)) {
/*
* If we've frozen the server, then erase the old box first!
*/
if (Freeze)
DrawBox();
/*
* Box position has changed.
*/
ulx += cur_x - prev_x;
uly += cur_y - prev_y;
lrx += cur_x - prev_x;
lry += cur_y - prev_y;
/*
* Box needs to be restored.
*/
if (Grid)
num_vectors = StoreGridBox(box, ulx, uly, lrx, lry);
else num_vectors = StoreBox(box, ulx, uly, lrx, lry);
/*
* Draw the new box.
*/
if (Freeze)
DrawBox();
}
/*
* Save old box position.
*/
prev_x = cur_x;
prev_y = cur_y;
/*
* If server is not frozen, then draw the "flicker" box.
*/
if (!Freeze) {
DrawBox();
DrawBox();
}
}
}