diff options
author | alon@honor <none@none> | 2010-09-11 14:15:46 -0700 |
---|---|---|
committer | alon@honor <none@none> | 2010-09-11 14:15:46 -0700 |
commit | ac805ebf0af3ad7873dbed0f0f28e5f6d481c464 (patch) | |
tree | 29d01717b6c05cfb43749fd6a88610079447dc74 /src | |
parent | c91d6e20014b124c32d29d301e39a5782570300e (diff) |
Catch a corner case with 0 in varargs
Diffstat (limited to 'src')
-rw-r--r-- | src/parser.js | 6 | ||||
-rw-r--r-- | src/preamble.js | 15 | ||||
-rw-r--r-- | src/snippets.js | 6 |
3 files changed, 18 insertions, 9 deletions
diff --git a/src/parser.js b/src/parser.js index 94be1dc6..e4beee08 100644 --- a/src/parser.js +++ b/src/parser.js @@ -2447,10 +2447,12 @@ function JSify(data) { function makeFunctionCall(ident, params) { // Special cases if (ident == '_llvm_va_start') { + var args = 'Array.prototype.slice.call(arguments, __numArgs__)'; + var data = 'Pointer_make([' + args + '.length].concat(' + args + '), 0)'; if (SAFE_HEAP) { - return 'SAFE_HEAP_STORE(' + params[0].ident + ', Pointer_make(Array.prototype.slice.call(arguments, __numArgs__).concat([0]), 0))'; + return 'SAFE_HEAP_STORE(' + params[0].ident + ', ' + data + ', 0)'; } else { - return 'HEAP[' + params[0].ident + '] = Pointer_make(Array.prototype.slice.call(arguments, __numArgs__).concat([0]), 0)'; + return 'HEAP[' + params[0].ident + '] = ' + data; } } else if (ident == '_llvm_va_end') { return ';' diff --git a/src/preamble.js b/src/preamble.js index 4d473ee3..2ededac1 100644 --- a/src/preamble.js +++ b/src/preamble.js @@ -173,9 +173,18 @@ function _strlen(p) { // return p.slab.length; // XXX might want to find the null terminator... } -function String_copy(p, addZero) { +// Copies a list of num items on the HEAP into a +// a normal JavaScript array of numbers +function Array_copy(ptr, num) { // XXX hardcoded ptr impl - return HEAP.slice(p, p+_strlen(p)).concat(addZero ? [0] : []); + return HEAP.slice(ptr, ptr+num); +} + +// Copies a C-style string, terminated by a zero, from the HEAP into +// a normal JavaScript array of numbers +function String_copy(ptr, addZero) { + // XXX hardcoded ptr impl + return Array_copy(ptr, _strlen(ptr)).concat(addZero ? [0] : []); } // stdlib.h @@ -215,6 +224,8 @@ function jrint(label, obj) { print(label + JSON.stringify(obj)); } +// This processes a 'normal' string into a C-line array of numbers. +// For LLVM-originating strings, see parser.js:parseLLVMString function function intArrayFromString(stringy) { var ret = []; var t; diff --git a/src/snippets.js b/src/snippets.js index 96420990..2f60015f 100644 --- a/src/snippets.js +++ b/src/snippets.js @@ -1,10 +1,6 @@ var Snippets = { vsnprintf: function(dst, num, src, ptr) { - var args = []; - while (HEAP[ptr] != 0) { - args.push(HEAP[ptr]); - ptr ++; - } + var args = Array_copy(ptr+1, HEAP[ptr]); // # of args in in first place var text = __formatString.apply(null, [src].concat(args)); for (var i = 0; i < num; i++) { HEAP[dst+i] = HEAP[text+i]; |