//===-------------------------------------------------------------- C++ -*-===// // // 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 // //===----------------------------------------------------------------------===// #include "llvm/Frontend/Directive/Spelling.h" #include "llvm/ADT/StringRef.h" #include "llvm/Support/MathExtras.h" #include using namespace llvm; static bool Contains(directive::VersionRange V, int P) { return V.Min <= P && P <= V.Max; } llvm::StringRef llvm::directive::FindName( llvm::iterator_range Range, unsigned Version) { assert(llvm::isInt<8 * sizeof(int)>(Version) && "Version value out of range"); int V = Version; // Do a linear search to find the first Spelling that contains Version. // The condition "contains(S, Version)" does not partition the list of // spellings, so std::[lower|upper]_bound cannot be used. // In practice the list of spellings is expected to be very short, so // linear search seems appropriate. In general, an interval tree may be // a better choice, but in this case it may be an overkill. for (auto &S : Range) { if (Contains(S.Versions, V)) return S.Name; } return StringRef(); }