|
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 - downloadIndex: ┃ T X ┃
Length: 1193 (0x4a9) Types: TextFile Names: »XGetColCells.c«
└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki └─ ⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« └─⟦2109abc41⟧ └─ ⟦this⟧ »./X.V10R4/Xlib/XGetColCells.c«
#include <X/mit-copyright.h> /* $Header: XGetColCells.c,v 10.5 86/04/22 15:30:25 jg Rel $ */ /* Copyright Massachusetts Institute of Technology 1985 */ #include "XlibInternal.h" Status XGetColorCells (contig, ncolors, nplanes, planes, pixels) int contig; int ncolors; int nplanes; int *planes; register int pixels[]; { register Display *dpy; register XReq *req; XRep rep; GetReq (X_GetColorCells, 0); req->func = contig; req->params0 = ncolors; req->params1 = nplanes; if (!_XReply (dpy, &rep)) { *planes = 0; return (0); } *planes = rep.paramu0; if (!ncolors) return (1); /* "pixels" is an array of ints, but the protocol * returns an array of shorts. Therefore data must be copied. */ { register int i; int nbytes = ncolors*2; #ifdef BIGSHORTS register ushort_p *proto_pixels = (ushort_p *) malloc (nbytes); _XReadPad (dpy, (char *)proto_pixels, nbytes); UnpackShorts(proto_pixels, (short *)pixels, nbytes); #else register u_short *proto_pixels = (u_short *) malloc (nbytes); _XReadPad (dpy, proto_pixels, nbytes); for (i=0;i<ncolors;i++) pixels[i] = proto_pixels[i]; #endif free ((char *)proto_pixels); return (1); } }