llvm-project/llvm/utils/TableGen/Basic/SDNodeProperties.cpp
Rahul Joshi ddda37a6c7
[TableGen] Refactor Intrinsic handling in TableGen (#103980)
CodeGenIntrinsic changes:
  - Use `const` Record pointers, and `StringRef` when possible.
  - Default initialize several fields with their definition instead of in
 the constructor.
- Simplify various string checks in the constructor using StringRef
starts_with()/ends_with() functions.
- Eliminate first argument to `setDefaultProperties` and use `TheDef`
class member instead.

IntrinsicEmitter changes:
  - Emit `namespace llvm::Intrinsic` instead of nested namespaces.
  - End generated comments with a .
  - Use range based for loops, and early continue within loops.
  - Emit `static constexpr` instead of `static const` for arrays.
- Change `compareFnAttributes` to use std::tie() to compare intrinsic
attributes and return a default value when all attributes are equal.

STLExtras:
  - Add std::replace wrapper which takes a range.
2024-08-16 09:26:57 -07:00

41 lines
1.7 KiB
C++

//===- SDNodeProperties.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 "SDNodeProperties.h"
#include "llvm/ADT/StringSwitch.h"
#include "llvm/TableGen/Error.h"
#include "llvm/TableGen/Record.h"
using namespace llvm;
unsigned llvm::parseSDPatternOperatorProperties(const Record *R) {
unsigned Properties = 0;
for (const Record *Property : R->getValueAsListOfDefs("Properties")) {
auto Offset = StringSwitch<unsigned>(Property->getName())
.Case("SDNPCommutative", SDNPCommutative)
.Case("SDNPAssociative", SDNPAssociative)
.Case("SDNPHasChain", SDNPHasChain)
.Case("SDNPOutGlue", SDNPOutGlue)
.Case("SDNPInGlue", SDNPInGlue)
.Case("SDNPOptInGlue", SDNPOptInGlue)
.Case("SDNPMayStore", SDNPMayStore)
.Case("SDNPMayLoad", SDNPMayLoad)
.Case("SDNPSideEffect", SDNPSideEffect)
.Case("SDNPMemOperand", SDNPMemOperand)
.Case("SDNPVariadic", SDNPVariadic)
.Default(-1u);
if (Offset != -1u)
Properties |= 1 << Offset;
else
PrintFatalError(R->getLoc(), "Unknown SD Node property '" +
Property->getName() + "' on node '" +
R->getName() + "'!");
}
return Properties;
}