#define ROW8_16(n) ROW4_16(n) ROW4_16(n+4)
#define ROW16_16() ROW8_16(0) ROW8_16(8)
+#define ROW1_32(n) \
+ memcpy((char *)image, (char *)mem + (4 * 16 * (n)), 4 * 16); \
+ image = (unsigned QUAD *)(((unsigned char *)image) + lineBytes);
+
+#define ROW2_32(n) ROW1_32(n) ROW1_32(n+1)
+#define ROW4_32(n) ROW2_32(n) ROW2_32(n+2)
+#define ROW8_32(n) ROW4_32(n) ROW4_32(n+4)
+#define ROW16_32() ROW8_32(0) ROW8_32(8)
+
switch (view->x->depth) {
case 8:
case 24:
case 32:
+ ROW16_32();
+ break;
+
default:
/* XXX: handle different depths */
break;
if (tile != *ha) {
*ha = tile;
- XCopyArea(view->x->dpy, view->x->big_tile_pixmap, view->pixmap,
+ if (view->x->big_tile_pixmap) {
+ XCopyArea(view->x->dpy, view->x->big_tile_pixmap, view->pixmap,
view->x->gc, 0, tile * 16, 16, 16,
col * 16, row * 16);
+ }
}
}
map += mm;