From 5a5f9eb384c7f90d57351c57ea92bcf231e889dd Mon Sep 17 00:00:00 2001 From: "Kirill Lipatov (Leency)" <lipatov.kiril@gmail.com> Date: Wed, 29 Apr 2020 20:43:31 +0000 Subject: [PATCH] TinyBasic: fix issue with extended keys like arrows Trying to add to autobuild git-svn-id: svn://kolibrios.org@7845 a494cfbc-eb01-0410-851d-a64ba20cac60 --- programs/develop/tinybasic/TinyBasic.c | 32 +++++++++++++++++--------- programs/develop/tinybasic/Tupfile.lua | 6 +++++ 2 files changed, 27 insertions(+), 11 deletions(-) create mode 100644 programs/develop/tinybasic/Tupfile.lua diff --git a/programs/develop/tinybasic/TinyBasic.c b/programs/develop/tinybasic/TinyBasic.c index d08d45c4d8..9b732f8dcf 100644 --- a/programs/develop/tinybasic/TinyBasic.c +++ b/programs/develop/tinybasic/TinyBasic.c @@ -4,10 +4,8 @@ #include <string.h> #include <stdlib.h> /* added 08 Oct 31 */ -#if defined(__TINYC__) #include <conio.h> -#define printf con_printf /* siemargl for smaller @tinyC */ -#endif + char *ExplainErr(int code); @@ -20,7 +18,7 @@ char *ExplainErr(int code); #define IoFileClose(fi) fclose(fi) #define InFileChar(fi) CfileRead(fi) #define OutFileChar(fi,ch) fputc(ch,fi) -#define ScreenChar(ch) printf("%c",ch) +#define ScreenChar(ch) con_printf("%c",ch) #define KeyInChar (char)getchar() #define NeedsEcho true #define BreakTest Broken @@ -125,10 +123,22 @@ char Inch(void) { /* read input character from stdin or file */ Ouch(ch); /* echo input to screen (but not output file) */ return ch;}} ch = KeyInChar; /* get input from stdin */ - if (ch == 0) exit(0); /* Kolibri specific - our window was killed */ - if (ch==13) printf ("\n"); - if (ch==8) printf ("\b "); + // ---Leency + // int __stdcall con_getch(void); + // For normal characters function returns ASCII-code. + // For extended characters (eg, Fx, and arrows), first function call + // returns 0 and second call returns the extended code (similar to the + // DOS-function input). Starting from version 7, after closing the + // console window, this function returns 0. + if (ch == 0) { + ch = (char)con_getch(); + if (ch == 0) exit(0); /* Kolibri specific - user closed window */ + return 0; /* Do not show anything on press extchar */ + } + + if (ch==13) con_printf ("\n"); + if (ch==8) con_printf ("\b "); if (NeedsEcho) ScreenChar(ch); /* alternative input may need this */ if (oFile != NULL) OutFileChar(oFile,ch); /* echo it to output file */ if (ch == '\n') { @@ -804,7 +814,8 @@ void Interp(void) { InLend = InLine; while (true) { /* read input line characters... */ ch = Inch(); - if (ch=='\r') break; /* end of the line */ + if (!ch) continue; + else if (ch=='\r') break; /* end of the line */ else if (ch=='\t') { Debugging = (Debugging+DEBUGON)&1; /* maybe toggle debug */ ch = ' ';} /* convert tabs to space */ @@ -1438,9 +1449,8 @@ void StartTinyBasic(char* ILtext) { int main(int argc, char* argv[]) { /* CONSOLE_INIT("TinyBasic"); */ -#if defined(__TINYC__) if (con_init_console_dll()) return 1; // init fail -#endif + con_set_title("TinyBasic"); int nx; long int len; @@ -1459,7 +1469,7 @@ int main(int argc, char* argv[]) { if (IL != NULL) len = fread(IL,1,len,tmpFile); IL[len] = '\0'; IoFileClose(tmpFile);}} - else printf("Could not open file %s", argv[nx]);} + else con_printf("Could not open file %s", argv[nx]);} else if (strcmp(argv[nx],"-o")==0 && ++nx<argc) /* output file */ oFile = fopen(argv[nx],"w"); else if (strcmp(argv[nx],"-i")==0 && ++nx<argc) /* input file */ diff --git a/programs/develop/tinybasic/Tupfile.lua b/programs/develop/tinybasic/Tupfile.lua new file mode 100644 index 0000000000..b9908315fd --- /dev/null +++ b/programs/develop/tinybasic/Tupfile.lua @@ -0,0 +1,6 @@ +if tup.getconfig('NO_GCC') ~= "" then return end +HELPERDIR = (tup.getconfig("HELPERDIR") == "") and "../.." or tup.getconfig("HELPERDIR") +tup.include(HELPERDIR .. "/use_gcc.lua") +tup.include(HELPERDIR .. "/use_menuetlibc.lua") +compile_gcc{"TinyBasic.c"} +link_gcc("TinyBasic") \ No newline at end of file