lcd/render.c: save 56 bytes

Introduce a utility function that reads a single byte from the current position
in the font file.
This commit is contained in:
Øyvind Kolås 2011-08-03 14:53:04 +01:00 committed by Stefan `Sec` Zehl
parent 81294835ec
commit ad0c993136

View file

@ -8,6 +8,7 @@
#include "fonts/smallfonts.h" #include "fonts/smallfonts.h"
#include "filesystem/ff.h" #include "filesystem/ff.h"
#include "render.h"
/* Global Variables */ /* Global Variables */
const struct FONT_DEF * font = NULL; const struct FONT_DEF * font = NULL;
@ -36,10 +37,17 @@ void setExtFont(const char *fname){
int getFontHeight(void){ int getFontHeight(void){
if(font) if(font)
return font->u8Height; return font->u8Height;
return 8; // XXX: Should be done right. return 8; // XXX: Should be done right.
}; };
static uint8_t read_byte (void)
{
UINT readbytes;
uint8_t byte;
f_read(&file, &byte, sizeof(uint8_t), &readbytes);
return byte;
}
int _getFontData(int type, int offset){ int _getFontData(int type, int offset){
UINT readbytes; UINT readbytes;
@ -51,10 +59,10 @@ int _getFontData(int type, int offset){
if(efont.type == FONT_EXTERNAL){ if(efont.type == FONT_EXTERNAL){
if (type == START_FONT){ if (type == START_FONT){
res = f_read(&file, &efont.def.u8Width, sizeof(uint8_t), &readbytes); efont.def.u8Width = read_byte ();
res = f_read(&file, &efont.def.u8Height, sizeof(uint8_t), &readbytes); efont.def.u8Height = read_byte ();
res = f_read(&file, &efont.def.u8FirstChar, sizeof(uint8_t), &readbytes); efont.def.u8FirstChar = read_byte ();
res = f_read(&file, &efont.def.u8LastChar, sizeof(uint8_t), &readbytes); efont.def.u8LastChar = read_byte ();
res = f_read(&file, &extras, sizeof(uint16_t), &readbytes); res = f_read(&file, &extras, sizeof(uint16_t), &readbytes);
return 0; return 0;
}; };
@ -72,9 +80,7 @@ int _getFontData(int type, int offset){
return 0; return 0;
}; };
if(type == GET_WIDTH || type == GET_DATA){ if(type == GET_WIDTH || type == GET_DATA){
uint8_t width; return read_byte ();
res = f_read(&file, &width, sizeof(uint8_t), &readbytes);
return width;
}; };
if(type == SEEK_DATA){ if(type == SEEK_DATA){
character=offset; character=offset;
@ -87,7 +93,7 @@ int _getFontData(int type, int offset){
}; };
if(type == PEEK_DATA){ if(type == PEEK_DATA){
uint8_t width; uint8_t width;
res = f_read(&file, &width, sizeof(uint8_t), &readbytes); width = read_byte ();
f_lseek(&file,6+ f_lseek(&file,6+
(extras*sizeof(uint16_t))+ (extras*sizeof(uint16_t))+
((extras+font->u8LastChar-font->u8FirstChar)*sizeof(uint8_t))+ ((extras+font->u8LastChar-font->u8FirstChar)*sizeof(uint8_t))+
@ -240,10 +246,10 @@ int DoChar(int sx, int sy, int c){
UINT res; UINT res;
UINT readbytes; UINT readbytes;
uint8_t testbyte; uint8_t testbyte;
res = f_read(&file, &testbyte, sizeof(uint8_t), &readbytes); testbyte = read_byte ();
if(testbyte>>4 ==15){ if(testbyte>>4 ==15){
res = f_read(&file, &preblank, sizeof(uint8_t), &readbytes); preblank = read_byte ();
res = f_read(&file, &postblank, sizeof(uint8_t), &readbytes); postblank = read_byte ();
width-=3; width-=3;
width/=height; width/=height;
res = f_read(&file, charBuf, width*height, &readbytes); res = f_read(&file, charBuf, width*height, &readbytes);