mirror of
https://github.com/cc65/cc65.git
synced 2024-09-27 19:55:09 +00:00
add tests for float vs int var
This commit is contained in:
parent
bb24862401
commit
771155ff02
99
test/val/float-basic-intvar-var.c
Normal file
99
test/val/float-basic-intvar-var.c
Normal file
@ -0,0 +1,99 @@
|
||||
|
||||
// test basic arithmetic operations
|
||||
|
||||
#ifdef CONIO
|
||||
#include <conio.h>
|
||||
#define WAIT() cgetc()
|
||||
#else
|
||||
#define WAIT()
|
||||
#endif
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <stdint.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <_float.h>
|
||||
|
||||
float fp1 = 12.34f;
|
||||
float fp2; // non initialized
|
||||
float fp3, fp4 = 55.55f;
|
||||
|
||||
char buf[0x20];
|
||||
char buf2[0x20];
|
||||
char buf3[0x20];
|
||||
|
||||
unsigned long l1,l2;
|
||||
|
||||
signed char var_schar;
|
||||
unsigned char var_uchar;
|
||||
signed int var_sint;
|
||||
unsigned int var_uint;
|
||||
signed long var_slong;
|
||||
unsigned long var_ulong;
|
||||
|
||||
int result = 0;
|
||||
int i;
|
||||
|
||||
unsigned char var_char;
|
||||
unsigned int var_int;
|
||||
float var_float;
|
||||
|
||||
// returns 1 if value in f matches the string
|
||||
// the string is a hex value without leading "0x"
|
||||
int compare(float f, char *str)
|
||||
{
|
||||
char temp[12];
|
||||
sprintf(temp, "%08lx", *((uint32_t*)&f));
|
||||
printf("[%s:%s]", temp, str);
|
||||
return (strcmp(temp, str) == 0) ? 1 : 0;
|
||||
}
|
||||
|
||||
void test1(float f, char *str)
|
||||
{
|
||||
if (compare(f, str)) {
|
||||
// printf(" (ok)");
|
||||
} else {
|
||||
printf(" (failed) !!! ");
|
||||
result++;
|
||||
}
|
||||
printf("result:%d\n", result);
|
||||
}
|
||||
|
||||
void SKIPPEDtest1(float f, char *str)
|
||||
{
|
||||
char temp[12];
|
||||
sprintf(temp, "%08lx", *((uint32_t*)&f));
|
||||
printf(" (SKIPPED:%s:%s)\n", temp, str);
|
||||
}
|
||||
|
||||
void test(void)
|
||||
{
|
||||
var_int = 47;
|
||||
var_float = 11.123f;
|
||||
fp1 = var_int;
|
||||
printf("fp1:0x%08lx [42687df4] %s (47)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
fp1 = var_float;
|
||||
printf("fp1:0x%08lx [42687df4] %s (11.123)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
|
||||
/* addition */
|
||||
fp1 = var_int + var_float;
|
||||
printf("fp1:0x%08lx [42687df4] %s (58.123)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
test1(fp1, "42687df4");
|
||||
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
float fp2 = 43.21f;
|
||||
|
||||
printf("*** float-basic-intvar-var ***\n");
|
||||
printf("fp1:0x%08lx [0x414570a4] %s (12.340000)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
printf("fp2:0x%08lx [0x422cd70a] %s (43.209999)\n", *((uint32_t*)&fp2), _ftostr(buf, fp2));
|
||||
|
||||
test();
|
||||
WAIT();
|
||||
|
||||
printf("\nfloat-basic-intvar-var (res:%d)\n", result);
|
||||
return result;
|
||||
}
|
100
test/val/float-basic-var-intvar.c
Normal file
100
test/val/float-basic-var-intvar.c
Normal file
@ -0,0 +1,100 @@
|
||||
|
||||
// test basic arithmetic operations
|
||||
|
||||
#ifdef CONIO
|
||||
#include <conio.h>
|
||||
#define WAIT() cgetc()
|
||||
#else
|
||||
#define WAIT()
|
||||
#endif
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <stdint.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <_float.h>
|
||||
|
||||
float fp1 = 12.34f;
|
||||
float fp2; // non initialized
|
||||
float fp3, fp4 = 55.55f;
|
||||
|
||||
char buf[0x20];
|
||||
char buf2[0x20];
|
||||
char buf3[0x20];
|
||||
|
||||
unsigned long l1,l2;
|
||||
|
||||
signed char var_schar;
|
||||
unsigned char var_uchar;
|
||||
signed int var_sint;
|
||||
unsigned int var_uint;
|
||||
signed long var_slong;
|
||||
unsigned long var_ulong;
|
||||
|
||||
int result = 0;
|
||||
int i;
|
||||
|
||||
unsigned char var_char;
|
||||
unsigned int var_int;
|
||||
float var_float;
|
||||
|
||||
// returns 1 if value in f matches the string
|
||||
// the string is a hex value without leading "0x"
|
||||
int compare(float f, char *str)
|
||||
{
|
||||
char temp[12];
|
||||
sprintf(temp, "%08lx", *((uint32_t*)&f));
|
||||
printf("[%s:%s]", temp, str);
|
||||
return (strcmp(temp, str) == 0) ? 1 : 0;
|
||||
}
|
||||
|
||||
void test1(float f, char *str)
|
||||
{
|
||||
if (compare(f, str)) {
|
||||
// printf(" (ok)");
|
||||
} else {
|
||||
printf(" (failed) !!! ");
|
||||
result++;
|
||||
}
|
||||
printf("result:%d\n", result);
|
||||
}
|
||||
|
||||
void SKIPPEDtest1(float f, char *str)
|
||||
{
|
||||
char temp[12];
|
||||
sprintf(temp, "%08lx", *((uint32_t*)&f));
|
||||
printf(" (SKIPPED:%s:%s)\n", temp, str);
|
||||
}
|
||||
|
||||
void test(void)
|
||||
{
|
||||
|
||||
var_int = 47;
|
||||
var_float = 11.123f;
|
||||
fp1 = var_int;
|
||||
printf("fp1:0x%08lx [42687df4] %s (47)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
fp1 = var_float;
|
||||
printf("fp1:0x%08lx [42687df4] %s (11.123)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
|
||||
/* addition */
|
||||
fp1 = var_float + var_int;
|
||||
printf("fp1:0x%08lx [42687df4] %s (58.123)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
test1(fp1, "42687df4");
|
||||
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
float fp2 = 43.21f;
|
||||
|
||||
printf("*** float-basic-var-intvar ***\n");
|
||||
printf("fp1:0x%08lx [0x414570a4] %s (12.340000)\n", *((uint32_t*)&fp1), _ftostr(buf, fp1));
|
||||
printf("fp2:0x%08lx [0x422cd70a] %s (43.209999)\n", *((uint32_t*)&fp2), _ftostr(buf, fp2));
|
||||
|
||||
test();
|
||||
WAIT();
|
||||
|
||||
printf("\nfloat-basic-var-intvar (res:%d)\n", result);
|
||||
return result;
|
||||
}
|
89
test/val/float-cmp-var-var.c
Normal file
89
test/val/float-cmp-var-var.c
Normal file
@ -0,0 +1,89 @@
|
||||
|
||||
// test comparison operations
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <stdint.h>
|
||||
|
||||
#include <_float.h>
|
||||
|
||||
#ifdef CONIO
|
||||
#include <conio.h>
|
||||
#define WAIT() cgetc()
|
||||
#else
|
||||
#define WAIT()
|
||||
#endif
|
||||
|
||||
float fp1, fp2, fp3, fp4;
|
||||
|
||||
char buf[0x30];
|
||||
char buf2[0x30];
|
||||
char buf3[0x30];
|
||||
|
||||
signed char var_schar;
|
||||
unsigned char var_uchar;
|
||||
signed int var_sint;
|
||||
unsigned int var_uint;
|
||||
signed long var_slong;
|
||||
unsigned long var_ulong;
|
||||
|
||||
int result = 0;
|
||||
|
||||
#define expect(msg, exp, val) \
|
||||
printf("%s %s%s\n", \
|
||||
msg, \
|
||||
val ? "true" : "false", \
|
||||
(exp != val) ? " (failed)" : ""); \
|
||||
if (exp != val) { \
|
||||
result++; \
|
||||
}
|
||||
|
||||
//-------------------------------------------------------------------------
|
||||
// float variable vs float variable
|
||||
void varvar(void)
|
||||
{
|
||||
printf("var vs var\n");
|
||||
|
||||
fp1 = 1.6f;
|
||||
fp2 = 1.5f;
|
||||
fp3 = 1.6f;
|
||||
fp4 = 1.5f;
|
||||
|
||||
expect("1.5f == 1.6f is", 0, (fp2 == fp3));
|
||||
expect("1.6f == 1.5f is", 0, (fp1 == fp4));
|
||||
expect("1.6f == 1.6f is", 1, (fp1 == fp3));
|
||||
|
||||
expect("1.5f != 1.6f is", 1, (fp2 != fp3));
|
||||
expect("1.6f != 1.5f is", 1, (fp1 != fp4));
|
||||
expect("1.6f != 1.6f is", 0, (fp1 != fp3));
|
||||
|
||||
expect("1.5f < 1.6f is", 1, (fp2 < fp3));
|
||||
expect("1.6f < 1.5f is", 0, (fp1 < fp4));
|
||||
expect("1.6f < 1.6f is", 0, (fp1 < fp3));
|
||||
|
||||
expect("1.5f > 1.6f is", 0, (fp2 > fp3));
|
||||
expect("1.6f > 1.5f is", 1, (fp1 > fp4));
|
||||
expect("1.6f > 1.6f is", 0, (fp1 > fp3));
|
||||
|
||||
expect("1.5f <= 1.6f is", 1, (fp2 <= fp3));
|
||||
expect("1.6f <= 1.5f is", 0, (fp1 <= fp4));
|
||||
expect("1.6f <= 1.6f is", 1, (fp1 <= fp3));
|
||||
|
||||
expect("1.5f >= 1.6f is", 0, (fp2 >= fp3));
|
||||
expect("1.6f >= 1.5f is", 1, (fp1 >= fp4));
|
||||
expect("1.6f >= 1.6f is", 1, (fp1 >= fp3));
|
||||
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
printf("float-cmp\n");
|
||||
|
||||
fp1 = 1.6f;
|
||||
fp2 = 1.5f;
|
||||
|
||||
varvar();
|
||||
|
||||
printf("float-cmp (res: %d)\n", result);
|
||||
return result;
|
||||
}
|
Loading…
Reference in New Issue
Block a user