[llvm] 3327a4c - [Remarks] Move BitstreamRemarkParser helpers to private header (NFC) (#156302)
via llvm-commits
llvm-commits at lists.llvm.org
Wed Sep 10 04:51:29 PDT 2025
Author: Tobias Stadler
Date: 2025-09-10T12:51:26+01:00
New Revision: 3327a4c8f63b37301eaed2b9af8c0c696dff13fb
URL: https://github.com/llvm/llvm-project/commit/3327a4c8f63b37301eaed2b9af8c0c696dff13fb
DIFF: https://github.com/llvm/llvm-project/commit/3327a4c8f63b37301eaed2b9af8c0c696dff13fb.diff
LOG: [Remarks] Move BitstreamRemarkParser helpers to private header (NFC) (#156302)
These helpers are only used in the implementation, and we also don't
expose similar details for the YAMLRemarkParser.
Pull Request: https://github.com/llvm/llvm-project/pull/156302
Added:
Modified:
llvm/lib/Remarks/BitstreamRemarkParser.cpp
llvm/lib/Remarks/BitstreamRemarkParser.h
Removed:
llvm/include/llvm/Remarks/BitstreamRemarkParser.h
################################################################################
diff --git a/llvm/include/llvm/Remarks/BitstreamRemarkParser.h b/llvm/include/llvm/Remarks/BitstreamRemarkParser.h
deleted file mode 100644
index bfa60332d1a90..0000000000000
--- a/llvm/include/llvm/Remarks/BitstreamRemarkParser.h
+++ /dev/null
@@ -1,116 +0,0 @@
-//===-- BitstreamRemarkParser.h - Bitstream parser --------------*- C++ -*-===//
-//
-// 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
-//
-//===----------------------------------------------------------------------===//
-//
-// This file provides an implementation of the remark parser using the LLVM
-// Bitstream format.
-//
-//===----------------------------------------------------------------------===//
-
-#ifndef LLVM_REMARKS_BITSTREAMREMARKPARSER_H
-#define LLVM_REMARKS_BITSTREAMREMARKPARSER_H
-
-#include "llvm/ADT/ArrayRef.h"
-#include "llvm/ADT/StringRef.h"
-#include "llvm/Bitstream/BitstreamReader.h"
-#include "llvm/Support/Error.h"
-#include <array>
-#include <cstdint>
-#include <optional>
-
-namespace llvm {
-namespace remarks {
-
-/// Helper to parse a META_BLOCK for a bitstream remark container.
-struct BitstreamMetaParserHelper {
- /// The Bitstream reader.
- BitstreamCursor &Stream;
- /// Reference to the storage for the block info.
- BitstreamBlockInfo &BlockInfo;
- /// The parsed content: depending on the container type, some fields might be
- /// empty.
- std::optional<uint64_t> ContainerVersion;
- std::optional<uint8_t> ContainerType;
- std::optional<StringRef> StrTabBuf;
- std::optional<StringRef> ExternalFilePath;
- std::optional<uint64_t> RemarkVersion;
-
- /// Continue parsing with \p Stream. \p Stream is expected to contain a
- /// ENTER_SUBBLOCK to the META_BLOCK at the current position.
- /// \p Stream is expected to have a BLOCKINFO_BLOCK set.
- BitstreamMetaParserHelper(BitstreamCursor &Stream,
- BitstreamBlockInfo &BlockInfo);
-
- /// Parse the META_BLOCK and fill the available entries.
- /// This helper does not check for the validity of the fields.
- Error parse();
-};
-
-/// Helper to parse a REMARK_BLOCK for a bitstream remark container.
-struct BitstreamRemarkParserHelper {
- /// The Bitstream reader.
- BitstreamCursor &Stream;
- /// The parsed content: depending on the remark, some fields might be empty.
- std::optional<uint8_t> Type;
- std::optional<uint64_t> RemarkNameIdx;
- std::optional<uint64_t> PassNameIdx;
- std::optional<uint64_t> FunctionNameIdx;
- std::optional<uint64_t> SourceFileNameIdx;
- std::optional<uint32_t> SourceLine;
- std::optional<uint32_t> SourceColumn;
- std::optional<uint64_t> Hotness;
- struct Argument {
- std::optional<uint64_t> KeyIdx;
- std::optional<uint64_t> ValueIdx;
- std::optional<uint64_t> SourceFileNameIdx;
- std::optional<uint32_t> SourceLine;
- std::optional<uint32_t> SourceColumn;
- };
- std::optional<ArrayRef<Argument>> Args;
- /// Avoid re-allocating a vector every time.
- SmallVector<Argument, 8> TmpArgs;
-
- /// Continue parsing with \p Stream. \p Stream is expected to contain a
- /// ENTER_SUBBLOCK to the REMARK_BLOCK at the current position.
- /// \p Stream is expected to have a BLOCKINFO_BLOCK set and to have already
- /// parsed the META_BLOCK.
- BitstreamRemarkParserHelper(BitstreamCursor &Stream);
-
- /// Parse the REMARK_BLOCK and fill the available entries.
- /// This helper does not check for the validity of the fields.
- Error parse();
-};
-
-/// Helper to parse any bitstream remark container.
-struct BitstreamParserHelper {
- /// The Bitstream reader.
- BitstreamCursor Stream;
- /// The block info block.
- BitstreamBlockInfo BlockInfo;
- /// Start parsing at \p Buffer.
- BitstreamParserHelper(StringRef Buffer);
- /// Parse the magic number.
- Expected<std::array<char, 4>> parseMagic();
- /// Parse the block info block containing all the abbrevs.
- /// This needs to be called before calling any other parsing function.
- Error parseBlockInfoBlock();
- /// Return true if the next block is a META_BLOCK. This function does not move
- /// the cursor.
- Expected<bool> isMetaBlock();
- /// Return true if the next block is a REMARK_BLOCK. This function does not
- /// move the cursor.
- Expected<bool> isRemarkBlock();
- /// Return true if the parser reached the end of the stream.
- bool atEndOfStream() { return Stream.AtEndOfStream(); }
- /// Jump to the end of the stream, skipping everything.
- void skipToEnd() { return Stream.skipToEnd(); }
-};
-
-} // end namespace remarks
-} // end namespace llvm
-
-#endif // LLVM_REMARKS_BITSTREAMREMARKPARSER_H
diff --git a/llvm/lib/Remarks/BitstreamRemarkParser.cpp b/llvm/lib/Remarks/BitstreamRemarkParser.cpp
index 20a8ebbadc681..86a6c6dffb187 100644
--- a/llvm/lib/Remarks/BitstreamRemarkParser.cpp
+++ b/llvm/lib/Remarks/BitstreamRemarkParser.cpp
@@ -11,7 +11,6 @@
//
//===----------------------------------------------------------------------===//
-#include "llvm/Remarks/BitstreamRemarkParser.h"
#include "BitstreamRemarkParser.h"
#include "llvm/Remarks/Remark.h"
#include "llvm/Support/MemoryBuffer.h"
diff --git a/llvm/lib/Remarks/BitstreamRemarkParser.h b/llvm/lib/Remarks/BitstreamRemarkParser.h
index 061206471fee4..cba805dc24b59 100644
--- a/llvm/lib/Remarks/BitstreamRemarkParser.h
+++ b/llvm/lib/Remarks/BitstreamRemarkParser.h
@@ -13,10 +13,14 @@
#ifndef LLVM_LIB_REMARKS_BITSTREAM_REMARK_PARSER_H
#define LLVM_LIB_REMARKS_BITSTREAM_REMARK_PARSER_H
+#include "llvm/ADT/ArrayRef.h"
+#include "llvm/ADT/StringRef.h"
+#include "llvm/Bitstream/BitstreamReader.h"
#include "llvm/Remarks/BitstreamRemarkContainer.h"
-#include "llvm/Remarks/BitstreamRemarkParser.h"
#include "llvm/Remarks/RemarkFormat.h"
#include "llvm/Remarks/RemarkParser.h"
+#include "llvm/Support/Error.h"
+#include <array>
#include <cstdint>
#include <memory>
#include <optional>
@@ -26,6 +30,91 @@ namespace remarks {
struct Remark;
+/// Helper to parse a META_BLOCK for a bitstream remark container.
+struct BitstreamMetaParserHelper {
+ /// The Bitstream reader.
+ BitstreamCursor &Stream;
+ /// Reference to the storage for the block info.
+ BitstreamBlockInfo &BlockInfo;
+ /// The parsed content: depending on the container type, some fields might be
+ /// empty.
+ std::optional<uint64_t> ContainerVersion;
+ std::optional<uint8_t> ContainerType;
+ std::optional<StringRef> StrTabBuf;
+ std::optional<StringRef> ExternalFilePath;
+ std::optional<uint64_t> RemarkVersion;
+
+ /// Continue parsing with \p Stream. \p Stream is expected to contain a
+ /// ENTER_SUBBLOCK to the META_BLOCK at the current position.
+ /// \p Stream is expected to have a BLOCKINFO_BLOCK set.
+ BitstreamMetaParserHelper(BitstreamCursor &Stream,
+ BitstreamBlockInfo &BlockInfo);
+
+ /// Parse the META_BLOCK and fill the available entries.
+ /// This helper does not check for the validity of the fields.
+ Error parse();
+};
+
+/// Helper to parse a REMARK_BLOCK for a bitstream remark container.
+struct BitstreamRemarkParserHelper {
+ /// The Bitstream reader.
+ BitstreamCursor &Stream;
+ /// The parsed content: depending on the remark, some fields might be empty.
+ std::optional<uint8_t> Type;
+ std::optional<uint64_t> RemarkNameIdx;
+ std::optional<uint64_t> PassNameIdx;
+ std::optional<uint64_t> FunctionNameIdx;
+ std::optional<uint64_t> SourceFileNameIdx;
+ std::optional<uint32_t> SourceLine;
+ std::optional<uint32_t> SourceColumn;
+ std::optional<uint64_t> Hotness;
+ struct Argument {
+ std::optional<uint64_t> KeyIdx;
+ std::optional<uint64_t> ValueIdx;
+ std::optional<uint64_t> SourceFileNameIdx;
+ std::optional<uint32_t> SourceLine;
+ std::optional<uint32_t> SourceColumn;
+ };
+ std::optional<ArrayRef<Argument>> Args;
+ /// Avoid re-allocating a vector every time.
+ SmallVector<Argument, 8> TmpArgs;
+
+ /// Continue parsing with \p Stream. \p Stream is expected to contain a
+ /// ENTER_SUBBLOCK to the REMARK_BLOCK at the current position.
+ /// \p Stream is expected to have a BLOCKINFO_BLOCK set and to have already
+ /// parsed the META_BLOCK.
+ BitstreamRemarkParserHelper(BitstreamCursor &Stream);
+
+ /// Parse the REMARK_BLOCK and fill the available entries.
+ /// This helper does not check for the validity of the fields.
+ Error parse();
+};
+
+/// Helper to parse any bitstream remark container.
+struct BitstreamParserHelper {
+ /// The Bitstream reader.
+ BitstreamCursor Stream;
+ /// The block info block.
+ BitstreamBlockInfo BlockInfo;
+ /// Start parsing at \p Buffer.
+ BitstreamParserHelper(StringRef Buffer);
+ /// Parse the magic number.
+ Expected<std::array<char, 4>> parseMagic();
+ /// Parse the block info block containing all the abbrevs.
+ /// This needs to be called before calling any other parsing function.
+ Error parseBlockInfoBlock();
+ /// Return true if the next block is a META_BLOCK. This function does not move
+ /// the cursor.
+ Expected<bool> isMetaBlock();
+ /// Return true if the next block is a REMARK_BLOCK. This function does not
+ /// move the cursor.
+ Expected<bool> isRemarkBlock();
+ /// Return true if the parser reached the end of the stream.
+ bool atEndOfStream() { return Stream.AtEndOfStream(); }
+ /// Jump to the end of the stream, skipping everything.
+ void skipToEnd() { return Stream.skipToEnd(); }
+};
+
/// Parses and holds the state of the latest parsed remark.
struct BitstreamRemarkParser : public RemarkParser {
/// The buffer to parse.
More information about the llvm-commits
mailing list