From 5465f0adc461d9816a5dd1b4d09ca5d7960ba90a Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Sun, 27 Mar 2016 23:38:36 +0000 Subject: BitcodeWriter: Restructure WriteFunctionLocalMetadata, NFC Use an early return to simplify logic. llvm-svn: 264554 --- llvm/lib/Bitcode/Writer/BitcodeWriter.cpp | 20 +++++++++----------- 1 file changed, 9 insertions(+), 11 deletions(-) (limited to 'llvm/lib/Bitcode/Writer/BitcodeWriter.cpp') diff --git a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp index 08724bd..e173d80 100644 --- a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -1429,19 +1429,17 @@ static void WriteModuleMetadata(const Module &M, static void WriteFunctionLocalMetadata(const Function &F, const ValueEnumerator &VE, BitstreamWriter &Stream) { - bool StartedMetadataBlock = false; + ArrayRef MDs = VE.getFunctionMDs(); + if (MDs.empty()) + return; + + Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3); + SmallVector Record; - for (const Metadata *MD : VE.getFunctionMDs()) { - auto *Local = cast(MD); - if (!StartedMetadataBlock) { - Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3); - StartedMetadataBlock = true; - } - WriteValueAsMetadata(Local, VE, Stream, Record); - } + for (const Metadata *MD : VE.getFunctionMDs()) + WriteValueAsMetadata(cast(MD), VE, Stream, Record); - if (StartedMetadataBlock) - Stream.ExitBlock(); + Stream.ExitBlock(); } static void WriteMetadataAttachment(const Function &F, -- cgit v1.1