================
@@ -142,6 +142,13 @@ class MinidumpFileBuilder {
   lldb_private::Status AddDirectory(llvm::minidump::StreamType type,
                                     uint64_t stream_size);
   lldb::offset_t GetCurrentDataEndOffset() const;
+
+  // Read a memory region from the process and write it to the file
+  // in fixed size chunks.
+  lldb_private::Status ReadWriteMemoryInChunks(
+      const std::unique_ptr<lldb_private::DataBufferHeap> &data_up,
+      const lldb_private::CoreFileMemoryRange &range, uint64_t *bytes_read);
+
----------------
clayborg wrote:

Move this into the PostMortemProcess.h/.cpp and have it take a lambda callback:
```
lldb_private::Status ReadMemoryInChunks(
    lldb_private::CoreFileMemoryRange &range, 
    uint64_t chunk_size, 
    lldb_private::DataBufferHeap &data, // Re-use between calls if needed, 
might expand to chunk_size
    const std::function<Status(const uint8_t *bytes, uint64_t length)> 
&chunk_callback,
    uint64_t &bytes_read); 
```
Then `chunk_callback` gets called for each chunk that is read and your 
ProcessMinidump can pass in a lambda that just calls `AddData(...)`

There is no need to create a `const 
std::unique_ptr<lldb_private::DataBufferHeap> &data_up`, just create a local 
`lldb_private::DataBufferHeap heap(...)`. The unique pointer does nothing 
useful here

https://github.com/llvm/llvm-project/pull/129307
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to