|
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(); } } }