1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
//===- DirectiveNameParser.cpp --------------------------------------------===//
//
// 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/OpenMP/DirectiveNameParser.h"
#include "llvm/ADT/Sequence.h"
#include "llvm/ADT/StringExtras.h"
#include "llvm/ADT/StringRef.h"
#include "llvm/Frontend/OpenMP/OMP.h"
#include <cassert>
#include <memory>
namespace llvm::omp {
DirectiveNameParser::DirectiveNameParser(SourceLanguage L) {
// Take every directive, get its name in every version, break the name up
// into whitespace-separated tokens, and insert each token.
for (size_t I : llvm::seq<size_t>(Directive_enumSize)) {
auto D = static_cast<Directive>(I);
if (D == Directive::OMPD_unknown || !(getDirectiveLanguages(D) & L))
continue;
for (unsigned Ver : getOpenMPVersions())
insertName(getOpenMPDirectiveName(D, Ver), D);
}
}
const DirectiveNameParser::State *
DirectiveNameParser::consume(const State *Current, StringRef Tok) const {
if (!Current)
return Current;
assert(Current->isValid() && "Invalid input state");
if (const State *Next = Current->next(Tok))
return Next->isValid() ? Next : nullptr;
return nullptr;
}
SmallVector<StringRef> DirectiveNameParser::tokenize(StringRef Str) {
SmallVector<StringRef> Tokens;
SplitString(Str, Tokens);
return Tokens;
}
void DirectiveNameParser::insertName(StringRef Name, Directive D) {
State *Where = &InitialState;
for (StringRef Tok : tokenize(Name))
Where = insertTransition(Where, Tok);
Where->Value = D;
}
DirectiveNameParser::State *
DirectiveNameParser::insertTransition(State *From, StringRef Tok) {
assert(From && "Expecting state");
if (!From->Transition)
From->Transition = std::make_unique<State::TransitionMapTy>();
if (State *Next = From->next(Tok))
return Next;
auto [Where, DidIt] = From->Transition->try_emplace(Tok, State());
assert(DidIt && "Map insertion failed");
return &Where->second;
}
const DirectiveNameParser::State *
DirectiveNameParser::State::next(StringRef Tok) const {
if (!Transition)
return nullptr;
auto F = Transition->find(Tok);
return F != Transition->end() ? &F->second : nullptr;
}
DirectiveNameParser::State *DirectiveNameParser::State::next(StringRef Tok) {
if (!Transition)
return nullptr;
auto F = Transition->find(Tok);
return F != Transition->end() ? &F->second : nullptr;
}
} // namespace llvm::omp
|