diff options
author | Aaron Ballman <aaron@aaronballman.com> | 2018-12-21 19:16:38 +0000 |
---|---|---|
committer | Aaron Ballman <aaron@aaronballman.com> | 2018-12-21 19:16:38 +0000 |
commit | 88b36702dc16d4ddf06136a1ca3a027c31c90c8f (patch) | |
tree | 14cc16b619fd19332627647bb277d4008f46c6f6 | |
parent | 255b05820cb9b52099cc14257fcf599d97084650 (diff) | |
download | bcm5719-llvm-88b36702dc16d4ddf06136a1ca3a027c31c90c8f.tar.gz bcm5719-llvm-88b36702dc16d4ddf06136a1ca3a027c31c90c8f.zip |
Switch from cast<> to dyn_cast<>.
This avoids a potential failed assertion that is happening on someone's out-of-tree build.
llvm-svn: 349940
-rw-r--r-- | clang/utils/TableGen/ClangSACheckersEmitter.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/clang/utils/TableGen/ClangSACheckersEmitter.cpp b/clang/utils/TableGen/ClangSACheckersEmitter.cpp index 4f20274334a..453dfe564bf 100644 --- a/clang/utils/TableGen/ClangSACheckersEmitter.cpp +++ b/clang/utils/TableGen/ClangSACheckersEmitter.cpp @@ -63,8 +63,11 @@ static inline uint64_t getValueFromBitsInit(const BitsInit *B) { uint64_t Value = 0; for (unsigned i = 0, e = B->getNumBits(); i != e; ++i) { - const auto *Bit = cast<BitInit>(B->getBit(i)); - Value |= uint64_t(Bit->getValue()) << i; + const auto *Bit = dyn_cast<BitInit>(B->getBit(i)); + if (Bit) + Value |= uint64_t(Bit->getValue()) << i; + else + PrintFatalError("Invalid bits"); } return Value; } |