diff options
author | orivej <orivej@yandex-team.ru> | 2022-02-10 16:45:01 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:45:01 +0300 |
commit | 2d37894b1b037cf24231090eda8589bbb44fb6fc (patch) | |
tree | be835aa92c6248212e705f25388ebafcf84bc7a1 /contrib/libs/llvm12/lib/Support/IntEqClasses.cpp | |
parent | 718c552901d703c502ccbefdfc3c9028d608b947 (diff) | |
download | ydb-2d37894b1b037cf24231090eda8589bbb44fb6fc.tar.gz |
Restoring authorship annotation for <orivej@yandex-team.ru>. Commit 2 of 2.
Diffstat (limited to 'contrib/libs/llvm12/lib/Support/IntEqClasses.cpp')
-rw-r--r-- | contrib/libs/llvm12/lib/Support/IntEqClasses.cpp | 154 |
1 files changed, 77 insertions, 77 deletions
diff --git a/contrib/libs/llvm12/lib/Support/IntEqClasses.cpp b/contrib/libs/llvm12/lib/Support/IntEqClasses.cpp index 144d8e7569..ebb02e6c01 100644 --- a/contrib/libs/llvm12/lib/Support/IntEqClasses.cpp +++ b/contrib/libs/llvm12/lib/Support/IntEqClasses.cpp @@ -1,77 +1,77 @@ -//===-- llvm/ADT/IntEqClasses.cpp - Equivalence Classes of Integers -------===// -// -// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. -// See https://llvm.org/LICENSE.txt for license information. -// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception -// -//===----------------------------------------------------------------------===// -// -// Equivalence classes for small integers. This is a mapping of the integers -// 0 .. N-1 into M equivalence classes numbered 0 .. M-1. -// -// Initially each integer has its own equivalence class. Classes are joined by -// passing a representative member of each class to join(). -// -// Once the classes are built, compress() will number them 0 .. M-1 and prevent -// further changes. -// -//===----------------------------------------------------------------------===// - -#include "llvm/ADT/IntEqClasses.h" -#include <cassert> - -using namespace llvm; - -void IntEqClasses::grow(unsigned N) { - assert(NumClasses == 0 && "grow() called after compress()."); - EC.reserve(N); - while (EC.size() < N) - EC.push_back(EC.size()); -} - -unsigned IntEqClasses::join(unsigned a, unsigned b) { - assert(NumClasses == 0 && "join() called after compress()."); - unsigned eca = EC[a]; - unsigned ecb = EC[b]; - // Update pointers while searching for the leaders, compressing the paths - // incrementally. The larger leader will eventually be updated, joining the - // classes. - while (eca != ecb) - if (eca < ecb) { - EC[b] = eca; - b = ecb; - ecb = EC[b]; - } else { - EC[a] = ecb; - a = eca; - eca = EC[a]; - } - - return eca; -} - -unsigned IntEqClasses::findLeader(unsigned a) const { - assert(NumClasses == 0 && "findLeader() called after compress()."); - while (a != EC[a]) - a = EC[a]; - return a; -} - -void IntEqClasses::compress() { - if (NumClasses) - return; - for (unsigned i = 0, e = EC.size(); i != e; ++i) - EC[i] = (EC[i] == i) ? NumClasses++ : EC[EC[i]]; -} - -void IntEqClasses::uncompress() { - if (!NumClasses) - return; - SmallVector<unsigned, 8> Leader; - for (unsigned i = 0, e = EC.size(); i != e; ++i) - if (EC[i] < Leader.size()) - EC[i] = Leader[EC[i]]; - else - Leader.push_back(EC[i] = i); - NumClasses = 0; -} +//===-- llvm/ADT/IntEqClasses.cpp - Equivalence Classes of Integers -------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// +// +// Equivalence classes for small integers. This is a mapping of the integers +// 0 .. N-1 into M equivalence classes numbered 0 .. M-1. +// +// Initially each integer has its own equivalence class. Classes are joined by +// passing a representative member of each class to join(). +// +// Once the classes are built, compress() will number them 0 .. M-1 and prevent +// further changes. +// +//===----------------------------------------------------------------------===// + +#include "llvm/ADT/IntEqClasses.h" +#include <cassert> + +using namespace llvm; + +void IntEqClasses::grow(unsigned N) { + assert(NumClasses == 0 && "grow() called after compress()."); + EC.reserve(N); + while (EC.size() < N) + EC.push_back(EC.size()); +} + +unsigned IntEqClasses::join(unsigned a, unsigned b) { + assert(NumClasses == 0 && "join() called after compress()."); + unsigned eca = EC[a]; + unsigned ecb = EC[b]; + // Update pointers while searching for the leaders, compressing the paths + // incrementally. The larger leader will eventually be updated, joining the + // classes. + while (eca != ecb) + if (eca < ecb) { + EC[b] = eca; + b = ecb; + ecb = EC[b]; + } else { + EC[a] = ecb; + a = eca; + eca = EC[a]; + } + + return eca; +} + +unsigned IntEqClasses::findLeader(unsigned a) const { + assert(NumClasses == 0 && "findLeader() called after compress()."); + while (a != EC[a]) + a = EC[a]; + return a; +} + +void IntEqClasses::compress() { + if (NumClasses) + return; + for (unsigned i = 0, e = EC.size(); i != e; ++i) + EC[i] = (EC[i] == i) ? NumClasses++ : EC[EC[i]]; +} + +void IntEqClasses::uncompress() { + if (!NumClasses) + return; + SmallVector<unsigned, 8> Leader; + for (unsigned i = 0, e = EC.size(); i != e; ++i) + if (EC[i] < Leader.size()) + EC[i] = Leader[EC[i]]; + else + Leader.push_back(EC[i] = i); + NumClasses = 0; +} |