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