2 * Copyright (C) 2015-2017 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 #include "ScopedArgumentsTable.h"
29 #include "JSCInlines.h"
33 const ClassInfo ScopedArgumentsTable::s_info = { "ScopedArgumentsTable", nullptr, nullptr, nullptr, CREATE_METHOD_TABLE(ScopedArgumentsTable) };
35 ScopedArgumentsTable::ScopedArgumentsTable(VM& vm)
36 : Base(vm, vm.scopedArgumentsTableStructure.get())
42 ScopedArgumentsTable::~ScopedArgumentsTable()
46 void ScopedArgumentsTable::destroy(JSCell* cell)
48 static_cast<ScopedArgumentsTable*>(cell)->ScopedArgumentsTable::~ScopedArgumentsTable();
51 ScopedArgumentsTable* ScopedArgumentsTable::create(VM& vm)
53 ScopedArgumentsTable* result =
54 new (NotNull, allocateCell<ScopedArgumentsTable>(vm.heap)) ScopedArgumentsTable(vm);
55 result->finishCreation(vm);
59 ScopedArgumentsTable* ScopedArgumentsTable::create(VM& vm, uint32_t length)
61 ScopedArgumentsTable* result = create(vm);
62 result->m_length = length;
63 result->m_arguments = ArgumentsPtr::create(length);
67 ScopedArgumentsTable* ScopedArgumentsTable::clone(VM& vm)
69 ScopedArgumentsTable* result = create(vm, m_length);
70 for (unsigned i = m_length; i--;)
71 result->m_arguments[i] = m_arguments[i];
75 ScopedArgumentsTable* ScopedArgumentsTable::setLength(VM& vm, uint32_t newLength)
77 if (LIKELY(!m_locked)) {
78 ArgumentsPtr newArguments = ArgumentsPtr::create(newLength);
79 for (unsigned i = std::min(m_length, newLength); i--;)
80 newArguments[i] = m_arguments[i];
82 m_arguments = WTFMove(newArguments);
86 ScopedArgumentsTable* result = create(vm, newLength);
87 for (unsigned i = std::min(m_length, newLength); i--;)
88 result->m_arguments[i] = m_arguments[i];
92 ScopedArgumentsTable* ScopedArgumentsTable::set(VM& vm, uint32_t i, ScopeOffset value)
94 ScopedArgumentsTable* result;
95 if (UNLIKELY(m_locked))
99 result->at(i) = value;
103 Structure* ScopedArgumentsTable::createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype)
105 return Structure::create(vm, globalObject, prototype, TypeInfo(CellType, StructureFlags), info());