Documentation ¶
Overview ¶
Package dwarfbuilder provides a way to build DWARF sections with arbitrary contents.
Index ¶
- func LocationBlock(args ...interface{}) []byte
- type Address
- type Builder
- func (b *Builder) AddBaseType(typename string, encoding Encoding, byteSz uint16) dwarf.Offset
- func (b *Builder) AddCompileUnit(name string, lowPC uint64) dwarf.Offset
- func (b *Builder) AddMember(fieldname string, typ dwarf.Offset, memberLoc []byte) dwarf.Offset
- func (b *Builder) AddPointerType(typename string, typ dwarf.Offset) dwarf.Offset
- func (b *Builder) AddStructType(typename string, byteSz uint16) dwarf.Offset
- func (b *Builder) AddSubprogram(fnname string, lowpc, highpc uint64) dwarf.Offset
- func (b *Builder) AddVariable(varname string, typ dwarf.Offset, loc interface{}) dwarf.Offset
- func (b *Builder) Attr(attr dwarf.Attr, val interface{}) dwarf.Offset
- func (b *Builder) Build() (abbrev, aranges, frame, info, line, pubnames, ranges, str, loc []byte, ...)
- func (b *Builder) PatchOffset(patchedOffset, patch dwarf.Offset)
- func (b *Builder) SetHasChildren()
- func (b *Builder) TagClose()
- func (b *Builder) TagOpen(tag dwarf.Tag, name string) dwarf.Offset
- type Encoding
- type Form
- type LocEntry
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func LocationBlock ¶
func LocationBlock(args ...interface{}) []byte
LocationBlock returns a DWARF expression corresponding to the list of arguments.
Types ¶
type Builder ¶
type Builder struct {
// contains filtered or unexported fields
}
Builder dwarf builder
func (*Builder) AddBaseType ¶
AddBaseType adds a new base type entry to debug_info. Will write a DW_TAG_base_type, followed by a DW_AT_encoding and a DW_AT_byte_size.
func (*Builder) AddCompileUnit ¶
func (*Builder) AddMember ¶
AddMember adds a new member entry to debug_info. Writes a DW_TAG_member followed by DW_AT_type and DW_AT_data_member_loc.
func (*Builder) AddPointerType ¶
AddPointerType adds a new pointer type to debug_info.
func (*Builder) AddStructType ¶
AddStructType adds a new structure type to debug_info. Call TagClose to finish adding fields. Will write a DW_TAG_struct_type, followed by a DW_AT_byte_size.
func (*Builder) AddSubprogram ¶
AddSubprogram adds a subprogram declaration to debug_info, must call TagClose after adding all local variables and parameters. Will write an abbrev corresponding to a DW_TAG_subprogram, followed by a DW_AT_lowpc and a DW_AT_highpc.
func (*Builder) AddVariable ¶
AddVariable adds a new variable entry to debug_info. Will write a DW_TAG_variable, followed by a DW_AT_type and a DW_AT_location.
func (*Builder) Build ¶
func (b *Builder) Build() (abbrev, aranges, frame, info, line, pubnames, ranges, str, loc []byte, err error)
Build closes b and returns all the dwarf sections.
func (*Builder) PatchOffset ¶
PatchOffset writes the offset 'patch' at offset patchedOffset.
func (*Builder) SetHasChildren ¶
func (b *Builder) SetHasChildren()
SetHasChildren sets the current DIE as having children (even if none are added).
type Encoding ¶
type Encoding uint16
Encoding represents a DWARF base type encoding (see section 7.8, page 168 and following, DWARF v4).
const ( DW_ATE_address Encoding = 0x01 DW_ATE_boolean Encoding = 0x02 DW_ATE_complex_float Encoding = 0x03 DW_ATE_float Encoding = 0x04 DW_ATE_signed Encoding = 0x05 DW_ATE_signed_char Encoding = 0x06 DW_ATE_unsigned Encoding = 0x07 DW_ATE_unsigned_char Encoding = 0x08 DW_ATE_imaginary_float Encoding = 0x09 DW_ATE_packed_decimal Encoding = 0x0a DW_ATE_numeric_string Encoding = 0x0b DW_ATE_edited Encoding = 0x0c DW_ATE_signed_fixed Encoding = 0x0d DW_ATE_unsigned_fixed Encoding = 0x0e DW_ATE_decimal_float Encoding = 0x0f DW_ATE_UTF Encoding = 0x10 DW_ATE_lo_user Encoding = 0x80 DW_ATE_hi_user Encoding = 0xff )
type Form ¶
type Form uint16
Form represents a DWARF form kind (see Figure 20, page 160 and following, DWARF v4)
const ( DW_FORM_addr Form = 0x01 // address DW_FORM_block2 Form = 0x03 // block DW_FORM_block4 Form = 0x04 // block DW_FORM_data2 Form = 0x05 // constant DW_FORM_data4 Form = 0x06 // constant DW_FORM_data8 Form = 0x07 // constant DW_FORM_string Form = 0x08 // string DW_FORM_block Form = 0x09 // block DW_FORM_block1 Form = 0x0a // block DW_FORM_data1 Form = 0x0b // constant DW_FORM_flag Form = 0x0c // flag DW_FORM_sdata Form = 0x0d // constant DW_FORM_strp Form = 0x0e // string DW_FORM_udata Form = 0x0f // constant DW_FORM_ref_addr Form = 0x10 // reference DW_FORM_ref1 Form = 0x11 // reference DW_FORM_ref2 Form = 0x12 // reference DW_FORM_ref4 Form = 0x13 // reference DW_FORM_ref8 Form = 0x14 // reference DW_FORM_ref_udata Form = 0x15 // reference DW_FORM_indirect Form = 0x16 // (see Section 7.5.3) DW_FORM_sec_offset Form = 0x17 // lineptr, loclistptr, macptr, rangelistptr DW_FORM_exprloc Form = 0x18 // exprloc DW_FORM_flag_present Form = 0x19 // flag DW_FORM_ref_sig8 Form = 0x20 // reference )