From: Adrian Prantl Date: Wed, 6 Oct 2021 21:30:02 +0000 (-0700) Subject: Simplify control flow (NFC) X-Git-Tag: upstream/15.0.7~29396 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=2edb9058ea635f950f67bf7cb52f76588d362dfc;p=platform%2Fupstream%2Fllvm.git Simplify control flow (NFC) --- diff --git a/lldb/source/Plugins/SymbolFile/DWARF/DWARFUnit.cpp b/lldb/source/Plugins/SymbolFile/DWARF/DWARFUnit.cpp index 3140fb6..17417f7 100644 --- a/lldb/source/Plugins/SymbolFile/DWARF/DWARFUnit.cpp +++ b/lldb/source/Plugins/SymbolFile/DWARF/DWARFUnit.cpp @@ -661,31 +661,31 @@ bool DWARFUnit::Supports_unnamed_objc_bitfields() { } void DWARFUnit::ParseProducerInfo() { + m_producer = eProducerOther; const DWARFDebugInfoEntry *die = GetUnitDIEPtrOnly(); - if (die) { - const char *producer_cstr = - die->GetAttributeValueAsString(this, DW_AT_producer, nullptr); - llvm::StringRef producer(producer_cstr); - if (!producer.empty()) { - RegularExpression llvm_gcc_regex( - llvm::StringRef("^4\\.[012]\\.[01] \\(Based on Apple " - "Inc\\. build [0-9]+\\) \\(LLVM build " - "[\\.0-9]+\\)$")); - if (llvm_gcc_regex.Execute(producer)) { - m_producer = eProducerLLVMGCC; - } else if (producer.contains("clang")) { - static RegularExpression g_clang_version_regex( - llvm::StringRef(R"(clang-([0-9]+\.[0-9]+\.[0-9]+(\.[0-9]+)?))")); - llvm::SmallVector matches; - if (g_clang_version_regex.Execute(producer, &matches)) - m_producer_version.tryParse(matches[1]); - m_producer = eProducerClang; - } else if (producer.contains("GNU")) - m_producer = eProducerGCC; - } - } - if (m_producer == eProducerInvalid) - m_producer = eProducerOther; + if (!die) + return; + + llvm::StringRef producer( + die->GetAttributeValueAsString(this, DW_AT_producer, nullptr)); + if (producer.empty()) + return; + + static RegularExpression llvm_gcc_regex( + llvm::StringRef("^4\\.[012]\\.[01] \\(Based on Apple " + "Inc\\. build [0-9]+\\) \\(LLVM build " + "[\\.0-9]+\\)$")); + if (llvm_gcc_regex.Execute(producer)) { + m_producer = eProducerLLVMGCC; + } else if (producer.contains("clang")) { + static RegularExpression g_clang_version_regex( + llvm::StringRef(R"(clang-([0-9]+\.[0-9]+\.[0-9]+(\.[0-9]+)?))")); + llvm::SmallVector matches; + if (g_clang_version_regex.Execute(producer, &matches)) + m_producer_version.tryParse(matches[1]); + m_producer = eProducerClang; + } else if (producer.contains("GNU")) + m_producer = eProducerGCC; } DWARFProducer DWARFUnit::GetProducer() {