Fetch the repository succeeded.
// Package dwarfbuilder provides a way to build DWARF sections with
// arbitrary contents.
package dwarfbuilder
import (
"bytes"
"debug/dwarf"
"encoding/binary"
"fmt"
)
type Builder struct {
info bytes.Buffer
loc bytes.Buffer
abbrevs []tagDescr
tagStack []*tagState
}
// New creates a new DWARF builder.
func New() *Builder {
b := &Builder{}
b.info.Write([]byte{
0x0, 0x0, 0x0, 0x0, // length
0x4, 0x0, // version
0x0, 0x0, 0x0, 0x0, // debug_abbrev_offset
0x8, // address_size
})
b.TagOpen(dwarf.TagCompileUnit, "go")
b.Attr(dwarf.AttrLanguage, uint8(22))
return b
}
// Build closes b and returns all the dwarf sections.
func (b *Builder) Build() (abbrev, aranges, frame, info, line, pubnames, ranges, str, loc []byte, err error) {
b.TagClose()
if len(b.tagStack) > 0 {
err = fmt.Errorf("unbalanced TagOpen/TagClose %d", len(b.tagStack))
return
}
abbrev = b.makeAbbrevTable()
info = b.info.Bytes()
binary.LittleEndian.PutUint32(info, uint32(len(info)-4))
loc = b.loc.Bytes()
return
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。