aboutsummaryrefslogtreecommitdiffstats
path: root/includes/deferred/MergeableUpdate.php
blob: a0da1fb2dd02be3b928f8e22b7ce870578c3f551 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?php

/**
 * Interface that deferrable updates can implement to signal that updates can be combined.
 *
 * DeferredUpdates uses this to merge all pending updates of PHP class into a single update
 * by calling merge(). Note that upon merge(), the combined update goes to the back of the FIFO
 * queue so that such updates occur after related non-mergeable deferred updates. For example,
 * suppose updates that purge URLs can be merged, and the calling pattern is:
 *   - a) DeferredUpdates::addUpdate( $purgeCdnUrlsA );
 *   - b) DeferredUpdates::addUpdate( $deleteContentUrlsB );
 *   - c) DeferredUpdates::addUpdate( $purgeCdnUrlsB )
 *
 * The purges for urls A and B will all happen after the $deleteContentUrlsB update.
 *
 * @since 1.27
 */
interface MergeableUpdate extends DeferrableUpdate {
	/**
	 * Merge this update with $update
	 *
	 * @param MergeableUpdate $update Update of the same class type
	 */
	public function merge( MergeableUpdate $update );
}