Support l0dable nickname display.
This commit is contained in:
parent
1091daeb9d
commit
16da194336
7 changed files with 46 additions and 12 deletions
|
@ -16,7 +16,20 @@
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
|
void simpleNickname(void);
|
||||||
|
|
||||||
void fancyNickname(void) {
|
void fancyNickname(void) {
|
||||||
|
if(GLOBAL(l0nick)){
|
||||||
|
if(execute_file(GLOBAL(nickl0),0,0))
|
||||||
|
GLOBAL(l0nick)=0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!GLOBAL(l0nick))
|
||||||
|
simpleNickname();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
void simpleNickname(void) {
|
||||||
int dx=0;
|
int dx=0;
|
||||||
int dy=0;
|
int dy=0;
|
||||||
static uint32_t ctr=0;
|
static uint32_t ctr=0;
|
||||||
|
@ -44,6 +57,7 @@ void fancyNickname(void) {
|
||||||
void init_nick(void){
|
void init_nick(void){
|
||||||
readFile("nick.cfg",GLOBAL(nickname),MAXNICK);
|
readFile("nick.cfg",GLOBAL(nickname),MAXNICK);
|
||||||
readFile("font.cfg",GLOBAL(nickfont),FILENAMELEN);
|
readFile("font.cfg",GLOBAL(nickfont),FILENAMELEN);
|
||||||
|
readFile("l0nick.cfg",GLOBAL(nickl0),FILENAMELEN);
|
||||||
};
|
};
|
||||||
|
|
||||||
//# MENU nick editNick
|
//# MENU nick editNick
|
||||||
|
@ -71,3 +85,16 @@ void doFont(void){
|
||||||
setIntFont(&Font_7x8);
|
setIntFont(&Font_7x8);
|
||||||
while(!getInputRaw())delayms(10);
|
while(!getInputRaw())delayms(10);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//# MENU nick chooseAnim
|
||||||
|
void doAnim(void){
|
||||||
|
getInputWaitRelease();
|
||||||
|
if( selectFile(GLOBAL(nickl0),"NIK") != 0){
|
||||||
|
lcdPrintln("No file selected.");
|
||||||
|
GLOBAL(l0nick)=0;
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
writeFile("l0nick.cfg",GLOBAL(nickl0),strlen(GLOBAL(nickl0)));
|
||||||
|
GLOBAL(l0nick)=1;
|
||||||
|
getInputWaitRelease();
|
||||||
|
};
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
#include "basic/random.h"
|
#include "basic/random.h"
|
||||||
#include "basic/config.h"
|
#include "basic/config.h"
|
||||||
|
|
||||||
#define CFGVER 2
|
#define CFGVER 3
|
||||||
|
|
||||||
struct CDESC the_config[]= {
|
struct CDESC the_config[]= {
|
||||||
{"version", CFGVER, CFGVER, CFGVER, 0, 0},
|
{"version", CFGVER, CFGVER, CFGVER, 0, 0},
|
||||||
|
@ -27,11 +27,13 @@ struct CDESC the_config[]= {
|
||||||
{"flamespeed", 1, 1, 100, 1, CFG_TYPE_FLAME},
|
{"flamespeed", 1, 1, 100, 1, CFG_TYPE_FLAME},
|
||||||
{"flamemaxw", 255, 1, 255, 1, CFG_TYPE_FLAME},
|
{"flamemaxw", 255, 1, 255, 1, CFG_TYPE_FLAME},
|
||||||
{"flameminw", 0x8f, 1, 255, 1, CFG_TYPE_FLAME},
|
{"flameminw", 0x8f, 1, 255, 1, CFG_TYPE_FLAME},
|
||||||
|
{"l0nick", 0, 0, 1 , 0, 0},
|
||||||
{ NULL, 0, 0, 0 , 0, 0},
|
{ NULL, 0, 0, 0 , 0, 0},
|
||||||
};
|
};
|
||||||
|
|
||||||
char nickname[MAXNICK]="anonymous";
|
char nickname[MAXNICK]="anonymous";
|
||||||
char nickfont[FILENAMELEN];
|
char nickfont[FILENAMELEN];
|
||||||
|
char nickl0[FILENAMELEN];
|
||||||
|
|
||||||
#define CONFFILE "r0ket.cfg"
|
#define CONFFILE "r0ket.cfg"
|
||||||
#define CONF_ITER for(int i=0;the_config[i].name!=NULL;i++)
|
#define CONF_ITER for(int i=0;the_config[i].name!=NULL;i++)
|
||||||
|
|
|
@ -21,8 +21,9 @@ struct CDESC {
|
||||||
|
|
||||||
#define MAXNICK 20
|
#define MAXNICK 20
|
||||||
extern struct CDESC the_config[];
|
extern struct CDESC the_config[];
|
||||||
extern char nickname[MAXNICK];
|
extern char nickname[];
|
||||||
extern char nickfont[];
|
extern char nickfont[];
|
||||||
|
extern char nickl0[];
|
||||||
|
|
||||||
#define GLOBALversion (the_config[ 0].value)
|
#define GLOBALversion (the_config[ 0].value)
|
||||||
#define GLOBALprivacy (the_config[ 1].value)
|
#define GLOBALprivacy (the_config[ 1].value)
|
||||||
|
@ -40,8 +41,10 @@ extern char nickfont[];
|
||||||
#define GLOBALflamespeed (the_config[13].value)
|
#define GLOBALflamespeed (the_config[13].value)
|
||||||
#define GLOBALflamemaxw (the_config[14].value)
|
#define GLOBALflamemaxw (the_config[14].value)
|
||||||
#define GLOBALflameminw (the_config[15].value)
|
#define GLOBALflameminw (the_config[15].value)
|
||||||
|
#define GLOBALl0nick (the_config[16].value)
|
||||||
#define GLOBALnickname (nickname)
|
#define GLOBALnickname (nickname)
|
||||||
#define GLOBALnickfont (nickfont)
|
#define GLOBALnickfont (nickfont)
|
||||||
|
#define GLOBALnickl0 (nickl0)
|
||||||
|
|
||||||
#define GLOBAL(x) GLOBAL ## x
|
#define GLOBAL(x) GLOBAL ## x
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ extern void * sram_top;
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
void execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
uint8_t execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
||||||
FRESULT res;
|
FRESULT res;
|
||||||
FIL file;
|
FIL file;
|
||||||
UINT readbytes;
|
UINT readbytes;
|
||||||
|
@ -38,7 +38,7 @@ void execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
||||||
//lcdPrintln(f_get_rc_string(res));
|
//lcdPrintln(f_get_rc_string(res));
|
||||||
//lcdRefresh();
|
//lcdRefresh();
|
||||||
if(res){
|
if(res){
|
||||||
return;
|
return -1;
|
||||||
};
|
};
|
||||||
|
|
||||||
res = f_read(&file, (char *)dst, RAMCODE, &readbytes);
|
res = f_read(&file, (char *)dst, RAMCODE, &readbytes);
|
||||||
|
@ -46,7 +46,7 @@ void execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
||||||
//lcdPrintln(f_get_rc_string(res));
|
//lcdPrintln(f_get_rc_string(res));
|
||||||
//lcdRefresh();
|
//lcdRefresh();
|
||||||
if(res){
|
if(res){
|
||||||
return;
|
return -1;
|
||||||
};
|
};
|
||||||
if( decode || checksignature )
|
if( decode || checksignature )
|
||||||
//only accept files with fixed length
|
//only accept files with fixed length
|
||||||
|
@ -55,7 +55,7 @@ void execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
||||||
lcdPrint("readbytes&3");
|
lcdPrint("readbytes&3");
|
||||||
lcdRefresh();
|
lcdRefresh();
|
||||||
while(1);
|
while(1);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
if( checksignature ){
|
if( checksignature ){
|
||||||
uint32_t mac[4];
|
uint32_t mac[4];
|
||||||
|
@ -72,7 +72,7 @@ void execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
||||||
lcdPrintIntHex(mac[3]); lcdNl();
|
lcdPrintIntHex(mac[3]); lcdNl();
|
||||||
lcdRefresh();
|
lcdRefresh();
|
||||||
while(1);
|
while(1);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
//lcdPrint("macok");
|
//lcdPrint("macok");
|
||||||
//lcdRefresh();
|
//lcdRefresh();
|
||||||
|
@ -90,6 +90,7 @@ void execute_file (const char * fname, uint8_t checksignature, uint8_t decode){
|
||||||
|
|
||||||
dst=(void (*)(void)) ((uint32_t)(dst) | 1); // Enable Thumb mode!
|
dst=(void (*)(void)) ((uint32_t)(dst) | 1); // Enable Thumb mode!
|
||||||
dst();
|
dst();
|
||||||
|
return 0;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#ifndef _EXECUTE_H_
|
#ifndef _EXECUTE_H_
|
||||||
#define _EXECUTE_H_
|
#define _EXECUTE_H_
|
||||||
|
|
||||||
void execute_file (const char * fname, uint8_t checksignature, uint8_t decode);
|
uint8_t execute_file (const char * fname, uint8_t checksignature, uint8_t decode);
|
||||||
void executeSelect(char *ext);
|
void executeSelect(char *ext);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -72,3 +72,8 @@ nrf_check_reset
|
||||||
sspSend
|
sspSend
|
||||||
sspReceive
|
sspReceive
|
||||||
sspSendReceive
|
sspSendReceive
|
||||||
|
getInputWait
|
||||||
|
lcdGetPixel
|
||||||
|
nickfont
|
||||||
|
setExtFont
|
||||||
|
getFontHeight
|
||||||
|
|
|
@ -44,10 +44,6 @@ $(LDFILE):
|
||||||
clean:
|
clean:
|
||||||
rm -f *.o *.elf *.bin usetable.h
|
rm -f *.o *.elf *.bin usetable.h
|
||||||
|
|
||||||
IDIR=/cygdrive/f
|
|
||||||
install:
|
|
||||||
for a in $(BINS) ; do f=$${a#*/};cp $$a $(IDIR)/$${f%.bin}.c0d ; done
|
|
||||||
|
|
||||||
$(OBJS): usetable.h
|
$(OBJS): usetable.h
|
||||||
|
|
||||||
usetable.h:
|
usetable.h:
|
||||||
|
|
Loading…
Reference in a new issue