blob: 01733f48234f9684f35e31dfbf92f60bad225a16 [file] [log] [blame]
// run-pass
// Test slicing expressions on slices and Vecs.
fn main() {
let x: &[isize] = &[1, 2, 3, 4, 5];
let cmp: &[isize] = &[1, 2, 3, 4, 5];
assert_eq!(&x[..], cmp);
let cmp: &[isize] = &[3, 4, 5];
assert_eq!(&x[2..], cmp);
let cmp: &[isize] = &[1, 2, 3];
assert_eq!(&x[..3], cmp);
let cmp: &[isize] = &[2, 3, 4];
assert_eq!(&x[1..4], cmp);
let x: Vec<isize> = vec![1, 2, 3, 4, 5];
let cmp: &[isize] = &[1, 2, 3, 4, 5];
assert_eq!(&x[..], cmp);
let cmp: &[isize] = &[3, 4, 5];
assert_eq!(&x[2..], cmp);
let cmp: &[isize] = &[1, 2, 3];
assert_eq!(&x[..3], cmp);
let cmp: &[isize] = &[2, 3, 4];
assert_eq!(&x[1..4], cmp);
let x: &mut [isize] = &mut [1, 2, 3, 4, 5];
{
let cmp: &mut [isize] = &mut [1, 2, 3, 4, 5];
assert_eq!(&mut x[..], cmp);
}
{
let cmp: &mut [isize] = &mut [3, 4, 5];
assert_eq!(&mut x[2..], cmp);
}
{
let cmp: &mut [isize] = &mut [1, 2, 3];
assert_eq!(&mut x[..3], cmp);
}
{
let cmp: &mut [isize] = &mut [2, 3, 4];
assert_eq!(&mut x[1..4], cmp);
}
let mut x: Vec<isize> = vec![1, 2, 3, 4, 5];
{
let cmp: &mut [isize] = &mut [1, 2, 3, 4, 5];
assert_eq!(&mut x[..], cmp);
}
{
let cmp: &mut [isize] = &mut [3, 4, 5];
assert_eq!(&mut x[2..], cmp);
}
{
let cmp: &mut [isize] = &mut [1, 2, 3];
assert_eq!(&mut x[..3], cmp);
}
{
let cmp: &mut [isize] = &mut [2, 3, 4];
assert_eq!(&mut x[1..4], cmp);
}
}