92 |
#define PROP_MOTIF_WM_HINTS_ELEMENTS 5 |
#define PROP_MOTIF_WM_HINTS_ELEMENTS 5 |
93 |
typedef struct |
typedef struct |
94 |
{ |
{ |
95 |
uint32 flags; |
unsigned long flags; |
96 |
uint32 functions; |
unsigned long functions; |
97 |
uint32 decorations; |
unsigned long decorations; |
98 |
sint32 inputMode; |
long inputMode; |
99 |
uint32 status; |
unsigned long status; |
100 |
} |
} |
101 |
PropMotifWmHints; |
PropMotifWmHints; |
102 |
|
|
138 |
XDrawArc(g_display, g_backstore, g_gc, x, y, cx, cy, 0, 360*64); \ |
XDrawArc(g_display, g_backstore, g_gc, x, y, cx, cy, 0, 360*64); \ |
139 |
break; \ |
break; \ |
140 |
case 1: /* Filled */ \ |
case 1: /* Filled */ \ |
141 |
XFillArc(g_display, g_ownbackstore ? g_backstore : g_wnd, g_gc, x, y, \ |
XFillArc(g_display, g_wnd, g_gc, x, y, cx, cy, 0, 360*64); \ |
|
cx, cy, 0, 360*64); \ |
|
142 |
if (g_ownbackstore) \ |
if (g_ownbackstore) \ |
143 |
XCopyArea(g_display, g_backstore, g_wnd, g_gc, x, y, cx, cy, x, y); \ |
XFillArc(g_display, g_backstore, g_gc, x, y, cx, cy, 0, 360*64); \ |
144 |
break; \ |
break; \ |
145 |
} \ |
} \ |
146 |
} |
} |
802 |
#else |
#else |
803 |
REPEAT4 |
REPEAT4 |
804 |
( |
( |
805 |
*((uint32 *) out) = *((uint32 *) data); |
/* Only read 3 bytes. Reading 4 bytes means reading beyond buffer. */ |
806 |
out += 4; |
*((uint32 *) out) = *((uint16 *) data) + (*((uint8 *) data + 2) << 16); |
807 |
data += 3; |
out += 4; |
808 |
|
data += 3; |
809 |
) |
) |
810 |
#endif |
#endif |
811 |
/* *INDENT-ON* */ |
/* *INDENT-ON* */ |
2446 |
switch (text[i]) |
switch (text[i]) |
2447 |
{ |
{ |
2448 |
case 0xff: |
case 0xff: |
2449 |
if (i + 2 < length) |
/* At least two bytes needs to follow */ |
2450 |
cache_put_text(text[i + 1], text, text[i + 2]); |
if (i + 3 > length) |
|
else |
|
2451 |
{ |
{ |
2452 |
error("this shouldn't be happening\n"); |
warning("Skipping short 0xff command:"); |
2453 |
exit(1); |
for (j = 0; j < length; j++) |
2454 |
|
fprintf(stderr, "%02x ", text[j]); |
2455 |
|
fprintf(stderr, "\n"); |
2456 |
|
i = length = 0; |
2457 |
|
break; |
2458 |
} |
} |
2459 |
|
cache_put_text(text[i + 1], text, text[i + 2]); |
2460 |
|
i += 3; |
2461 |
|
length -= i; |
2462 |
/* this will move pointer from start to first character after FF command */ |
/* this will move pointer from start to first character after FF command */ |
2463 |
length -= i + 3; |
text = &(text[i]); |
|
text = &(text[i + 3]); |
|
2464 |
i = 0; |
i = 0; |
2465 |
break; |
break; |
2466 |
|
|
2467 |
case 0xfe: |
case 0xfe: |
2468 |
|
/* At least one byte needs to follow */ |
2469 |
|
if (i + 2 > length) |
2470 |
|
{ |
2471 |
|
warning("Skipping short 0xfe command:"); |
2472 |
|
for (j = 0; j < length; j++) |
2473 |
|
fprintf(stderr, "%02x ", text[j]); |
2474 |
|
fprintf(stderr, "\n"); |
2475 |
|
i = length = 0; |
2476 |
|
break; |
2477 |
|
} |
2478 |
entry = cache_get_text(text[i + 1]); |
entry = cache_get_text(text[i + 1]); |
2479 |
if (entry != NULL) |
if (entry->data != NULL) |
2480 |
{ |
{ |
2481 |
if ((((uint8 *) (entry->data))[1] == |
if ((((uint8 *) (entry->data))[1] == 0) |
2482 |
0) && (!(flags & TEXT2_IMPLICIT_X))) |
&& (!(flags & TEXT2_IMPLICIT_X)) && (i + 2 < length)) |
2483 |
{ |
{ |
2484 |
if (flags & TEXT2_VERTICAL) |
if (flags & TEXT2_VERTICAL) |
2485 |
y += text[i + 2]; |
y += text[i + 2]; |