pretty-printing check cases


git-svn-id: https://asn1c.svn.sourceforge.net/svnroot/asn1c/trunk@421 59561ff5-6e30-0410-9f3c-9617f08c8826
diff --git a/skeletons/tests/check-REAL.c b/skeletons/tests/check-REAL.c
index 0d6d073..198113c 100644
--- a/skeletons/tests/check-REAL.c
+++ b/skeletons/tests/check-REAL.c
@@ -7,8 +7,53 @@
 #include <der_encoder.c>
 #include <constraints.c>
 
+static char reconstructed[2][512];
+static int reconstr_lens[2];
+
+static int
+callback(const void *buffer, size_t size, void *app_key) {
+	char *buf = reconstructed[app_key ? 1 : 0];
+	int *len = &reconstr_lens[app_key ? 1 : 0];
+
+	if(*len + size >= sizeof(reconstructed[0]))
+		return -1;
+
+	memcpy(buf + *len, buffer, size);
+	*len += size;
+
+	return 0;
+}
+
 static void
-check(REAL_t *rn, double orig_dbl) {
+check_str_repr(double d, const char *sample, const char *canonical_sample) {
+	ssize_t s1, s2;
+
+	reconstr_lens[1] = reconstr_lens[0] = 0;
+
+	s1 = REAL__dump(d, 0, callback, 0);
+	assert(s1 < sizeof(reconstructed[0]));
+	assert(s1 == reconstr_lens[0]);
+	reconstructed[0][s1] = '\0';
+
+	s2 = REAL__dump(d, 1, callback, (void *)1);
+	assert(s2 < sizeof(reconstructed[1]));
+	assert(s2 == reconstr_lens[1]);
+	reconstructed[1][s2] = '\0';
+
+	if(sample) {
+		printf("Checking [%s] against [%s]\n",
+			reconstructed[0], sample);
+		assert(!strcmp(reconstructed[0], sample));
+	}
+	if(canonical_sample) {
+		printf("Checking [%s] against [%s] (canonical)\n",
+			reconstructed[1], canonical_sample);
+		assert(!strcmp(reconstructed[1], canonical_sample));
+	}
+}
+
+static void
+check(REAL_t *rn, double orig_dbl, const char *sample, const char *canonical_sample) {
 	double val;
 	uint8_t *p, *end;
 	int ret;
@@ -44,17 +89,19 @@
 
 	assert(orig_dbl == val);
 	printf("OK\n");
+
+	check_str_repr(val, sample, canonical_sample);
 }
 
 uint8_t buf_1_0[]  = { 0x80, 0xcc, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
 uint8_t buf_1_1[]  = { 0x80, 0xcc, 0x11, 0x99, 0x99, 0x99, 0x99, 0x99, 0x9a };
 uint8_t buf_3_14[] = { 0x80, 0xcd, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f };
 /* These ones are very interesting! It checks mantissa overflow! */
-uint8_t buf_mo1[]  = { 0x80, 0xc5, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f,3};
+uint8_t buf_mo1[]  = { 0xC0, 0xc5, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f,3};
 uint8_t buf_mo2[]  = { 0x80, 0xbd, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f,3,2};
 
 static void
-check_buf(uint8_t *buf, size_t bufsize, double verify) {
+check_buf(uint8_t *buf, size_t bufsize, double verify, const char *sample, const char *canonical_sample) {
 	REAL_t rn;
 	double val;
 	uint8_t *p, *end;
@@ -90,6 +137,8 @@
 	printf("%.12f vs %.12f\n", verify, val);
 
 	assert(val == verify);
+
+	check_str_repr(val, sample, canonical_sample);
 }
 
 int
@@ -98,42 +147,43 @@
 
 	memset(&rn, 0, sizeof(rn));
 
-	check(&rn, 0.0);
-	check(&rn, 1.0);
-	check(&rn, -1.0);
-	check(&rn, 1.5);
-	check(&rn, 0.1);
-	check(&rn, 0.33333);
-	check(&rn, 2);
-	check(&rn, 2.1);
-	check(&rn, 3);
-	check(&rn, 3.1);
-	check(&rn, 3.14);
-	check(&rn, 3.1415);
-	check(&rn, 3.141592);
-	check(&rn, 3.14159265);
-	check(&rn, -3.14159265);
-	check(&rn, 14159265.0);
-	check(&rn, -123456789123456789.0);
-	check(&rn, 0.00000000001);
-	check(&rn, 0.00000000002);
-	check(&rn, 0.00000000009);
-	check(&rn, 0.0000000000000000000001);
-	check(&rn, 0.000000000000000000000000000001); /* proved 2B a problem */
-	check(&rn,-0.000000000000000000000000000001); /* proved 2B a problem */
-	check(&rn, 0.0000000000010000000001000000000001);
-	check(&rn, 0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
-	check(&rn, 0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
-	check(&rn,-0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
-	check(&rn,-3.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333);
-	check(&rn, 0.0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000033333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333);
-	check(&rn, -0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
+	check(&rn, 0.0, "0", "0");
+	check(&rn, -0.0, "-0", "-0");	/* minus-zero */
+	check(&rn, 1.0, "1.0", "1.0E0");
+	check(&rn, -1.0, "-1.0", "-1.0E0");
+	check(&rn, 1.5, "1.5", "1.5E0");
+	check(&rn, 0.1, "0.1", "1.0E-1");
+	check(&rn, 0.33333, "0.33333", "3.3333E-1");
+	check(&rn, 2, "2.0", "2.0E0");
+	check(&rn, 2.1, "2.1", "2.1E0");
+	check(&rn, 3, "3.0", "3.0E0");
+	check(&rn, 3.1, "3.1", "3.1E0");
+	check(&rn, 3.14, "3.14", "3.14E0");
+	check(&rn, 3.1415, "3.1415", "3.1415E0");
+	check(&rn, 3.141592, "3.141592", "3.141592E0");
+	check(&rn, 3.14159265, "3.14159265", "3.14159265E0");
+	check(&rn, -3.14159265, "-3.14159265", "-3.14159265E0");
+	check(&rn, 14159265.0, "14159265.0", "1.4159265E7");
+	check(&rn, -123456789123456789.0, "-123456789123456784.0", "-1.234567891234568E17");
+	check(&rn, 0.00000000001, "0.0", "9.999999999999999E-12");
+	check(&rn, 0.00000000002, "0.0", "2.0E-11");
+	check(&rn, 0.00000000009, "0.0", "9.0E-11");
+	check(&rn, 0.0000000000000000000001, "0.0", "1.0E-22");
+	check(&rn, 0.000000000000000000000000000001, "0.0", "1.0E-30"); /* proved 2B a problem */
+	check(&rn,-0.000000000000000000000000000001, "-0.0", "-1.0E-30"); /* proved 2B a problem */
+	check(&rn, 0.0000000000010000000001000000000001, 0, 0);
+	check(&rn, 0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+	check(&rn, 0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+	check(&rn,-0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+	check(&rn,-3.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333, 0, 0);
+	check(&rn, 0.0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000033333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333, 0, 0);
+	check(&rn, -0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
 
-	check_buf(buf_1_0, sizeof(buf_1_0),	1.0);
-	check_buf(buf_1_1, sizeof(buf_1_1),	1.1);
-	check_buf(buf_3_14, sizeof(buf_3_14),	3.14);
-	check_buf(buf_mo1, sizeof(buf_mo1),	3.14);
-	check_buf(buf_mo2, sizeof(buf_mo2),	3.14);
+	check_buf(buf_1_0, sizeof(buf_1_0),	1.0, "1.0", "1.0E0");
+	check_buf(buf_1_1, sizeof(buf_1_1),	1.1, "1.1", "1.1E0");
+	check_buf(buf_3_14, sizeof(buf_3_14),	3.14, "3.14", "3.14E0");
+	check_buf(buf_mo1, sizeof(buf_mo1),	-3.14, "-3.14", "-3.14E0");
+	check_buf(buf_mo2, sizeof(buf_mo2),	3.14, "3.14", "3.14E0");
 
 	return 0;
 }