From afcf60fe15999ea07193118f447a34f41171e433 Mon Sep 17 00:00:00 2001 From: Sean Silva Date: Tue, 18 Jun 2013 23:14:03 +0000 Subject: [yaml2obj][ELF] Rudimentary symbol table support. Currently, we only output the name. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184255 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Object/ELFYAML.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'lib') diff --git a/lib/Object/ELFYAML.cpp b/lib/Object/ELFYAML.cpp index e0e95bee93..32a759dc0b 100644 --- a/lib/Object/ELFYAML.cpp +++ b/lib/Object/ELFYAML.cpp @@ -260,6 +260,10 @@ void MappingTraits::mapping(IO &IO, IO.mapOptional("Entry", FileHdr.Entry, Hex64(0)); } +void MappingTraits::mapping(IO &IO, ELFYAML::Symbol &Symbol) { + IO.mapOptional("Name", Symbol.Name, StringRef()); +} + void MappingTraits::mapping(IO &IO, ELFYAML::Section &Section) { IO.mapOptional("Name", Section.Name, StringRef()); @@ -269,6 +273,12 @@ void MappingTraits::mapping(IO &IO, IO.mapOptional("Content", Section.Content); IO.mapOptional("Link", Section.Link); IO.mapOptional("AddressAlign", Section.AddressAlign, Hex64(0)); + // TODO: Error if `Type` is SHT_SYMTAB and this is not present, or if + // `Type` is *not* SHT_SYMTAB and this *is* present. (By SHT_SYMTAB I + // also mean SHT_DYNSYM, but for simplicity right now we just do + // SHT_SYMTAB). Want to be able to share the predicate with consumers of + // this structure. + IO.mapOptional("Symbols", Section.Symbols); } void MappingTraits::mapping(IO &IO, ELFYAML::Object &Object) { -- cgit v1.2.3