shithub: libmujs

Download patch

ref: c1bd06728a4d37eab587ab8e2d8516e4ae24ce5e
parent: 9321f8fec69afe99e15c1e06ad588d319fa7a1e7
author: Tor Andersson <[email protected]>
date: Wed Apr 19 19:49:01 EDT 2017

Don't truncate error messages.

--- a/jsdump.c
+++ b/jsdump.c
@@ -826,7 +826,7 @@
 		case JS_CBOOLEAN: printf("[Boolean %d]", v.u.object->u.boolean); break;
 		case JS_CNUMBER: printf("[Number %g]", v.u.object->u.number); break;
 		case JS_CSTRING: printf("[String'%s']", v.u.object->u.s.string); break;
-		case JS_CERROR: printf("[Error %s]", v.u.object->u.s.string); break;
+		case JS_CERROR: printf("[Error]"); break;
 		case JS_CITERATOR: printf("[Iterator %p]", (void*)v.u.object); break;
 		case JS_CUSERDATA:
 			printf("[Userdata %s %p]", v.u.object->u.user.tag, v.u.object->u.user.data);
--- a/jserror.c
+++ b/jserror.c
@@ -31,7 +31,6 @@
 
 static void Ep_toString(js_State *J)
 {
-	char buf[256];
 	const char *name = "Error";
 	const char *message = "";
 
@@ -43,8 +42,17 @@
 	if (js_hasproperty(J, 0, "message"))
 		message = js_tostring(J, -1);
 
-	snprintf(buf, sizeof buf, "%s: %s", name, message);
-	js_pushstring(J, buf);
+	if (name[0] == 0)
+		js_pushstring(J, message);
+	else if (message[0] == 0)
+		js_pushstring(J, name);
+	else {
+		js_pushstring(J, name);
+		js_pushstring(J, ": ");
+		js_concat(J);
+		js_pushstring(J, message);
+		js_concat(J);
+	}
 
 	if (js_hasproperty(J, 0, "stackTrace"))
 		js_concat(J);