getRole(); $inherited[$role] = SlotRecord::newInherited( $slot ); } return new MutableRevisionSlots( $inherited ); } /** * @param SlotRecord[] $slots An array of SlotRecords. */ public function __construct( array $slots = [] ) { parent::__construct( $slots ); } /** * Sets the given slot. * If a slot with the same role is already present, it is replaced. * * @note This may cause the slot meta-data for the revision to be lazy-loaded. * * @param SlotRecord $slot */ public function setSlot( SlotRecord $slot ) { if ( !is_array( $this->slots ) ) { $this->getSlots(); // initialize $this->slots } $role = $slot->getRole(); $this->slots[$role] = $slot; } /** * Sets the content for the slot with the given role. * If a slot with the same role is already present, it is replaced. * * @note This may cause the slot meta-data for the revision to be lazy-loaded. * * @param string $role * @param Content $content */ public function setContent( $role, Content $content ) { $slot = SlotRecord::newUnsaved( $role, $content ); $this->setSlot( $slot ); } /** * Remove the slot for the given role, discontinue the corresponding stream. * * @note This may cause the slot meta-data for the revision to be lazy-loaded. * * @param string $role */ public function removeSlot( $role ) { if ( !is_array( $this->slots ) ) { $this->getSlots(); // initialize $this->slots } unset( $this->slots[$role] ); } /** * Return all slots that are not inherited. * * @note This may cause the slot meta-data for the revision to be lazy-loaded. * * @return SlotRecord[] */ public function getTouchedSlots() { return array_filter( $this->getSlots(), function ( SlotRecord $slot ) { return !$slot->isInherited(); } ); } /** * Return all slots that are inherited. * * @note This may cause the slot meta-data for the revision to be lazy-loaded. * * @return SlotRecord[] */ public function getInheritedSlots() { return array_filter( $this->getSlots(), function ( SlotRecord $slot ) { return $slot->isInherited(); } ); } }