Merge pull request #8816 from gemu2015/scripter-string_array

scripter support for string array
This commit is contained in:
Theo Arends 2020-06-29 08:42:45 +02:00 committed by GitHub
commit 04dca1e61f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 84 additions and 12 deletions

View File

@ -363,6 +363,10 @@ struct SCRIPT_MEM {
uint8_t max_ssize; uint8_t max_ssize;
uint8_t script_loglevel; uint8_t script_loglevel;
uint8_t flags; uint8_t flags;
uint8_t si_num;
uint8_t siro_num;
char *last_index_string;
#ifdef USE_SCRIPT_FATFS #ifdef USE_SCRIPT_FATFS
File files[SFS_MAX]; File files[SFS_MAX];
FILE_FLAGS file_flags[SFS_MAX]; FILE_FLAGS file_flags[SFS_MAX];
@ -374,12 +378,15 @@ struct SCRIPT_MEM {
#endif #endif
} glob_script_mem; } glob_script_mem;
#ifdef USE_SCRIPT_GLOBVARS #ifdef USE_SCRIPT_GLOBVARS
IPAddress last_udp_ip; IPAddress last_udp_ip;
WiFiUDP Script_PortUdp; WiFiUDP Script_PortUdp;
#endif #endif
int16_t last_findex; int16_t last_findex;
int16_t last_sindex;
uint8_t tasm_cmd_activ=0; uint8_t tasm_cmd_activ=0;
uint8_t fast_script=0; uint8_t fast_script=0;
uint8_t glob_script=0; uint8_t glob_script=0;
@ -1312,6 +1319,7 @@ char *isvar(char *lp, uint8_t *vtype,struct T_INDEX *tind,float *fp,char *sp,Jso
strcpy (dvnam,vname); strcpy (dvnam,vname);
uint8_t olen=len; uint8_t olen=len;
last_findex=-1; last_findex=-1;
last_sindex=-1;
char *ja=strchr(dvnam,'['); char *ja=strchr(dvnam,'[');
if (ja) { if (ja) {
*ja=0; *ja=0;
@ -1981,6 +1989,7 @@ chknext:
//#endif //#endif
#endif #endif
break; break;
#define MAX_SARRAY_NUM 32
case 'i': case 'i':
if (!strncmp(vname,"int(",4)) { if (!strncmp(vname,"int(",4)) {
lp=GetNumericResult(lp+4,OPER_EQU,&fvar,0); lp=GetNumericResult(lp+4,OPER_EQU,&fvar,0);
@ -1996,21 +2005,74 @@ chknext:
break; break;
} }
lp++; lp++;
char *sstr=lp;
if (glob_script_mem.si_num>0 && glob_script_mem.last_index_string) {
free(glob_script_mem.last_index_string);
}
char *sstart=lp;
uint8_t slen=0;
for (uint32_t cnt=0; cnt<256; cnt++) { for (uint32_t cnt=0; cnt<256; cnt++) {
if (lp[cnt]='\n' || lp[cnt]=='"') { if (*lp=='\n' || *lp=='"' || *lp==0) {
lp+=cnt+1; lp++;
if (cnt>0 && !slen) {
slen++;
}
glob_script_mem.siro_num=slen;
break; break;
} }
if (*lp=='|') {
slen++;
} }
char str[SCRIPT_MAXSSIZE];
GetTextIndexed(str, sizeof(str), fvar, sstr);
lp++; lp++;
if (sp) strlcpy(sp,str,glob_script_mem.max_ssize); }
glob_script_mem.si_num = fvar;
if (glob_script_mem.si_num>0) {
if (glob_script_mem.si_num>MAX_SARRAY_NUM) {
glob_script_mem.si_num=MAX_SARRAY_NUM;
}
glob_script_mem.last_index_string=(char*)calloc(glob_script_mem.max_ssize*glob_script_mem.si_num,1);
for (uint32_t cnt=0; cnt<glob_script_mem.siro_num; cnt++) {
char str[SCRIPT_MAXSSIZE];
GetTextIndexed(str, sizeof(str), cnt, sstart);
strlcpy(glob_script_mem.last_index_string+(cnt*glob_script_mem.max_ssize),str,glob_script_mem.max_ssize);
}
} else {
glob_script_mem.last_index_string=sstart;
}
lp++;
fvar=0; fvar=0;
len=0; len=0;
goto exit; goto exit;
} }
if (!strncmp(vname,"is[",3)) {
lp=GetNumericResult(lp+3,OPER_EQU,&fvar,0);
SCRIPT_SKIP_SPACES
char str[SCRIPT_MAXSSIZE];
str[0]=0;
uint8_t index=fvar;
if (index<1) index=1;
index--;
last_sindex = index;
if (glob_script_mem.last_index_string) {
if (!glob_script_mem.si_num) {
if (index<=glob_script_mem.siro_num) {
GetTextIndexed(str, sizeof(str), index , glob_script_mem.last_index_string);
}
} else {
if (index>glob_script_mem.si_num) {
fvar=glob_script_mem.si_num;
}
strlcpy(str,glob_script_mem.last_index_string+(index*glob_script_mem.max_ssize),glob_script_mem.max_ssize);
}
}
lp++;
if (sp) strlcpy(sp,str,glob_script_mem.max_ssize);
len=0;
goto strexit;
}
break; break;
case 'l': case 'l':
if (!strncmp(vname,"lip",3)) { if (!strncmp(vname,"lip",3)) {
@ -3219,7 +3281,7 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
uint8_t vtype=0,sindex,xflg,floop=0,globvindex,fromscriptcmd=0; uint8_t vtype=0,sindex,xflg,floop=0,globvindex,fromscriptcmd=0;
char *lp_next; char *lp_next;
int8_t globaindex; int8_t globaindex,saindex;
struct T_INDEX ind; struct T_INDEX ind;
uint8_t operand,lastop,numeric=1,if_state[IF_NEST],if_exe[IF_NEST],if_result[IF_NEST],and_or,ifstck=0; uint8_t operand,lastop,numeric=1,if_state[IF_NEST],if_exe[IF_NEST],if_result[IF_NEST],and_or,ifstck=0;
if_state[ifstck]=0; if_state[ifstck]=0;
@ -3778,6 +3840,7 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
// string result // string result
numeric=0; numeric=0;
sindex=index; sindex=index;
saindex=last_sindex;
// string result // string result
char str[SCRIPT_MAXSSIZE]; char str[SCRIPT_MAXSSIZE];
lp=getop(lp,&lastop); lp=getop(lp,&lastop);
@ -3799,6 +3862,14 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
script_udp_sendvar(varname,0,str); script_udp_sendvar(varname,0,str);
} }
#endif #endif
if (saindex>=0) {
if (lastop==OPER_EQU) {
strlcpy(glob_script_mem.last_index_string+(saindex*glob_script_mem.max_ssize),str,glob_script_mem.max_ssize);
} else if (lastop==OPER_PLSEQU) {
strncat(glob_script_mem.last_index_string+(saindex*glob_script_mem.max_ssize),str,glob_script_mem.max_ssize);
}
last_sindex=-1;
} else {
if (lastop==OPER_EQU) { if (lastop==OPER_EQU) {
strlcpy(glob_script_mem.glob_snp+(sindex*glob_script_mem.max_ssize),str,glob_script_mem.max_ssize); strlcpy(glob_script_mem.glob_snp+(sindex*glob_script_mem.max_ssize),str,glob_script_mem.max_ssize);
} else if (lastop==OPER_PLSEQU) { } else if (lastop==OPER_PLSEQU) {
@ -3806,6 +3877,7 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
} }
} }
} }
}
} }
SCRIPT_SKIP_SPACES SCRIPT_SKIP_SPACES
@ -5494,7 +5566,6 @@ void ScriptGetSDCard(void) {
} }
HandleNotFound(); HandleNotFound();
} }
#endif // USE_SCRIPT_FATFS
void SendFile(char *fname) { void SendFile(char *fname) {
char buff[512]; char buff[512];
@ -5528,6 +5599,7 @@ char buff[512];
Webserver->client().stop(); Webserver->client().stop();
} }
#endif // USE_SCRIPT_FATFS
void ScriptFullWebpage(void) { void ScriptFullWebpage(void) {
uint32_t fullpage_refresh=10000; uint32_t fullpage_refresh=10000;