Linux vmi284606.contaboserver.net 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64
Apache/2.4.57 (Ubuntu)
: 167.86.127.34 | : 216.73.217.31
Cant Read [ /etc/named.conf ]
7.2.24-0ubuntu0.18.04.17
root
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
usr /
local /
go /
src /
reflect /
[ HOME SHELL ]
Name
Size
Permission
Action
all_test.go
173.95
KB
-rw-r--r--
asm_386.s
1.04
KB
-rw-r--r--
asm_amd64.s
1.05
KB
-rw-r--r--
asm_arm.s
1.07
KB
-rw-r--r--
asm_arm64.s
1.07
KB
-rw-r--r--
asm_mips64x.s
1.12
KB
-rw-r--r--
asm_mipsx.s
1.12
KB
-rw-r--r--
asm_ppc64x.s
1.22
KB
-rw-r--r--
asm_riscv64.s
1.06
KB
-rw-r--r--
asm_s390x.s
1.07
KB
-rw-r--r--
asm_wasm.s
1.11
KB
-rw-r--r--
deepequal.go
6.61
KB
-rw-r--r--
example_test.go
3.73
KB
-rw-r--r--
export_test.go
2.54
KB
-rw-r--r--
makefunc.go
4.94
KB
-rw-r--r--
set_test.go
5.77
KB
-rw-r--r--
swapper.go
1.92
KB
-rw-r--r--
tostring_test.go
2.14
KB
-rw-r--r--
type.go
84.92
KB
-rw-r--r--
value.go
80.39
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : swapper.go
// Copyright 2016 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package reflect import "unsafe" // Swapper returns a function that swaps the elements in the provided // slice. // // Swapper panics if the provided interface is not a slice. func Swapper(slice interface{}) func(i, j int) { v := ValueOf(slice) if v.Kind() != Slice { panic(&ValueError{Method: "Swapper", Kind: v.Kind()}) } // Fast path for slices of size 0 and 1. Nothing to swap. switch v.Len() { case 0: return func(i, j int) { panic("reflect: slice index out of range") } case 1: return func(i, j int) { if i != 0 || j != 0 { panic("reflect: slice index out of range") } } } typ := v.Type().Elem().(*rtype) size := typ.Size() hasPtr := typ.ptrdata != 0 // Some common & small cases, without using memmove: if hasPtr { if size == ptrSize { ps := *(*[]unsafe.Pointer)(v.ptr) return func(i, j int) { ps[i], ps[j] = ps[j], ps[i] } } if typ.Kind() == String { ss := *(*[]string)(v.ptr) return func(i, j int) { ss[i], ss[j] = ss[j], ss[i] } } } else { switch size { case 8: is := *(*[]int64)(v.ptr) return func(i, j int) { is[i], is[j] = is[j], is[i] } case 4: is := *(*[]int32)(v.ptr) return func(i, j int) { is[i], is[j] = is[j], is[i] } case 2: is := *(*[]int16)(v.ptr) return func(i, j int) { is[i], is[j] = is[j], is[i] } case 1: is := *(*[]int8)(v.ptr) return func(i, j int) { is[i], is[j] = is[j], is[i] } } } s := (*sliceHeader)(v.ptr) tmp := unsafe_New(typ) // swap scratch space return func(i, j int) { if uint(i) >= uint(s.Len) || uint(j) >= uint(s.Len) { panic("reflect: slice index out of range") } val1 := arrayAt(s.Data, i, size, "i < s.Len") val2 := arrayAt(s.Data, j, size, "j < s.Len") typedmemmove(typ, tmp, val1) typedmemmove(typ, val1, val2) typedmemmove(typ, val2, tmp) } }
Close