// Copyright 2013 the V8 project authors. All rights reserved. // Copyright (C) 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions // are met: // 1. Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // 2. 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. // // THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS 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 APPLE INC. OR ITS 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 stackOverflowIn20ArgFn = false, gotRegexCatch = false, gotDateCatch = false; function funcWith20Args(arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9, arg10, arg11, arg12, arg13, arg14, arg15, arg16, arg17, arg18, arg19, arg20) { assertUnreachable("shouldn't arrive in non-inlined 20 arg function after stack overflow"); } // If we should run with TurboFan, then make sure {funcWith20Args} does // not get inlined. %NeverOptimizeFunction(funcWith20Args); function mutual_recursion_1() { try { mutual_recursion_2(); } catch (err) { // Should get here because of stack overflow, // now cause a stack overflow exception due to arity processing try { var dummy = new RegExp('a|b|c'); } catch(err) { // (1) It is dependent on the stack size if we arrive here, in (2) or // both. gotRegexCatch = true; } try { funcWith20Args(1, 2, 3); } catch (err2) { stackOverflowIn20ArgFn = true; } } } function mutual_recursion_2() { try { var dummy = new Date(); } catch(err) { // (2) It is dependent on the stack size if we arrive here, in (1) or // both. gotDateCatch = true; } try { mutual_recursion_1(); } catch (err) { // Should get here because of stack overflow, // now cause a stack overflow exception due to arity processing try { funcWith20Args(1, 2, 3, 4, 5, 6); } catch (err2) { stackOverflowIn20ArgFn = true; } } } mutual_recursion_1(); assertTrue(stackOverflowIn20ArgFn);