Thu, 15 Jan 2015 21:03:48 +0100
Integrate friendly tips from Tor colleagues to make (or not) 4.5 alpha 3;
This includes removal of overloaded (but unused) methods, and addition of
a overlooked call to DataStruct::SetData(nsISupports, uint32_t, bool.)
michael@0 | 1 | function test(name, fn, val) { |
michael@0 | 2 | gc(); |
michael@0 | 3 | var ok = {}, bad = {}; |
michael@0 | 4 | bad.__defineSetter__(name, fn); |
michael@0 | 5 | var arr = [ok, ok, ok, ok, ok, bad]; |
michael@0 | 6 | |
michael@0 | 7 | var log = ''; |
michael@0 | 8 | try { |
michael@0 | 9 | for (var i = 0; i < arr.length; i++) { |
michael@0 | 10 | arr[i][name] = val; |
michael@0 | 11 | log += '.'; |
michael@0 | 12 | } |
michael@0 | 13 | } catch (exc) { |
michael@0 | 14 | log += 'E'; |
michael@0 | 15 | } |
michael@0 | 16 | assertEq(log, '.....E'); |
michael@0 | 17 | } |
michael@0 | 18 | |
michael@0 | 19 | test("x", Function.prototype.call, null); // TypeError: Function.prototype.call called on incompatible [object Object] |
michael@0 | 20 | test("y", Array, 0.1); // RangeError: invalid array length |
michael@0 | 21 | test(1, Function.prototype.call, null); // TypeError: Function.prototype.call called on incompatible [object Object] |
michael@0 | 22 | test(1, Array, 0.1); // RangeError: invalid array length |