-
Notifications
You must be signed in to change notification settings - Fork 106
/
Copy pathfixedarray_block.mbt
117 lines (114 loc) · 3.65 KB
/
fixedarray_block.mbt
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Copyright 2025 International Digital Economy Academy
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
///|
/// Copies a slice of elements from one fixed array to another.
///
/// This function copies `len` elements from `src` starting at `src_offset` to `dst` starting at `dst_offset`.
/// The arrays may overlap, in which case the copy is performed in a way that preserves the data.
///
/// # Example
/// ```
/// let src = FixedArray::from_array([1, 2, 3, 4, 5])
/// let dst = FixedArray::from_array([0, 0, 0, 0, 0])
/// FixedArray::unsafe_blit(dst, 0, src, 0, 3)
/// assert_eq!(dst, FixedArray::from_array([1, 2, 3, 0, 0]))
/// ```
///
/// The behavior is undefined and platform-specific if:
/// - `len < 0`
/// - `src_offset < 0`
/// - `dst_offset < 0`
/// - `dst_offset + len > dst.length()`
/// - `src_offset + len > src.length()`
///
#intrinsic("%fixedarray.copy")
pub fn FixedArray::unsafe_blit[A](
dst : FixedArray[A],
dst_offset : Int,
src : FixedArray[A],
src_offset : Int,
len : Int
) -> Unit {
if physical_equal(dst, src) && dst_offset < src_offset {
for i in 0..<len {
dst[dst_offset + i] = src[src_offset + i]
}
} else {
for i = len - 1; i >= 0; i = i - 1 {
dst[dst_offset + i] = src[src_offset + i]
}
}
}
///|
#intrinsic("%fixedarray.copy")
/// This is the same as `unsafe_blit`, but it is used when the source array is
/// FixedArray[T] instead of UninitializedArray[T].
fn UninitializedArray::unsafe_blit_fixed[T](
dst : UninitializedArray[T],
dst_offset : Int,
src : FixedArray[T],
src_offset : Int,
len : Int
) -> Unit {
for i = len - 1; i >= 0; i = i - 1 {
dst[dst_offset + i] = src[src_offset + i]
}
}
///|
/// Copies a sequence of elements from the source fixed array to a destination
/// fixed array. The arrays may overlap, in which case the copy is performed in a
/// way that preserves the data.
///
/// Parameters:
///
/// * `self` : The source fixed array from which elements will be copied.
/// * `dst` : The destination fixed array where elements will be copied to.
/// * `len` : The number of elements to copy.
/// * `src_offset` : The starting position in the source array. Defaults to 0.
/// * `dst_offset` : The starting position in the destination array. Defaults to
/// 0.
///
/// Throws a panic if:
///
/// * `src_offset + len` exceeds the length of the source array
/// * `dst_offset + len` exceeds the length of the destination array
///
/// Example:
///
/// ```moonbit
/// test "FixedArray::blit_to" {
/// let src = FixedArray::make(5, 1)
/// let dst = FixedArray::make(5, 0)
/// src.blit_to(dst, len=3, src_offset=1, dst_offset=2)
/// inspect!(dst, content="[0, 0, 1, 1, 1]")
/// }
///
/// test "panic FixedArray::blit_to/out_of_bounds" {
/// let src = FixedArray::make(3, 1)
/// let dst = FixedArray::make(3, 0)
/// ignore(src.blit_to(dst, len=4)) // Panics: length out of bounds
/// }
/// ```
pub fn FixedArray::blit_to[A](
self : FixedArray[A],
dst : FixedArray[A],
len~ : Int,
src_offset~ : Int = 0,
dst_offset~ : Int = 0
) -> Unit {
if dst_offset + len > dst.length() || src_offset + len > self.length() {
panic()
}
FixedArray::unsafe_blit(dst, dst_offset, self, src_offset, len)
}