14514f5e3Sopenharmony_ci/* 24514f5e3Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 34514f5e3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 44514f5e3Sopenharmony_ci * you may not use this file except in compliance with the License. 54514f5e3Sopenharmony_ci * You may obtain a copy of the License at 64514f5e3Sopenharmony_ci * 74514f5e3Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 84514f5e3Sopenharmony_ci * 94514f5e3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 104514f5e3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 114514f5e3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 124514f5e3Sopenharmony_ci * See the License for the specific language governing permissions and 134514f5e3Sopenharmony_ci * limitations under the License. 144514f5e3Sopenharmony_ci */ 154514f5e3Sopenharmony_ci 164514f5e3Sopenharmony_ci#include "ecmascript/compiler/base/depend_chain_helper.h" 174514f5e3Sopenharmony_ci 184514f5e3Sopenharmony_cinamespace panda::ecmascript::kungfu { 194514f5e3Sopenharmony_ci 204514f5e3Sopenharmony_civoid DependChains::Merge(DependChains* that) 214514f5e3Sopenharmony_ci{ 224514f5e3Sopenharmony_ci // find common sub list 234514f5e3Sopenharmony_ci while (size_ > that->size_) { 244514f5e3Sopenharmony_ci head_ = head_->next; 254514f5e3Sopenharmony_ci size_--; 264514f5e3Sopenharmony_ci } 274514f5e3Sopenharmony_ci 284514f5e3Sopenharmony_ci auto lhs = this->head_; 294514f5e3Sopenharmony_ci auto rhs = that->head_; 304514f5e3Sopenharmony_ci size_t rhsSize = that->size_; 314514f5e3Sopenharmony_ci while (rhsSize > size_) { 324514f5e3Sopenharmony_ci rhs = rhs->next; 334514f5e3Sopenharmony_ci rhsSize--; 344514f5e3Sopenharmony_ci } 354514f5e3Sopenharmony_ci while (lhs != rhs) { 364514f5e3Sopenharmony_ci ASSERT(lhs != nullptr); 374514f5e3Sopenharmony_ci lhs = lhs->next; 384514f5e3Sopenharmony_ci rhs = rhs->next; 394514f5e3Sopenharmony_ci size_--; 404514f5e3Sopenharmony_ci } 414514f5e3Sopenharmony_ci head_ = lhs; 424514f5e3Sopenharmony_ci} 434514f5e3Sopenharmony_ci 444514f5e3Sopenharmony_cibool DependChains::Equals(DependChains* that) 454514f5e3Sopenharmony_ci{ 464514f5e3Sopenharmony_ci if (that == nullptr) { 474514f5e3Sopenharmony_ci return false; 484514f5e3Sopenharmony_ci } 494514f5e3Sopenharmony_ci if (size_ != that->size_) { 504514f5e3Sopenharmony_ci return false; 514514f5e3Sopenharmony_ci } 524514f5e3Sopenharmony_ci auto lhs = this->head_; 534514f5e3Sopenharmony_ci auto rhs = that->head_; 544514f5e3Sopenharmony_ci while (lhs != rhs) { 554514f5e3Sopenharmony_ci if (lhs->gate != rhs->gate) { 564514f5e3Sopenharmony_ci return false; 574514f5e3Sopenharmony_ci } 584514f5e3Sopenharmony_ci lhs = lhs->next; 594514f5e3Sopenharmony_ci rhs = rhs->next; 604514f5e3Sopenharmony_ci } 614514f5e3Sopenharmony_ci return true; 624514f5e3Sopenharmony_ci} 634514f5e3Sopenharmony_ci 644514f5e3Sopenharmony_ciDependChains* DependChains::UpdateNode(GateRef gate) 654514f5e3Sopenharmony_ci{ 664514f5e3Sopenharmony_ci // assign node->next to head 674514f5e3Sopenharmony_ci Node* node = chunk_->New<Node>(gate, head_); 684514f5e3Sopenharmony_ci DependChains* that = new (chunk_) DependChains(chunk_); 694514f5e3Sopenharmony_ci // assign head to node 704514f5e3Sopenharmony_ci that->head_ = node; 714514f5e3Sopenharmony_ci that->size_ = size_ + 1; 724514f5e3Sopenharmony_ci return that; 734514f5e3Sopenharmony_ci} 744514f5e3Sopenharmony_ci} // namespace panda::ecmascript::kungfu