SplitterV2

SplitterV2 decodes a Batcher v2 super-frame and emits one Rogue stream frame per record.

Protocol reference: https://confluence.slac.stanford.edu/x/L2VlK

SplitterV2 objects in C++ are referenced by the following shared pointer typedef:

typedef std::shared_ptr<rogue::protocols::batcher::SplitterV2> rogue::protocols::batcher::SplitterV2Ptr

The class description is shown below:

class SplitterV2 : public rogue::interfaces::stream::Master, public rogue::interfaces::stream::Slave

Splits one batcher v2 super-frame into per-record output frames.

Protocol reference: https://confluence.slac.stanford.edu/x/L2VlK

SplitterV2 uses CoreV2 to parse a batcher super-frame, then emits one Rogue stream frame per parsed Data record:

  • Payload bytes copied from record data.

  • Channel set from record destination.

  • First/last user fields propagated from record metadata.

Threading model:

  • No internal worker thread is created.

  • Processing executes synchronously in the caller thread of acceptFrame().

Public Functions

SplitterV2()

Constructs a SplitterV2 instance.

This constructor is a low-level C++ allocation path. Prefer create() when shared ownership or Python exposure is required.

~SplitterV2()

Destroys the splitter.

virtual void acceptFrame(std::shared_ptr<rogue::interfaces::stream::Frame> frame)

Accepts one batcher v2 frame and emits parsed records as frames.

Parameters:

frame – Input batcher super-frame.

Public Static Functions

static std::shared_ptr<rogue::protocols::batcher::SplitterV2> create()

Creates a SplitterV2 instance.

This static factory is the preferred construction path when the object is shared across Rogue graph connections or exposed to Python. It returns std::shared_ptr ownership compatible with Rogue pointer typedefs.

Returns:

Shared pointer to the created splitter.

static void setup_python()

Registers Python bindings for this class.