View source code
					
 Display the source code in std/algorithm/mutation.d from which this page was generated on
 github.
					
				
				
 Improve this page
					
 Quickly fork, edit online, and submit a pull request for this page.
 Requires a signed-in GitHub account. This works well for small changes.
 If you'd like to make larger changes you may want to consider using
 local clone.
					
				
				
 Page wiki
					
 View or edit the community-maintained wiki page associated with this page.
					
				
			
			Module std.algorithm.mutation
			This is a submodule of std.algorithm. It contains generic mutation algorithms.
| Function Name | Description | 
|---|---|
| bringToFront | If a = [1, 2, 3]andb = [4, 5, 6, 7],leavesa = [4, 5, 6]andb = [7, 1, 2, 3]. | 
| copy | Copies a range to another. If a = [1, 2, 3]andb = new int[5], thenleavesb = [1, 2, 3, 0, 0]and returnsb[3 .. $]. | 
| fill | Fills a range with a pattern,
        e.g., if a = new int[3], thenleavesa = [4, 4, 4]andleavesa = [3, 4, 3]. | 
| initializeAll | If a = [1.2, 3.4], thenleavesa = [double.init, double.init]. | 
| move | movesaintob.readsadestructively. | 
| moveAll | Moves all elements from one range to another. | 
| moveSome | Moves as many elements as possible from one range to another. | 
| remove | Removes elements from a range in-place, and returns the shortened range. | 
| reverse | If a = [1, 2, 3],changes it to[3, 2, 1]. | 
| strip | Strips all leading and trailing elements equal to a value, or that
        satisfy a predicate.
        If a = [1, 1, 0, 1, 1], thenandreturns[0]. | 
| stripLeft | Strips all leading elements equal to a value, or that satisfy a
        predicate.  If a = [1, 1, 0, 1, 1], thenandreturns[0, 1, 1]. | 
| stripRight | Strips all trailing elements equal to a value, or that satisfy a
        predicate.
        If a = [1, 1, 0, 1, 1], thenandreturns[1, 1, 0]. | 
| swap | Swaps two values. | 
| swapRanges | Swaps all elements of two ranges. | 
| uninitializedFill | Fills a range (assumed uninitialized) with a value. | 
Functions
| Name | Description | 
|---|---|
| bringToFront | The function has considerable flexibility and
usefulness. It can rotate elements in one buffer left or right,swapbuffers of equal length, and evenmoveelements across disjoint
buffers of different types and different lengths. | 
| copy | Copies the content of intoand returns the
remaining (unfilled) part of. | 
| fill | Assigns to each element of input range. | 
| fill | Fills with a pattern copied from. The length ofdoes not have to be a multiple of the length of. Ifis empty, an exception is thrown. | 
| initializeAll | Initializes all elements of with their.initvalue.
Assumes that the elements of therangeare uninitialized. | 
| move | Moves intovia a destructivecopy. | 
| moveAll | For each element ainand each elementbinin lockstep in increasing order, calls. | 
| moveEmplaceAll | Similar to moveAllbut assumes all elements intargetare
 uninitialized. Uses moveEmplace tomoveelements fromsourceover elements fromtarget. | 
| moveEmplaceSome | Same as moveSomebut assumes all elements intargetare
 uninitialized. Uses moveEmplace tomoveelements fromsourceover elements fromtarget. | 
| moveSome | For each element ainand each elementbinin lockstep in increasing order, calls. Stops
when eitherorhave been exhausted. | 
| remove | Eliminates elements at given offsets from and returns the
shortenedrange. In the simplest call, one element is removed. | 
| remove | Reduces the length of the bidirectional rangeby removing
elements that satisfypred. Ifs = ,
elements are moved from the right end of therangeover the elements
to eliminate. Ifs = (the default),
elements are moved progressively to front such that their relative
order is preserved. Returns the filteredrange. | 
| reverse | Reverses in-place.  Performsr.length / 2evaluations of. | 
| reverse | Reverses rin-place, whereris a narrow string (having
elements of typecharorwchar). UTF sequences consisting of
multiple code units are preserved properly. | 
| strip | The stripgroup of functions allow stripping of either leading, trailing,
    or both leading and trailing elements. | 
| stripLeft | The stripgroup of functions allow stripping of either leading, trailing,
    or both leading and trailing elements. | 
| stripRight | The stripgroup of functions allow stripping of either leading, trailing,
    or both leading and trailing elements. | 
| swap | Swaps and. The instancesandare moved in
memory, without ever callingopAssign, nor any other function.Tneed not be assignable at all to be swapped. | 
| swapRanges | Swaps all elements of with successive elements in.
Returns a tuple containing the remainder portions ofandthat were not swapped (one of them will be empty). The ranges may
be of different types but must have the same element type and support
swapping. | 
| uninitializedFill | Initializes each element of with.
Assumes that the elements of therangeare uninitialized.
This is of interest for structs that
definecopyconstructors (for all other types,fillanduninitializedFillare equivalent). | 
Enums
| Name | Description | 
|---|---|
| SwapStrategy | Defines the swapping strategy for algorithms that need to swapelements in a range (such as partition and sort). The strategy
concerns the swapping of elements that are not the core concern of the
algorithm. For example, consider an algorithm that sorts[ "abc",
"b", "aBc" ]according totoUpper(a) < toUpper(b). That
algorithm might choose toswapthe two equivalent strings"abc"and"aBc". That does not affect the sorting since both[
"abc", "aBc", "b" ]and[ "aBc", "abc", "b" ]are valid
outcomes. |