 Chromium Code Reviews
 Chromium Code Reviews Issue 7792054:
  Make arguments and caller always be null on native functions (fixes issue 1548 and issue 1643).  (Closed) 
  Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
    
  
    Issue 7792054:
  Make arguments and caller always be null on native functions (fixes issue 1548 and issue 1643).  (Closed) 
  Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/| OLD | NEW | 
|---|---|
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. | 
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without | 
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are | 
| 4 // met: | 4 // met: | 
| 5 // | 5 // | 
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright | 
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. | 
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above | 
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following | 
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided | 
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 48 // Helper function used to install functions on objects. | 48 // Helper function used to install functions on objects. | 
| 49 function InstallFunctions(object, attributes, functions) { | 49 function InstallFunctions(object, attributes, functions) { | 
| 50 if (functions.length >= 8) { | 50 if (functions.length >= 8) { | 
| 51 %OptimizeObjectForAddingMultipleProperties(object, functions.length >> 1); | 51 %OptimizeObjectForAddingMultipleProperties(object, functions.length >> 1); | 
| 52 } | 52 } | 
| 53 for (var i = 0; i < functions.length; i += 2) { | 53 for (var i = 0; i < functions.length; i += 2) { | 
| 54 var key = functions[i]; | 54 var key = functions[i]; | 
| 55 var f = functions[i + 1]; | 55 var f = functions[i + 1]; | 
| 56 %FunctionSetName(f, key); | 56 %FunctionSetName(f, key); | 
| 57 %FunctionRemovePrototype(f); | 57 %FunctionRemovePrototype(f); | 
| 58 %IgnoreAttributesAndSetProperty(f, "caller", | |
| 
Lasse Reichstein
2011/09/01 08:23:49
Add comment that we don't match Safari, but we do
 | |
| 59 null, | |
| 60 DONT_ENUM | DONT_DELETE); | |
| 61 %IgnoreAttributesAndSetProperty(f, "arguments", | |
| 62 null, | |
| 63 DONT_ENUM | DONT_DELETE); | |
| 64 | |
| 
Lasse Reichstein
2011/09/01 08:23:49
Add a test that this works? E.g., 
[1].map(functio
 | |
| 58 %SetProperty(object, key, f, attributes); | 65 %SetProperty(object, key, f, attributes); | 
| 59 %SetNativeFlag(f); | 66 %SetNativeFlag(f); | 
| 60 } | 67 } | 
| 61 %ToFastProperties(object); | 68 %ToFastProperties(object); | 
| 62 } | 69 } | 
| 63 | 70 | 
| 64 // Emulates JSC by installing functions on a hidden prototype that | 71 // Emulates JSC by installing functions on a hidden prototype that | 
| 65 // lies above the current object/prototype. This lets you override | 72 // lies above the current object/prototype. This lets you override | 
| 66 // functions on String.prototype etc. and then restore the old function | 73 // functions on String.prototype etc. and then restore the old function | 
| 67 // with delete. See http://code.google.com/p/chromium/issues/detail?id=1717 | 74 // with delete. See http://code.google.com/p/chromium/issues/detail?id=1717 | 
| (...skipping 1455 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1523 // ---------------------------------------------------------------------------- | 1530 // ---------------------------------------------------------------------------- | 
| 1524 | 1531 | 
| 1525 function SetupFunction() { | 1532 function SetupFunction() { | 
| 1526 InstallFunctions($Function.prototype, DONT_ENUM, $Array( | 1533 InstallFunctions($Function.prototype, DONT_ENUM, $Array( | 
| 1527 "bind", FunctionBind, | 1534 "bind", FunctionBind, | 
| 1528 "toString", FunctionToString | 1535 "toString", FunctionToString | 
| 1529 )); | 1536 )); | 
| 1530 } | 1537 } | 
| 1531 | 1538 | 
| 1532 SetupFunction(); | 1539 SetupFunction(); | 
| OLD | NEW |