1a96d7823Smrg/*
2a96d7823Smrg
3a96d7823SmrgCopyright 1991, 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
36a96d7823Smrg#include <X11/fonts/fntfilst.h>
37a96d7823Smrg#include <X11/fonts/bitmap.h>
38a96d7823Smrg
39a96d7823Smrgint
40a96d7823SmrgbitmapGetGlyphs(FontPtr pFont, unsigned long count, unsigned char *chars,
41a96d7823Smrg		FontEncoding charEncoding,
42a96d7823Smrg		unsigned long *glyphCount, 	/* RETURN */
43a96d7823Smrg		CharInfoPtr *glyphs) 		/* RETURN */
44a96d7823Smrg{
45a96d7823Smrg    BitmapFontPtr  bitmapFont;
46a96d7823Smrg    unsigned int firstCol;
47a96d7823Smrg    register unsigned int numCols;
48a96d7823Smrg    unsigned int firstRow;
49a96d7823Smrg    unsigned int numRows;
50a96d7823Smrg    CharInfoPtr *glyphsBase;
51a96d7823Smrg    register unsigned int c;
52a96d7823Smrg    register CharInfoPtr pci;
53a96d7823Smrg    unsigned int r;
54a96d7823Smrg    CharInfoPtr **encoding;
55a96d7823Smrg    CharInfoPtr pDefault;
56a96d7823Smrg
57a96d7823Smrg    bitmapFont = (BitmapFontPtr) pFont->fontPrivate;
58a96d7823Smrg    encoding = bitmapFont->encoding;
59a96d7823Smrg    pDefault = bitmapFont->pDefault;
60a96d7823Smrg    firstCol = pFont->info.firstCol;
61a96d7823Smrg    numCols = pFont->info.lastCol - firstCol + 1;
62a96d7823Smrg    glyphsBase = glyphs;
63a96d7823Smrg    switch (charEncoding) {
64a96d7823Smrg
65a96d7823Smrg    case Linear8Bit:
66a96d7823Smrg    case TwoD8Bit:
67a96d7823Smrg	if (pFont->info.firstRow > 0) {
68a96d7823Smrg            if (pDefault)
69a96d7823Smrg                while (count--)
70a96d7823Smrg                    *glyphs++ = pDefault;
71a96d7823Smrg	    break;
72a96d7823Smrg        }
73a96d7823Smrg	if (pFont->info.allExist && pDefault) {
74a96d7823Smrg	    while (count--) {
75a96d7823Smrg		c = (*chars++) - firstCol;
76a96d7823Smrg		if (c < numCols)
77a96d7823Smrg		    *glyphs++ = ACCESSENCODING(encoding,c);
78a96d7823Smrg		else
79a96d7823Smrg		    *glyphs++ = pDefault;
80a96d7823Smrg	    }
81a96d7823Smrg	} else {
82a96d7823Smrg	    while (count--) {
83a96d7823Smrg		c = (*chars++) - firstCol;
84a96d7823Smrg		if (c < numCols && (pci = ACCESSENCODING(encoding,c)))
85a96d7823Smrg		    *glyphs++ = pci;
86a96d7823Smrg		else if (pDefault)
87a96d7823Smrg		    *glyphs++ = pDefault;
88a96d7823Smrg	    }
89a96d7823Smrg	}
90a96d7823Smrg	break;
91a96d7823Smrg    case Linear16Bit:
92a96d7823Smrg	if (pFont->info.allExist && pDefault) {
93a96d7823Smrg	    while (count--) {
94a96d7823Smrg		c = *chars++ << 8;
95a96d7823Smrg		c = (c | *chars++) - firstCol;
96a96d7823Smrg		if (c < numCols)
97a96d7823Smrg		    *glyphs++ = ACCESSENCODING(encoding,c);
98a96d7823Smrg		else
99a96d7823Smrg		    *glyphs++ = pDefault;
100a96d7823Smrg	    }
101a96d7823Smrg	} else {
102a96d7823Smrg	    while (count--) {
103a96d7823Smrg		c = *chars++ << 8;
104a96d7823Smrg		c = (c | *chars++) - firstCol;
105a96d7823Smrg		if (c < numCols && (pci = ACCESSENCODING(encoding,c)))
106a96d7823Smrg		    *glyphs++ = pci;
107a96d7823Smrg		else if (pDefault)
108a96d7823Smrg		    *glyphs++ = pDefault;
109a96d7823Smrg	    }
110a96d7823Smrg	}
111a96d7823Smrg	break;
112a96d7823Smrg
113a96d7823Smrg    case TwoD16Bit:
114a96d7823Smrg	firstRow = pFont->info.firstRow;
115a96d7823Smrg	numRows = pFont->info.lastRow - firstRow + 1;
116a96d7823Smrg	while (count--) {
117a96d7823Smrg	    r = (*chars++) - firstRow;
118a96d7823Smrg	    c = (*chars++) - firstCol;
119a96d7823Smrg	    if (r < numRows && c < numCols &&
120a96d7823Smrg		    (pci = ACCESSENCODING(encoding, r * numCols + c)))
121a96d7823Smrg		*glyphs++ = pci;
122a96d7823Smrg	    else if (pDefault)
123a96d7823Smrg		*glyphs++ = pDefault;
124a96d7823Smrg	}
125a96d7823Smrg	break;
126a96d7823Smrg    }
127a96d7823Smrg    *glyphCount = glyphs - glyphsBase;
128a96d7823Smrg    return Successful;
129a96d7823Smrg}
130a96d7823Smrg
131a96d7823Smrgstatic CharInfoRec nonExistantChar;
132a96d7823Smrg
133a96d7823Smrgint
134a96d7823SmrgbitmapGetMetrics(FontPtr pFont, unsigned long count, unsigned char *chars,
135a96d7823Smrg		 FontEncoding charEncoding,
136a96d7823Smrg		 unsigned long *glyphCount,	/* RETURN */
137a96d7823Smrg		 xCharInfo **glyphs)		/* RETURN */
138a96d7823Smrg{
139a96d7823Smrg    int         ret;
140a96d7823Smrg    xCharInfo  *ink_metrics;
141a96d7823Smrg    CharInfoPtr metrics;
142a96d7823Smrg    BitmapFontPtr  bitmapFont;
143a96d7823Smrg    CharInfoPtr	oldDefault;
144a96d7823Smrg    int         i;
145a96d7823Smrg
146a96d7823Smrg    bitmapFont = (BitmapFontPtr) pFont->fontPrivate;
147a96d7823Smrg    oldDefault = bitmapFont->pDefault;
148a96d7823Smrg    bitmapFont->pDefault = &nonExistantChar;
149a96d7823Smrg    ret = bitmapGetGlyphs(pFont, count, chars, charEncoding, glyphCount, (CharInfoPtr *) glyphs);
150a96d7823Smrg    if (ret == Successful) {
151a96d7823Smrg	if (bitmapFont->ink_metrics) {
152a96d7823Smrg	    metrics = bitmapFont->metrics;
153a96d7823Smrg	    ink_metrics = bitmapFont->ink_metrics;
154a96d7823Smrg	    for (i = 0; i < *glyphCount; i++) {
155a96d7823Smrg		if (glyphs[i] != (xCharInfo *) & nonExistantChar)
156a96d7823Smrg		    glyphs[i] = ink_metrics + (((CharInfoPtr) glyphs[i]) - metrics);
157a96d7823Smrg	    }
158a96d7823Smrg	}
159a96d7823Smrg    }
160a96d7823Smrg    bitmapFont->pDefault = oldDefault;
161a96d7823Smrg    return ret;
162a96d7823Smrg}
163