Skip to content

Commit

Permalink
Make vara-feature compatible to newer LLVM versions
Browse files Browse the repository at this point in the history
  • Loading branch information
vulder committed Oct 16, 2024
1 parent ec6a1bf commit f589931
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 8 deletions.
26 changes: 19 additions & 7 deletions include/vara/Feature/ConstraintParser.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,18 @@ namespace vara::feature {
// ConstraintToken
//===----------------------------------------------------------------------===//

namespace legacy {
// NOLINTNEXTLINE(readability-identifier-naming)
[[nodiscard]] inline bool starts_with(llvm::StringRef Str,
llvm::StringRef Prefix) {
#if LLVM_VERSION_MAJOR <= 14
return Str.startswith(Prefix);
#else
return Str.starts_with(Prefix);
#endif
}
} // namespace legacy

class ConstraintToken {
public:
using PrecedenceTy = unsigned int;
Expand Down Expand Up @@ -187,38 +199,38 @@ class ConstraintLexer {
static ResultTy munchOperator(const llvm::StringRef &Str) {
switch (Str.front()) {
case '-':
if (Str.startswith("->")) {
if (legacy::starts_with(Str, "->")) {
return {ConstraintToken(ConstraintToken::ConstraintTokenKind::IMPLIES),
2};
}
return {ConstraintToken(ConstraintToken::ConstraintTokenKind::MINUS), 1};
case '!':
if (Str.startswith("!=")) {
if (legacy::starts_with(Str, "!=")) {
return {
ConstraintToken(ConstraintToken::ConstraintTokenKind::NOT_EQUAL),
2};
}
return {ConstraintToken(ConstraintToken::ConstraintTokenKind::NOT), 1};
case '=':
if (Str.startswith("=>")) {
if (legacy::starts_with(Str, "=>")) {
return {ConstraintToken(ConstraintToken::ConstraintTokenKind::IMPLIES),
2};
}
return {ConstraintToken(ConstraintToken::ConstraintTokenKind::EQUAL), 1};
case '>':
if (Str.startswith(">=")) {
if (legacy::starts_with(Str, ">=")) {
return {ConstraintToken(
ConstraintToken::ConstraintTokenKind::GREATER_EQUAL),
2};
}
return {ConstraintToken(ConstraintToken::ConstraintTokenKind::GREATER),
1};
case '<':
if (Str.startswith("<->") || Str.startswith("<=>")) {
if (legacy::starts_with(Str, "<->") || legacy::starts_with(Str, "<=>")) {
return {
ConstraintToken(ConstraintToken::ConstraintTokenKind::EQUIVALENT),
3};
} else if (Str.startswith("<=")) {
} else if (legacy::starts_with(Str, "<=")) {
return {
ConstraintToken(ConstraintToken::ConstraintTokenKind::LESS_EQUAL),
2};
Expand Down Expand Up @@ -282,7 +294,7 @@ static int64_t parseInteger(llvm::StringRef Str,
}

// If parsing failed, we return minimal or maximal value respectively.
if (Str.startswith("-")) {
if (legacy::starts_with(Str, "-")) {
return std::numeric_limits<int64_t>::min();
}
return std::numeric_limits<int64_t>::max();
Expand Down
4 changes: 3 additions & 1 deletion include/vara/Feature/FeatureSourceRange.h
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
#ifndef VARA_FEATURE_FEATURESOURCERANGE_H
#define VARA_FEATURE_FEATURESOURCERANGE_H

#if __has_include("llvm/ADT/Optional.h")
#include "llvm/ADT/None.h"
#include "llvm/ADT/Optional.h"
#endif

#include "llvm/IR/LLVMContext.h"
#include "llvm/Support/FormatVariadic.h"

Expand All @@ -17,7 +20,6 @@ namespace fs = std::experimental::filesystem;
#include <optional>
#include <sstream>
#include <string>
#include <tuple>
#include <utility>

namespace vara::feature {
Expand Down
7 changes: 7 additions & 0 deletions tools/fm-viewer/FeatureModelViewer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Support/Program.h"

#include <optional>

static llvm::cl::OptionCategory
FMViewerCategory("Feature model viewer options");

Expand Down Expand Up @@ -80,7 +82,12 @@ int main(int Argc, char **Argv) {
Viewer.empty() ? llvm::errc::invalid_argument
: llvm::sys::findProgramByName(Viewer)) {
llvm::errs() << "Trying '" << *P << "' program... \n";
#if __has_include("llvm/ADT/Optional.h")
// To stay compatible with older llvm versions
llvm::sys::ExecuteNoWait(*P, {*P, Filename}, llvm::None);
#else
llvm::sys::ExecuteNoWait(*P, {*P, Filename}, std::nullopt);
#endif
} else {
llvm::DisplayGraph(Filename);
}
Expand Down

0 comments on commit f589931

Please sign in to comment.