| Index: test/mjsunit/regress/regress-92.js | 
| =================================================================== | 
| --- test/mjsunit/regress/regress-92.js	(revision 1547) | 
| +++ test/mjsunit/regress/regress-92.js	(working copy) | 
| @@ -1,67 +0,0 @@ | 
| -// Copyright 2009 the V8 project authors. All rights reserved. | 
| -// Redistribution and use in source and binary forms, with or without | 
| -// modification, are permitted provided that the following conditions are | 
| -// met: | 
| -// | 
| -//     * Redistributions of source code must retain the above copyright | 
| -//       notice, this list of conditions and the following disclaimer. | 
| -//     * Redistributions in binary form must reproduce the above | 
| -//       copyright notice, this list of conditions and the following | 
| -//       disclaimer in the documentation and/or other materials provided | 
| -//       with the distribution. | 
| -//     * Neither the name of Google Inc. nor the names of its | 
| -//       contributors may be used to endorse or promote products derived | 
| -//       from this software without specific prior written permission. | 
| -// | 
| -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
| -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
| -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
| -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 
| -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
| -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
| -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
| -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
| -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
| -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
| -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
| - | 
| -function introduceSetter(useProto, Constructor) { | 
| -  // Before introducing the setter this test expects 'y' to be set | 
| -  // normally.  Afterwards setting 'y' will throw an exception. | 
| -  var runTest = new Function("Constructor", | 
| -    "var p = new Constructor(3); p.y = 4; assertEquals(p.y, 4);"); | 
| - | 
| -  // Create the prototype object first because defining a setter should | 
| -  // clear inline caches. | 
| -  if (useProto) { | 
| -    var newProto = { }; | 
| -    newProto.__defineSetter__('y', function () { throw signal; }); | 
| -  } | 
| - | 
| -  // Ensure that monomorphic ics have been set up. | 
| -  runTest(Constructor); | 
| -  runTest(Constructor); | 
| - | 
| -  var signal = "was called"; | 
| -  if (useProto) { | 
| -    // Either introduce the setter through __proto__... | 
| -    Constructor.prototype.__proto__ = newProto; | 
| -  } else { | 
| -    // ...or introduce it directly using __defineSetter__. | 
| -    Constructor.prototype.__defineSetter__('y', function () { throw signal; }); | 
| -  } | 
| - | 
| -  // Now setting 'y' should throw an exception. | 
| -  try { | 
| -    runTest(Constructor); | 
| -    fail("Accessor was not called."); | 
| -  } catch (e) { | 
| -    assertEquals(e, signal); | 
| -  } | 
| - | 
| -} | 
| - | 
| -introduceSetter(false, function FastCase(x) { this.x = x; }); | 
| -introduceSetter(true, function FastCase(x) { this.x = x; }); | 
| -introduceSetter(false, function SlowCase(x) { this.x = x; delete this.x; }); | 
| -introduceSetter(true, function SlowCase(x) { this.x = x; delete this.x; }); | 
|  |