2020-03-22 20:50:16 +01:00
|
|
|
enum { TAG, OPTION_VALUE, TEXT, COMMENT, SCRIPT};
|
2014-03-30 15:51:53 +02:00
|
|
|
|
2014-03-30 13:57:13 +02:00
|
|
|
dword ShowSource()
|
|
|
|
{
|
2020-03-22 20:50:16 +01:00
|
|
|
dword new_buf, new_buf_start, i, j;
|
|
|
|
int opened_font=0;
|
|
|
|
int mode = TEXT;
|
2014-03-30 13:57:13 +02:00
|
|
|
|
|
|
|
if (souce_mode) return;
|
|
|
|
souce_mode = true;
|
2014-03-31 19:14:16 +02:00
|
|
|
new_buf = malloc(bufsize*5);
|
|
|
|
new_buf_start = new_buf;
|
2015-08-27 01:45:56 +02:00
|
|
|
header[strrchr(#header, '-')-2]=0;
|
2016-12-11 23:58:11 +01:00
|
|
|
sprintf(new_buf,"<html><head><title>Source: %s</title><body><pre>",#header);
|
|
|
|
new_buf += strlen(new_buf);
|
2014-03-30 13:57:13 +02:00
|
|
|
for (i=bufpointer; i<bufpointer+bufsize; i++)
|
|
|
|
{
|
2018-10-06 00:10:27 +02:00
|
|
|
switch (ESBYTE[i])
|
2014-03-30 13:57:13 +02:00
|
|
|
{
|
|
|
|
case '<':
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == TEXT) && (!strncmp(i+1,"script", 6)) {
|
|
|
|
mode = SCRIPT;
|
|
|
|
strcpy(new_buf, "<font color=#00f><script</font><font color=#994500>"); opened_font++;
|
|
|
|
new_buf+=54;
|
|
|
|
i+=6;
|
2017-09-17 14:35:45 +02:00
|
|
|
break;
|
|
|
|
}
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == COMMENT) || (mode == SCRIPT) && (!strncmp(i+1,"/script>", 8)) {
|
|
|
|
mode = TEXT;
|
|
|
|
while (opened_font) {
|
|
|
|
strcpy(new_buf, "</font>"); opened_font--;
|
|
|
|
new_buf+=7;
|
|
|
|
}
|
|
|
|
strcpy(new_buf, "<font color=#00f></script></font>");
|
|
|
|
new_buf+=39;
|
|
|
|
i+=8;
|
2017-09-17 14:35:45 +02:00
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
2020-03-22 20:50:16 +01:00
|
|
|
if (ESBYTE[i+1]=='!') && (ESBYTE[i+2]=='-') && (ESBYTE[i+3]=='-') {
|
|
|
|
mode = COMMENT;
|
|
|
|
strcpy(new_buf, "<font color=#bbb><"); opened_font++;
|
2014-03-31 19:14:16 +02:00
|
|
|
new_buf+=21;
|
2020-03-22 20:50:16 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (mode == TEXT) {
|
2014-03-30 15:51:53 +02:00
|
|
|
mode = TAG;
|
2020-03-22 20:50:16 +01:00
|
|
|
strcpy(new_buf, "<font color=#00f><"); opened_font++;
|
|
|
|
new_buf+=21;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (mode == COMMENT) || (mode == SCRIPT) {
|
|
|
|
strcpy(new_buf, "<");
|
|
|
|
new_buf+=4;
|
2017-09-17 14:35:45 +02:00
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '>':
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == OPTION_VALUE) { //fix non-closed quote in TAG
|
|
|
|
mode = TEXT;
|
|
|
|
while (opened_font) {
|
|
|
|
strcpy(new_buf, ""</font>"); opened_font--;
|
|
|
|
new_buf+=13;
|
|
|
|
}
|
2017-09-17 14:35:45 +02:00
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == COMMENT) && (ESBYTE[i-1]=='-') && (ESBYTE[i-2]=='-') {
|
2014-03-30 15:51:53 +02:00
|
|
|
mode = TEXT;
|
2020-03-22 20:50:16 +01:00
|
|
|
strcpy(new_buf, "></font>"); opened_font--;
|
|
|
|
new_buf+=11;
|
2017-09-17 14:35:45 +02:00
|
|
|
break;
|
|
|
|
}
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == COMMENT) || (mode == SCRIPT) {
|
2017-09-17 14:35:45 +02:00
|
|
|
strcpy(new_buf, ">");
|
|
|
|
new_buf+=4;
|
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == TAG) {
|
2014-03-30 15:51:53 +02:00
|
|
|
mode = TEXT;
|
2020-03-22 20:50:16 +01:00
|
|
|
strcpy(new_buf, "></font>"); opened_font--;
|
|
|
|
new_buf+=11;
|
2017-09-17 14:35:45 +02:00
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '\"':
|
|
|
|
case '\'':
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == TAG) {
|
2014-03-30 15:51:53 +02:00
|
|
|
mode = OPTION_VALUE;
|
2020-03-22 20:50:16 +01:00
|
|
|
strcpy(new_buf, "<font color=#F301F2>'"); opened_font++;
|
|
|
|
new_buf+=25;
|
2014-03-30 15:51:53 +02:00
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
2020-03-22 20:50:16 +01:00
|
|
|
if (mode == OPTION_VALUE) {
|
2014-03-30 15:51:53 +02:00
|
|
|
mode = TAG;
|
2020-03-22 20:50:16 +01:00
|
|
|
strcpy(new_buf, "'</font>"); opened_font--;
|
|
|
|
new_buf+=12;
|
2014-03-30 15:51:53 +02:00
|
|
|
break;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
|
|
|
default:
|
2018-10-06 00:10:27 +02:00
|
|
|
ESBYTE[new_buf] = ESBYTE[i];
|
2014-03-31 19:14:16 +02:00
|
|
|
new_buf++;
|
2014-03-30 13:57:13 +02:00
|
|
|
}
|
|
|
|
}
|
2014-03-31 19:14:16 +02:00
|
|
|
ESBYTE[new_buf] = 0;
|
|
|
|
bufsize = new_buf - new_buf_start;
|
2014-03-30 13:57:13 +02:00
|
|
|
free(bufpointer);
|
|
|
|
bufpointer = new_buf_start;
|
2018-10-06 00:10:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2020-03-22 20:50:16 +01:00
|
|
|
|
|
|
|
enum { TAG, OPTION_VALUE, TEXT, COMMENT, INLINE_COMMENT, CODE };
|
|
|
|
|
2018-10-06 00:10:27 +02:00
|
|
|
char* C_HL_keywords[] = {
|
|
|
|
"switch", "if", "while", "for", "break", "continue", "return", "else",
|
|
|
|
"union", "typedef", "static", "class", "case", "#include",
|
|
|
|
"volatile", "register", "sizeof", "typedef", "union", "goto", "const", "auto",
|
|
|
|
"#define", "#endif", "#error", "#ifdef", "#ifndef", "#undef", "#if", "#else",
|
|
|
|
"inline",
|
|
|
|
|
|
|
|
"int ", "dword ", "long ", "double ", "float ", "char ", "unsigned ", "signed ",
|
|
|
|
"void ", "bool ", "enum ", "byte ", "word ", "struct ", "NULL", "loop", "stdcall ",
|
|
|
|
":void ", ":int ", ":bool ", ":dword ", NULL
|
|
|
|
};
|
|
|
|
|
|
|
|
dword ShowCodeSource()
|
|
|
|
{
|
|
|
|
dword new_buf, new_buf_start, i;
|
|
|
|
int mode = CODE;
|
|
|
|
|
|
|
|
char spstr[64];
|
|
|
|
dword keylen;
|
|
|
|
dword keyn;
|
|
|
|
dword keycolor;
|
|
|
|
|
|
|
|
new_buf = malloc(bufsize*10);
|
|
|
|
new_buf_start = new_buf;
|
|
|
|
sprintf(new_buf,"<html><head><title>C/C++/C-- source: %s</title><body><pre>",#URL);
|
|
|
|
new_buf += strlen(new_buf);
|
|
|
|
for (i=bufpointer; i<bufpointer+bufsize; i++)
|
|
|
|
{
|
|
|
|
if ('<' == ESBYTE[i]) {
|
|
|
|
strcpy(new_buf, "<");
|
|
|
|
new_buf+=4;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ('>' == ESBYTE[i]) {
|
|
|
|
strcpy(new_buf, ">");
|
|
|
|
new_buf+=4;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (ESBYTE[i] >= '0') && (ESBYTE[i] <= '9') && (CODE == mode) {
|
|
|
|
strcpy(new_buf, "<font color=#CF00FF>?</font>");
|
|
|
|
ESBYTE[new_buf+20] = ESBYTE[i];
|
|
|
|
new_buf+=28;
|
|
|
|
if (ESBYTE[i+1] == 'x') {
|
|
|
|
strcpy(new_buf, "<font color=#CF00FF>x</font>");
|
|
|
|
new_buf+=28;
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (CODE == mode) && ('\"' == ESBYTE[i]) {
|
|
|
|
mode = TEXT;
|
|
|
|
strcpy(new_buf, "<font color=#080>\"");
|
|
|
|
new_buf+=18;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (TEXT == mode) && ('\"' == ESBYTE[i]) {
|
|
|
|
mode = CODE;
|
|
|
|
strcpy(new_buf, "\"</font>");
|
|
|
|
new_buf+=8;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! strncmp(i, "//", 2) ) && (mode == CODE) {
|
|
|
|
mode = INLINE_COMMENT;
|
|
|
|
strcpy(new_buf, "<font color=#777>//");
|
|
|
|
new_buf+=19;
|
|
|
|
i++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (INLINE_COMMENT == mode) {
|
|
|
|
if (13 == ESBYTE[i]) {
|
|
|
|
mode = CODE;
|
|
|
|
strcpy(new_buf, "\13</font>");
|
|
|
|
new_buf+=8;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! strncmp(i, "/*", 2) ) {
|
|
|
|
mode = COMMENT;
|
|
|
|
strcpy(new_buf, "<font color=#665>/*");
|
|
|
|
new_buf+=19;
|
|
|
|
i++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (! strncmp(i, "*/", 2) ) {
|
|
|
|
mode = CODE;
|
|
|
|
strcpy(new_buf, "*/</font>");
|
|
|
|
new_buf+=9;
|
|
|
|
i++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (CODE == mode) for (keyn=0; C_HL_keywords[keyn]!=NULL; keyn++)
|
|
|
|
{
|
|
|
|
keylen = strlen(C_HL_keywords[keyn]);
|
|
|
|
if (! strncmp(i, C_HL_keywords[keyn], keylen) ) {
|
|
|
|
|
|
|
|
if (keyn<31) keycolor="#f00"; else keycolor="#00f";
|
|
|
|
sprintf(#spstr, "<font color=%s>%s</font>", keycolor, C_HL_keywords[keyn]);
|
|
|
|
strcpy(new_buf, #spstr);
|
|
|
|
|
|
|
|
new_buf += keylen + 24;
|
|
|
|
i += keylen-1;
|
|
|
|
goto _CONTINUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ESBYTE[new_buf] = ESBYTE[i];
|
|
|
|
new_buf++;
|
|
|
|
_CONTINUE:
|
|
|
|
}
|
|
|
|
ESBYTE[new_buf] = 0;
|
|
|
|
bufsize = new_buf - new_buf_start;
|
|
|
|
free(bufpointer);
|
|
|
|
bufpointer = new_buf_start;
|
|
|
|
}
|
|
|
|
*/
|