From 98849dd1cec1e8c28b3debd3ac3676a867e5304b Mon Sep 17 00:00:00 2001 From: "rossberg@chromium.org" Date: Wed, 14 May 2014 10:44:34 +0000 Subject: [PATCH] Drop thenable coercion cache R=dslomov@chromium.org BUG=372788 LOG=Y Review URL: https://codereview.chromium.org/281753004 git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21301 ce2b1a6d-e550-0410-aec6-3dcde31c8c00 --- include/v8.h | 8 ++--- src/promise.js | 25 +++++----------- test/mjsunit/es6/regress/regress-cr372788.js | 45 ++++++++++++++++++++++++++++ 3 files changed, 57 insertions(+), 21 deletions(-) create mode 100644 test/mjsunit/es6/regress/regress-cr372788.js diff --git a/include/v8.h b/include/v8.h index 8da01a8..9843933 100644 --- a/include/v8.h +++ b/include/v8.h @@ -1040,9 +1040,9 @@ class V8_EXPORT ScriptCompiler { BufferPolicy buffer_policy; private: - // Prevent copying. Not implemented. - CachedData(const CachedData&); - CachedData& operator=(const CachedData&); + // Prevent copying. Not implemented. + CachedData(const CachedData&); + CachedData& operator=(const CachedData&); }; /** @@ -1065,7 +1065,7 @@ class V8_EXPORT ScriptCompiler { private: friend class ScriptCompiler; - // Prevent copying. Not implemented. + // Prevent copying. Not implemented. Source(const Source&); Source& operator=(const Source&); diff --git a/src/promise.js b/src/promise.js index fa650ea..f4c60d6 100644 --- a/src/promise.js +++ b/src/promise.js @@ -204,31 +204,22 @@ function PromiseThen(onResolve, onReject) { ); } -PromiseCoerce.table = new $WeakMap; - function PromiseCoerce(constructor, x) { if (!IsPromise(x) && IS_SPEC_OBJECT(x)) { var then; try { then = x.then; } catch(r) { - var promise = %_CallFunction(constructor, r, PromiseRejected); - PromiseCoerce.table.set(x, promise); - return promise; + return %_CallFunction(constructor, r, PromiseRejected); } - if (typeof then === 'function') { - if (PromiseCoerce.table.has(x)) { - return PromiseCoerce.table.get(x); - } else { - var deferred = %_CallFunction(constructor, PromiseDeferred); - PromiseCoerce.table.set(x, deferred.promise); - try { - %_CallFunction(x, deferred.resolve, deferred.reject, then); - } catch(r) { - deferred.reject(r); - } - return deferred.promise; + if (IS_SPEC_FUNCTION(then)) { + var deferred = %_CallFunction(constructor, PromiseDeferred); + try { + %_CallFunction(x, deferred.resolve, deferred.reject, then); + } catch(r) { + deferred.reject(r); } + return deferred.promise; } } return x; diff --git a/test/mjsunit/es6/regress/regress-cr372788.js b/test/mjsunit/es6/regress/regress-cr372788.js new file mode 100644 index 0000000..9b66a7e --- /dev/null +++ b/test/mjsunit/es6/regress/regress-cr372788.js @@ -0,0 +1,45 @@ +// Copyright 2014 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. + +// Flags: --allow-natives-syntax + +var x = 0; +var y = 0; + +var thenable = { then: function(f) { x++; f(); } }; + +for (var i = 0; i < 3; ++i) { + Promise.resolve(thenable).then(function() { x++; y++; }); +} +assertEquals(0, x); + +(function check() { + Promise.resolve().chain(function() { + // Delay check until all handlers have run. + if (y < 3) check(); else assertEquals(6, x); + }).catch(function(e) { %AbortJS("FAILURE: " + e) }); +})(); -- 2.7.4