|
|
BSD 4.3
#include <X/mit-copyright.h>
/* $Header: /var/lib/cvsd/repos/CSRG/43BSD/contrib/X/Xlib/XCreate.c,v 1.1.1.1 2018/04/24 16:12:54 root Exp $ */
/* Copyright 1985, Massachusetts Institute of Technology */
/* stolen from CLU routine x_cons, redone by J. Gettys */
#include "XlibInternal.h"
#include <stdio.h>
#define TRUE 1
#define FALSE 0
#define max(a,b) ( (a) > (b) ? (a) : (b) )
#define min(a,b) ( (a) > (b) ? (b) : (a) )
#define abs(a) ( (a) > 0 ? (a) : -(a))
#define DCOUNT 2
#define VCOUNT 1 + (4 * 2 * DCOUNT)
#define FCOUNT 1 + 4
#include "../cursors/cross.cursor"
#include "../cursors/cross_mask.cursor"
Window XCreate(prompt, name, geometry, def, frame, minwidth, minheight)
char *prompt, *name;
register OpaqueFrame *frame;
int minwidth, minheight;
char *geometry, *def;
{
char *fn = "8x13"; /* default default font */
FontInfo *pfninfo; /* font info on prompt */
Window pop; /* pop up window */
char *opt;
int pfore, pback; /* prompt window colors */
int bpix; /* border color */
int mfore, mback; /* mouse colors */
int pbw = 1; /* prompt window border width */
int ibw = 1; /* internal border width */
int freeze = 0; /* should we freeze the server */
Color cdef; /* color structure for lookup */
Cursor cr; /* cursor for the prompt window */
int events; /* event mask */
int popw, poph; /* prompt window height and width */
int count = VCOUNT; /* vertex count */
Pixmap save = 0; /* saved pixmap */
Pixmap backmap, bdrmap; /* background and border pixmaps */
Vertex box[VCOUNT]; /* vertex list for box */
int x1, y1; /* location of mouse */
int x2, y2; /* other corner of box */
Window subw; /* subwindow it is in */
int mindim; /* minimum dimension */
int width, height; /* width and height of box */
int left, stop;
int mouse;
int force; /* force default window to track */
int xa, ya, xb, yb;
int doit;
XButtonEvent event; /* someplace to put the event */
register int i; /* ye olde indexe variabel */
int fx, fy, fw, fh; /* frame from parse... */
int pr; /* parse geometry result */
pr = XGeometry (geometry, def, frame->bdrwidth, 1, 1, 0, 0,
&fx, &fy, &fw, &fh);
/*
* none of this nonsense would be necessary if I hadn't blown
* the frame structure definition.
*/
frame->x = fx;
frame->y = fy;
frame->width = fw;
frame->height = fh;
if (geometry != NULL) {
/*
* if x or y offsets are specified, then we should autoplace
*/
if ( (pr & XValue ) || (pr & YValue) ) {
if (frame->width < minwidth) frame->width = minwidth;
if (frame->height < minheight) frame->height = minheight;
goto makeit;
}
}
if ((opt = XGetDefault(name, "MakeWindow.BodyFont")) != NULL) fn = opt;
if ((pfninfo = XOpenFont(fn)) == NULL) {
fprintf(stderr, "Can't open font %s!\n", fn);
return(0);
}
pfore = mback = WhitePixel;
pback = bpix = mfore = BlackPixel;
if ((opt = XGetDefault(name, "MakeWindow.ReverseVideo")) != NULL)
if (strcmp (opt, "on") == 0) {
pfore = BlackPixel;
pback = WhitePixel;
}
if ((opt = XGetDefault(name, "MakeWindow.BorderWidth")) != NULL)
pbw = atoi (opt);
if ((opt = XGetDefault(name, "MakeWindow.InternalBorder")) != NULL)
ibw = atoi (opt);
if ((opt = XGetDefault(name, "MakeWindow.Freeze")) != NULL)
if (strcmp (opt, "on") == 0) freeze = 1;
if (DisplayPlanes() > 2) { /* on color display, do color stuff */
if ((opt = XGetDefault(name,"MakeWindow.Foreground")) != NULL)
if (XParseColor(opt, &cdef) && XGetHardwareColor(&cdef))
pfore = cdef.pixel;
if ((opt = XGetDefault(name,"MakeWindow.Background")) != NULL)
if (XParseColor(opt, &cdef) && XGetHardwareColor(&cdef))
pback = cdef.pixel;
if ((opt = XGetDefault(name,"MakeWindow.Border")) != NULL)
if (XParseColor(opt, &cdef) && XGetHardwareColor(&cdef))
bpix = cdef.pixel;
if ((opt = XGetDefault(name,"MakeWindow.Mouse")) != NULL)
if (XParseColor(opt, &cdef) && XGetHardwareColor(&cdef))
mfore = cdef.pixel;
if ((opt = XGetDefault(name,"MakeWindow.MouseMask")) != NULL)
if (XParseColor(opt, &cdef) && XGetHardwareColor(&cdef))
mback = cdef.pixel;
}
cr = XCreateCursor (cross_width, cross_height, cross_bits,
cross_mask_bits, cross_x_hot, cross_y_hot,
mfore, mback, GXcopy);
events = ButtonPressed | ButtonReleased;
if (freeze) events |= MouseMoved;
/*
* go get the mouse as soon as you can
*/
while (1) {
if (XGrabMouse ( RootWindow, cr, events ) != 0) break;
sleep (1);
}
popw = XStringWidth (prompt, pfninfo, 0, 0) + 2 * ibw;
poph = pfninfo->height + 2 * ibw;
if (freeze) {
XGrabServer();
count = FCOUNT;
save = XPixmapSave (RootWindow, 0, 0,
popw + 2 * pbw, poph +2 * pbw);
}
backmap = XMakeTile (pback);
bdrmap = XMakeTile (bpix);
pop = XCreateWindow (RootWindow,
0, 0, popw, poph, pbw, bdrmap, backmap);
XMapWindow( pop);
XText (pop, ibw, ibw, prompt, strlen(prompt),
pfninfo->id, pfore, pback);
XQueryMouse (RootWindow, &x1, &y1, &subw);
mindim = 2 * frame->bdrwidth - 1;
minwidth = minwidth + mindim;
minheight = minheight + mindim;
x2 = x1 + minwidth;
y2 = y1 + minheight;
width = minwidth;
height = minheight;
left = TRUE;
force = FALSE;
stop = FALSE;
mouse = TRUE;
xa = ya = xb = yb = -1;
doit = TRUE;
while (stop == FALSE) {
if ( (xb != max (x1, x2)) || (yb != max(y1, y2))
||(xa != min (x1, x2)) || (ya != min(y1, y2))) {
if (freeze && (doit == FALSE)) {
XDraw (RootWindow, box, count, 1, 1, 0, GXinvert, 1);
}
xa = min (x1, x2);
ya = min (y1, y2);
xb = max (x1, x2);
yb = max (y1, y2);
for ( i = 0; i < count; i += 4) {
box[i].x = xa; box[i].y = ya; box[i].flags = 0;
if (i+1 == count) break;
box[i+1].x = xb; box[i+1].y = ya, box[i+1].flags = 0;
box[i+2].x = xb; box[i+2].y = yb, box[i+2].flags = 0;
box[i+3].x = xa; box[i+3].y = yb, box[i+3].flags = 0;
}
doit = TRUE;
}
if (doit) {
XDraw(RootWindow, box, count, 1, 1, 0, GXinvert, 1);
doit = !freeze;
}
if (freeze || XPending() ) {
register int button;
XNextEvent(&event);
button = event.detail & ValueMask;
if (mouse) {
x2 = event.x;
y2 = event.y;
}
if ( (left == TRUE) && ( event.type == ButtonPressed ) &&
( button == MiddleButton ) ) {
x1 = x2;
y1 = y2;
left = FALSE;
}
else if ( (left == FALSE) && (event.type == ButtonReleased) &&
( button == MiddleButton))
stop = TRUE;
else if ( (left == TRUE) && (event.type == ButtonPressed) &&
( button == LeftButton)) {
x1 = frame->x;
y1 = frame->y;
x2 = x1 + frame->width + mindim;
y2 = y1 + frame->height + mindim;
mouse = FALSE;
left = FALSE;
}
else if ( (left == FALSE) && (event.type == ButtonReleased) &&
( button == LeftButton)) {
x1 = frame->x;
y1 = frame->y;
x2 = x1 + frame->width + mindim;
y2 = y1 + frame->height + mindim;
stop = TRUE;
}
else if ( (left == TRUE) && (event.type == ButtonPressed) &&
( button == RightButton)) {
force = TRUE;
left = FALSE;
}
else if ( (left == FALSE) && (event.type == ButtonReleased) &&
( button == RightButton)) {
stop = TRUE;
}
else if (mouse) XQueryMouse (RootWindow, &x2, &y2, &subw);
}
else if (mouse) XQueryMouse (RootWindow, &x2, &y2, &subw);
if (force) { /* we force the default box */
x1 = x2;
y1 = y2;
x2 = x1 + frame->width + mindim;
y2 = y1 + frame->height + mindim;
}
if (left) {
x1 = x2;
y1 = y2;
}
width = max (abs (x2 - x1), minwidth);
if (x2 < x1) x2 = x1 - width;
else x2 = x1 + width;
height = max (abs (y2 - y1), minheight);
if (y2 < y1) y2 = y1 - height;
else y2 = y1 + height;
}
if (freeze) XDraw (RootWindow, box, count, 1, 1, 0, GXinvert, 1);
XUngrabMouse();
if (save != 0) {
XUnmapTransparent (pop);
XPixmapPut (RootWindow, 0, 0, 0, 0,
popw + 2 * pbw, poph + 2 * pbw,
save, GXcopy, AllPlanes);
XFreePixmap (save);
}
XDestroyWindow (pop);
if (freeze) XUngrabServer();
XCloseFont (pfninfo);
XFreeCursor (cr);
XFreePixmap (backmap);
XFreePixmap (bdrmap);
frame->x = min(x1, x2);
frame->y = min(y1, y2);
frame->width = width - mindim;
frame->height = height - mindim;
makeit: XCreateWindows(RootWindow, frame, 1);
/* store default name of the window and set the resize hint */
XStoreName(frame->self, prompt);
XSetResizeHint(frame->self, minwidth, minheight, 1, 1);
XSync(1); /* get rid of any extraneous events */
return (frame->self);
}
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.