1
0
mirror of https://gitlab.com/80486DX2-66/gists synced 2025-01-11 02:42:09 +05:30

floatscan-experiment.c: upgrade the experiment code, do not use STDIN

This commit is contained in:
パチュリー・ノーレッジ 2024-03-02 15:29:04 +03:00
parent ca099f2797
commit 4f9ceae08f
Signed by: 80486DX2-66
GPG Key ID: 83631EF27054609B

View File

@ -18,7 +18,12 @@
#include <stdio.h> #include <stdio.h>
/* wrapping code --- beginning */ /* wrapping code --- beginning */
#define shgetc(f) fgetc(f) const char* fgetc_ptr = NULL;
int __shgetc(void);
long double floatscan(const char* s, int prec);
#define shgetc(f) __shgetc()
#define shlim(...) #define shlim(...)
#define shunget(...) #define shunget(...)
@ -531,10 +536,28 @@ long double __floatscan(FILE *f, int prec, int pok)
} }
/* the original musl libc code --- end */ /* the original musl libc code --- end */
/* wrapping code --- beginning */
int __shgetc(void) {
return *fgetc_ptr++;
}
long double floatscan(const char* s, int prec) {
fgetc_ptr = s;
return __floatscan(NULL, prec, 1);
}
/* wrapping code --- end */
/* test code --- beginning */ /* test code --- beginning */
int main(void) { int main(int argc, char** argv) {
printf("LD_B1B_DIG = %d\n", LD_B1B_DIG); char* value = argc > 1 ? argv[1] : "+314.1e-2";
printf("%La\n", __floatscan(stdin, LONG_DOUBLE_TYPE, 1)); const int prec = LD_B1B_DIG;
printf("Selected precision index = %d\n", prec);
long double result = floatscan(value, LONG_DOUBLE_TYPE);
printf("Input : %s\n", value);
printf("Decimal floating-point format: %Lf\n", result);
printf("Double floating-point format : %Lg\n", result);
printf("Hexadecimal form : %La\n", result);
return 0; return 0;
} }
/* test code --- end */ /* test code --- end */