File: MergeableUpdate.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (33 lines) | stat: -rw-r--r-- 1,292 bytes parent folder | download
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
26
27
28
29
30
31
32
33
<?php

namespace MediaWiki\Deferred;

/**
 * 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 URL objects all use the same MergeableUpdate class, updates that
 * delete URL objects use a different class, and the calling pattern is:
 *   - a) DeferredUpdates::addUpdate( $purgeCdnUrlsA );
 *   - b) DeferredUpdates::addUpdate( $deleteContentUrlsB );
 *   - c) DeferredUpdates::addUpdate( $purgeCdnUrlsB )
 *
 * In this case, purges for urls A and B will all happen after the $deleteContentUrlsB update.
 *
 * @stable to implement
 *
 * @since 1.27
 */
interface MergeableUpdate extends DeferrableUpdate {
	/**
	 * Merge this enqueued update with a new MergeableUpdate of the same qualified class name
	 *
	 * @param MergeableUpdate $update The new update (having the same class)
	 */
	public function merge( MergeableUpdate $update );
}

/** @deprecated class alias since 1.42 */
class_alias( MergeableUpdate::class, 'MergeableUpdate' );