[llvm] [GOFF] Refactor GOFFOstream (PR #131143)
Kai Nacke via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 13 13:55:30 PDT 2025
================
@@ -63,158 +63,167 @@ constexpr uint8_t RecContinued = Flags(7, 1, 1);
constexpr uint8_t RecContinuation = Flags(6, 1, 1);
// The GOFFOstream is responsible to write the data into the fixed physical
-// records of the format. A user of this class announces the start of a new
-// logical record and the size of its content. While writing the content, the
-// physical records are created for the data. Possible fill bytes at the end of
-// a physical record are written automatically. In principle, the GOFFOstream
-// is agnostic of the endianness of the content. However, it also supports
-// writing data in big endian byte order.
-class GOFFOstream : public raw_ostream {
+// records of the format. A user of this class announces the begin of a new
+// logical record. While writing the payload, the physical records are created
+// for the data. Possible fill bytes at the end of a physical record are written
+// automatically. In principle, the GOFFOstream is agnostic of the endianness of
+// the payload. However, it also supports writing data in big endian byte order.
+//
+// The physical records use the flag field to indicate if the there is a
+// successor and predecessor record. To be able to set these flags while
+// writing, the basic implementation idea is to always buffer the last seen
+// physical record.
+class GOFFOstream {
/// The underlying raw_pwrite_stream.
raw_pwrite_stream &OS;
- /// The remaining size of this logical record, including fill bytes.
- size_t RemainingSize;
-
-#ifndef NDEBUG
- /// The number of bytes needed to fill up the last physical record.
- size_t Gap = 0;
-#endif
-
- /// The number of logical records emitted to far.
- uint32_t LogicalRecords;
-
- /// The type of the current (logical) record.
- GOFF::RecordType CurrentType;
-
- /// Signals start of new record.
- bool NewLogicalRecord;
+ /// The number of logical records emitted so far.
+ uint32_t LogicalRecords = 0;
- /// Static allocated buffer for the stream, used by the raw_ostream class. The
- /// buffer is sized to hold the content of a physical record.
- char Buffer[GOFF::RecordContentLength];
+ /// The number of physical records emitted so far.
+ uint32_t PhysicalRecords = 0;
- // Return the number of bytes left to write until next physical record.
- // Please note that we maintain the total numbers of byte left, not the
- // written size.
- size_t bytesToNextPhysicalRecord() {
- size_t Bytes = RemainingSize % GOFF::RecordContentLength;
- return Bytes ? Bytes : GOFF::RecordContentLength;
- }
-
- /// Write the record prefix of a physical record, using the given record type.
- static void writeRecordPrefix(raw_ostream &OS, GOFF::RecordType Type,
- size_t RemainingSize,
- uint8_t Flags = RecContinuation);
+ /// The size of the buffer. Same as the payload size of a physical record.
+ static constexpr uint8_t BufferSize = GOFF::PayloadLength;
- /// Fill the last physical record of a logical record with zero bytes.
- void fillRecord();
+ /// Current position in buffer.
+ char *BufferPtr = Buffer;
- /// See raw_ostream::write_impl.
- void write_impl(const char *Ptr, size_t Size) override;
+ /// Static allocated buffer for the stream.
+ char Buffer[BufferSize];
- /// Return the current position within the stream, not counting the bytes
- /// currently in the buffer.
- uint64_t current_pos() const override { return OS.tell(); }
+ /// The type of the current logical record, and the flags (aka continued and
+ /// continuation indicators) for the previous (physical) record.
+ uint8_t TypeAndFlags = 0;
public:
- explicit GOFFOstream(raw_pwrite_stream &OS)
- : OS(OS), RemainingSize(0), LogicalRecords(0), NewLogicalRecord(false) {
- SetBuffer(Buffer, sizeof(Buffer));
- }
-
- ~GOFFOstream() { finalize(); }
+ GOFFOstream(raw_pwrite_stream &OS);
+ ~GOFFOstream();
raw_pwrite_stream &getOS() { return OS; }
+ size_t getWrittenSize() const { return PhysicalRecords * GOFF::RecordLength; }
+ uint32_t getNumLogicalRecords() { return LogicalRecords; }
- void newRecord(GOFF::RecordType Type, size_t Size);
-
- void finalize() { fillRecord(); }
+ /// Write the specified bytes.
+ void write(const char *Ptr, size_t Size);
- uint32_t logicalRecords() { return LogicalRecords; }
+ /// Write zeroes, up to a maximum of 16 bytes.
+ void write_zeros(unsigned NumZeros);
- // Support for endian-specific data.
+ /// Support for endian specific data.
----------------
redstar wrote:
Thanks!
https://github.com/llvm/llvm-project/pull/131143
More information about the llvm-commits
mailing list