First public contribution.
1 // Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
18 EffRead::EffRead(fstream& aFile,FontCompiler& aFontCompiler,Fxf* aFxf,short int* aMapSpace):
19 FontRead(aFile,aFontCompiler,aFxf),
23 int EffRead::ReadFont()
27 char* outbuffer[(MAX_CHAR_WID+7)>>3];
33 LetterTableData lettertabledata;
34 LetterData letterdata;
39 int FileSize,FontNameOffs,VariousDataOffs,LetterOffs,LetterOffsBase,seekpos;
40 unsigned short int* pDest;
41 unsigned short int* pSrc;
42 EffVariousData VariousData;
44 char* inBuffer=new char[((MAX_CHAR_WID+7)>>3)*MAX_HEIGHT];
45 if(!inBuffer) return(NoMemory);
46 iInputFile.read((char*)&FileSize,4);
47 iInputFile.read((char*)&FontNameOffs,4);
48 iInputFile.read((char*)&VariousDataOffs,4);
49 iInputFile.read((char*)&VariousDataOffs,4);
50 iInputFile.read((char*)&LetterOffs,4);
51 iInputFile.seekg(FontNameOffs);
53 char tmpName[FONT_NAME_LEN+1];
54 iInputFile.read(tmpName,FONT_NAME_LEN);
55 tmpName[FONT_NAME_LEN]=0;
56 strcpy(iFxf->name,tmpName);
59 iInputFile.seekg(VariousDataOffs);
60 iInputFile.read((char*)&VariousData,sizeof(VariousData));
61 version=VariousData.version;
62 if(version==0) version=1;
63 if(version!=1 && version!=2) return(FileFormat);
64 pFxf=new FcmCharHead[MAX_CHARS];
65 for(count=0;count<sizeof(FcmCharHead)*MAX_CHARS;count++)
66 ((char*)pFxf)[count]=0;
69 LetterOffsBase=LetterOffs;
70 iFxf->descent= -VariousData.bly;
71 iFxf->UlinePos= -VariousData.UnderLinePos-VariousData.UnderLineThickness;
72 iFxf->UlineThickness=VariousData.UnderLineThickness;
73 iFxf->nominal_ascent=(VariousData.Hgt/*+VariousData.LineSpacing*/)-iFxf->descent;
75 iFxf->cell_height=VariousData.Hgt;
76 for(unsigned int chNum=0;chNum<MAX_CHARS;chNum++)
79 iInputFile.seekg((*(iMapSpace+chNum)<<2)+LetterOffsBase);
81 iInputFile.seekg(LetterOffs);
82 iInputFile.read((char*)&lettertabledata,sizeof(LetterTableData));
85 lettertabledata.width>>=4;
86 iInputFile.read((char*)&letterdata,sizeof(LetterData));
87 LetterOffs+=sizeof(LetterData);
89 LetterOffs+=sizeof(LetterTableData);
91 // char 0 in EFF fonts have a garbage offset so ignore them.
92 // if(letterdata.offset)
93 if(lettertabledata.offset && chNum>0)
95 seekpos=LetterOffsBase+lettertabledata.offset;
96 iInputFile.seekg(seekpos);
98 iInputFile.read((char*)&letterdata,sizeof(LetterData));
101 iFxf->FirstChr=chNum;
104 iFxf->n_chars=chNum+1;
105 iFxf->chr[chNum]=pFxf;
107 pFxf->xOffset=letterdata.blx;
108 pFxf->yOffset=letterdata.rHgt+letterdata.bly;
109 pFxf->width=letterdata.rWid;
111 widthofi=pFxf->width;
113 widthofM=pFxf->width;
114 pFxf->ByteWid=((pFxf->width+15)>>3)&(~1);
115 pFxf->height=letterdata.rHgt;
116 pFxf->move=lettertabledata.width;
117 int chWid=letterdata.rWid;
118 if(chWid>iFxf->MaxChrWidth)
119 iFxf->MaxChrWidth=chWid;
120 ReadSize=(letterdata.rWid*letterdata.rHgt+7)>>3;
121 iInputFile.read(inBuffer,ReadSize);
123 pSrc=(unsigned short int*)inBuffer;
124 for(int i=0;i<letterdata.rHgt;i++)
126 pDest=(unsigned short int*)outbuffer;
127 for(int j=0;j<pFxf->ByteWid;j+=2)
130 *pDest=(unsigned short int)((*pSrc)>>bitpos);
131 widToGo=letterdata.rWid-(j<<3);
140 if ((len1+bitpos)>widToGo)
145 *pDest|= (*pSrc)<<(16-bitpos);
147 *pDest&=0xFFFF>>(16-len2-len1);
148 bitpos=(bitpos+len1+len2)&0xF;
151 memcpy(iFontCompiler->FontStore()+offset+pFxf->ByteWid*(letterdata.rHgt-i-1),outbuffer,pFxf->ByteWid);
153 offset+=pFxf->ByteWid*letterdata.rHgt;
157 if(widthofi && widthofM)
158 iFxf->iProportional=(widthofi!=widthofM);