X7ROOT File Manager
Current Path:
/opt/golang/1.19.4/src/cmd/link/internal/ld
opt
/
golang
/
1.19.4
/
src
/
cmd
/
link
/
internal
/
ld
/
📁
..
📄
ar.go
(5.38 KB)
📄
asmb.go
(5.21 KB)
📄
config.go
(7.54 KB)
📄
data.go
(89.78 KB)
📄
data_test.go
(2.32 KB)
📄
deadcode.go
(15.66 KB)
📄
deadcode_test.go
(1.34 KB)
📄
decodesym.go
(9.98 KB)
📄
dwarf.go
(72.83 KB)
📄
dwarf_test.go
(46.02 KB)
📄
elf.go
(59.18 KB)
📄
elf_test.go
(2.75 KB)
📄
errors.go
(1.91 KB)
📄
execarchive.go
(901 B)
📄
execarchive_noexec.go
(343 B)
📄
fallocate_test.go
(1.64 KB)
📄
go.go
(11.84 KB)
📄
go_test.go
(2.68 KB)
📄
heap.go
(960 B)
📄
heap_test.go
(1.87 KB)
📄
issue33808_test.go
(792 B)
📄
ld.go
(8.08 KB)
📄
ld_test.go
(8.16 KB)
📄
lib.go
(76.84 KB)
📄
link.go
(5.13 KB)
📄
macho.go
(43.02 KB)
📄
macho_combine_dwarf.go
(13.11 KB)
📄
main.go
(14.01 KB)
📄
nooptcgolink_test.go
(738 B)
📄
outbuf.go
(8.05 KB)
📄
outbuf_darwin.go
(1.48 KB)
📄
outbuf_linux.go
(304 B)
📄
outbuf_mmap.go
(1.51 KB)
📄
outbuf_nofallocate.go
(342 B)
📄
outbuf_nommap.go
(805 B)
📄
outbuf_notdarwin.go
(292 B)
📄
outbuf_test.go
(2.21 KB)
📄
outbuf_windows.go
(2.28 KB)
📄
pcln.go
(28.96 KB)
📄
pe.go
(45.98 KB)
📄
stackcheck.go
(11.86 KB)
📄
stackcheck_test.go
(2.26 KB)
📄
sym.go
(3.89 KB)
📄
symtab.go
(29.49 KB)
📄
target.go
(3.77 KB)
📁
testdata
📄
typelink.go
(1.87 KB)
📄
util.go
(2.46 KB)
📄
xcoff.go
(51.88 KB)
Editing: util.go
// Copyright 2015 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 ld import ( "cmd/link/internal/loader" "encoding/binary" "fmt" "os" ) var atExitFuncs []func() func AtExit(f func()) { atExitFuncs = append(atExitFuncs, f) } // runAtExitFuncs runs the queued set of AtExit functions. func runAtExitFuncs() { for i := len(atExitFuncs) - 1; i >= 0; i-- { atExitFuncs[i]() } atExitFuncs = nil } // Exit exits with code after executing all atExitFuncs. func Exit(code int) { runAtExitFuncs() os.Exit(code) } // Exitf logs an error message then calls Exit(2). func Exitf(format string, a ...interface{}) { fmt.Fprintf(os.Stderr, os.Args[0]+": "+format+"\n", a...) nerrors++ Exit(2) } // afterErrorAction updates 'nerrors' on error and invokes exit or // panics in the proper circumstances. func afterErrorAction() { nerrors++ if *flagH { panic("error") } if nerrors > 20 { Exitf("too many errors") } } // Errorf logs an error message. // // If more than 20 errors have been printed, exit with an error. // // Logging an error means that on exit cmd/link will delete any // output file and return a non-zero error code. // // TODO: remove. Use ctxt.Errorf instead. // All remaining calls use nil as first arg. func Errorf(dummy *int, format string, args ...interface{}) { format += "\n" fmt.Fprintf(os.Stderr, format, args...) afterErrorAction() } // Errorf method logs an error message. // // If more than 20 errors have been printed, exit with an error. // // Logging an error means that on exit cmd/link will delete any // output file and return a non-zero error code. func (ctxt *Link) Errorf(s loader.Sym, format string, args ...interface{}) { if ctxt.loader != nil { ctxt.loader.Errorf(s, format, args...) return } // Note: this is not expected to happen very often. format = fmt.Sprintf("sym %d: %s", s, format) format += "\n" fmt.Fprintf(os.Stderr, format, args...) afterErrorAction() } func artrim(x []byte) string { i := 0 j := len(x) for i < len(x) && x[i] == ' ' { i++ } for j > i && x[j-1] == ' ' { j-- } return string(x[i:j]) } func stringtouint32(x []uint32, s string) { for i := 0; len(s) > 0; i++ { var buf [4]byte s = s[copy(buf[:], s):] x[i] = binary.LittleEndian.Uint32(buf[:]) } } // contains reports whether v is in s. func contains(s []string, v string) bool { for _, x := range s { if x == v { return true } } return false }
Upload File
Create Folder