1a96d7823Smrg/*
2a96d7823Smrg
3a96d7823SmrgCopyright 1990, 1994, 1998  The Open Group
4a96d7823Smrg
5a96d7823SmrgPermission to use, copy, modify, distribute, and sell this software and its
6a96d7823Smrgdocumentation for any purpose is hereby granted without fee, provided that
7a96d7823Smrgthe above copyright notice appear in all copies and that both that
8a96d7823Smrgcopyright notice and this permission notice appear in supporting
9a96d7823Smrgdocumentation.
10a96d7823Smrg
11a96d7823SmrgThe above copyright notice and this permission notice shall be included in
12a96d7823Smrgall copies or substantial portions of the Software.
13a96d7823Smrg
14a96d7823SmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15a96d7823SmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16a96d7823SmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
17a96d7823SmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
18a96d7823SmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
19a96d7823SmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
20a96d7823Smrg
21a96d7823SmrgExcept as contained in this notice, the name of The Open Group shall not be
22a96d7823Smrgused in advertising or otherwise to promote the sale, use or other dealings
23a96d7823Smrgin this Software without prior written authorization from The Open Group.
24a96d7823Smrg
25a96d7823Smrg*/
26a96d7823Smrg
27a96d7823Smrg/*
28a96d7823Smrg * Author:  Keith Packard, MIT X Consortium
29a96d7823Smrg */
30a96d7823Smrg
31a96d7823Smrg#ifdef HAVE_CONFIG_H
32a96d7823Smrg#include <config.h>
33a96d7823Smrg#endif
34a96d7823Smrg#include "libxfontint.h"
35a96d7823Smrg#include <X11/fonts/fontmisc.h>
36a96d7823Smrg
379c9cb266Smrg/* Utility functions for reformatting font bitmaps */
38a96d7823Smrg
39a96d7823Smrgstatic const unsigned char _reverse_byte[0x100] = {
40a96d7823Smrg	0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0,
41a96d7823Smrg	0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0,
42a96d7823Smrg	0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8,
43a96d7823Smrg	0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8,
44a96d7823Smrg	0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4,
45a96d7823Smrg	0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4,
46a96d7823Smrg	0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec,
47a96d7823Smrg	0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc,
48a96d7823Smrg	0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2,
49a96d7823Smrg	0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2,
50a96d7823Smrg	0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea,
51a96d7823Smrg	0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa,
52a96d7823Smrg	0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6,
53a96d7823Smrg	0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6,
54a96d7823Smrg	0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee,
55a96d7823Smrg	0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe,
56a96d7823Smrg	0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1,
57a96d7823Smrg	0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1,
58a96d7823Smrg	0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9,
59a96d7823Smrg	0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9,
60a96d7823Smrg	0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5,
61a96d7823Smrg	0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5,
62a96d7823Smrg	0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed,
63a96d7823Smrg	0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd,
64a96d7823Smrg	0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3,
65a96d7823Smrg	0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3,
66a96d7823Smrg	0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb,
67a96d7823Smrg	0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb,
68a96d7823Smrg	0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7,
69a96d7823Smrg	0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7,
70a96d7823Smrg	0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef,
71a96d7823Smrg	0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff
72a96d7823Smrg};
73a96d7823Smrg
74a96d7823Smrg/*
75a96d7823Smrg *	Invert bit order within each BYTE of an array.
76a96d7823Smrg */
77a96d7823Smrgvoid
78a96d7823SmrgBitOrderInvert(unsigned char *buf, int nbytes)
79a96d7823Smrg{
80a96d7823Smrg    const unsigned char *rev = _reverse_byte;
81a96d7823Smrg
82a96d7823Smrg    for (; --nbytes >= 0; buf++)
83a96d7823Smrg	*buf = rev[*buf];
84a96d7823Smrg}
85a96d7823Smrg
86a96d7823Smrg/*
87a96d7823Smrg *	Invert byte order within each 16-bits of an array.
88a96d7823Smrg */
89a96d7823Smrgvoid
90a96d7823SmrgTwoByteSwap(unsigned char *buf, int nbytes)
91a96d7823Smrg{
92a96d7823Smrg    unsigned char c;
93a96d7823Smrg
94a96d7823Smrg    for (; nbytes > 0; nbytes -= 2, buf += 2)
95a96d7823Smrg    {
96a96d7823Smrg	c = buf[0];
97a96d7823Smrg	buf[0] = buf[1];
98a96d7823Smrg	buf[1] = c;
99a96d7823Smrg    }
100a96d7823Smrg}
101a96d7823Smrg
102a96d7823Smrg/*
103a96d7823Smrg *	Invert byte order within each 32-bits of an array.
104a96d7823Smrg */
105a96d7823Smrgvoid
106a96d7823SmrgFourByteSwap(unsigned char *buf, int nbytes)
107a96d7823Smrg{
108a96d7823Smrg    unsigned char c;
109a96d7823Smrg
110a96d7823Smrg    for (; nbytes > 0; nbytes -= 4, buf += 4)
111a96d7823Smrg    {
112a96d7823Smrg	c = buf[0];
113a96d7823Smrg	buf[0] = buf[3];
114a96d7823Smrg	buf[3] = c;
115a96d7823Smrg	c = buf[1];
116a96d7823Smrg	buf[1] = buf[2];
117a96d7823Smrg	buf[2] = c;
118a96d7823Smrg    }
119a96d7823Smrg}
120a96d7823Smrg
121a96d7823Smrg/*
122a96d7823Smrg *	Repad a bitmap
123a96d7823Smrg */
124a96d7823Smrg
125a96d7823Smrgint
126a96d7823SmrgRepadBitmap (char *pSrc, char *pDst,
127a96d7823Smrg	     unsigned int srcPad, unsigned int dstPad,
128a96d7823Smrg	     int width, int height)
129a96d7823Smrg{
130a96d7823Smrg    int	    srcWidthBytes,dstWidthBytes;
131a96d7823Smrg    int	    row,col;
132a96d7823Smrg    char    *pTmpSrc,*pTmpDst;
133a96d7823Smrg
134a96d7823Smrg    switch (srcPad) {
135a96d7823Smrg    case 1:
136a96d7823Smrg	srcWidthBytes = (width+7)>>3;
137a96d7823Smrg	break;
138a96d7823Smrg    case 2:
139a96d7823Smrg	srcWidthBytes = ((width+15)>>4)<<1;
140a96d7823Smrg	break;
141a96d7823Smrg    case 4:
142a96d7823Smrg	srcWidthBytes = ((width+31)>>5)<<2;
143a96d7823Smrg	break;
144a96d7823Smrg    case 8:
145a96d7823Smrg	srcWidthBytes = ((width+63)>>6)<<3;
146a96d7823Smrg	break;
147a96d7823Smrg    default:
148a96d7823Smrg	return 0;
149a96d7823Smrg    }
150a96d7823Smrg    switch (dstPad) {
151a96d7823Smrg    case 1:
152a96d7823Smrg	dstWidthBytes = (width+7)>>3;
153a96d7823Smrg	break;
154a96d7823Smrg    case 2:
155a96d7823Smrg	dstWidthBytes = ((width+15)>>4)<<1;
156a96d7823Smrg	break;
157a96d7823Smrg    case 4:
158a96d7823Smrg	dstWidthBytes = ((width+31)>>5)<<2;
159a96d7823Smrg	break;
160a96d7823Smrg    case 8:
161a96d7823Smrg	dstWidthBytes = ((width+63)>>6)<<3;
162a96d7823Smrg	break;
163a96d7823Smrg    default:
164a96d7823Smrg	return 0;
165a96d7823Smrg    }
166a96d7823Smrg
167a96d7823Smrg    width = srcWidthBytes;
168a96d7823Smrg    if (width > dstWidthBytes)
169a96d7823Smrg	width = dstWidthBytes;
170a96d7823Smrg    pTmpSrc= pSrc;
171a96d7823Smrg    pTmpDst= pDst;
172a96d7823Smrg    for (row = 0; row < height; row++)
173a96d7823Smrg    {
174a96d7823Smrg	for (col = 0; col < width; col++)
175a96d7823Smrg	    *pTmpDst++ = *pTmpSrc++;
176a96d7823Smrg	while (col < dstWidthBytes)
177a96d7823Smrg 	{
178a96d7823Smrg	    *pTmpDst++ = '\0';
179a96d7823Smrg	    col++;
180a96d7823Smrg	}
181a96d7823Smrg	pTmpSrc += srcWidthBytes - width;
182a96d7823Smrg    }
183a96d7823Smrg    return dstWidthBytes * height;
184a96d7823Smrg}
185a96d7823Smrg
186a96d7823Smrg
187