mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 03:37:43 +00:00
LibDebug: Propagate errors around LineProgram
Found while playing Fixme-Roulette.
This commit is contained in:
parent
4093952a6e
commit
c5d3de3f7d
3 changed files with 18 additions and 8 deletions
|
@ -59,7 +59,7 @@ ErrorOr<void> DwarfInfo::populate_compilation_units()
|
||||||
|
|
||||||
u32 length_after_header = compilation_unit_header.length() - (compilation_unit_header.header_size() - offsetof(CompilationUnitHeader, common.version));
|
u32 length_after_header = compilation_unit_header.length() - (compilation_unit_header.header_size() - offsetof(CompilationUnitHeader, common.version));
|
||||||
|
|
||||||
auto line_program = make<LineProgram>(*this, line_info_stream);
|
auto line_program = TRY(LineProgram::create(*this, line_info_stream));
|
||||||
|
|
||||||
// HACK: Clang generates line programs for embedded resource assembly files, but not compile units.
|
// HACK: Clang generates line programs for embedded resource assembly files, but not compile units.
|
||||||
// Meaning that for graphical applications, some line info data would be unread, triggering the assertion below.
|
// Meaning that for graphical applications, some line info data would be unread, triggering the assertion below.
|
||||||
|
|
|
@ -13,15 +13,22 @@
|
||||||
|
|
||||||
namespace Debug::Dwarf {
|
namespace Debug::Dwarf {
|
||||||
|
|
||||||
LineProgram::LineProgram(DwarfInfo& dwarf_info, SeekableStream& stream)
|
LineProgram::LineProgram(DwarfInfo& dwarf_info, SeekableStream& stream, size_t unit_offset)
|
||||||
: m_dwarf_info(dwarf_info)
|
: m_dwarf_info(dwarf_info)
|
||||||
, m_stream(stream)
|
, m_stream(stream)
|
||||||
|
, m_unit_offset(unit_offset)
|
||||||
{
|
{
|
||||||
m_unit_offset = m_stream.tell().release_value_but_fixme_should_propagate_errors();
|
}
|
||||||
parse_unit_header().release_value_but_fixme_should_propagate_errors();
|
|
||||||
parse_source_directories().release_value_but_fixme_should_propagate_errors();
|
ErrorOr<NonnullOwnPtr<LineProgram>> LineProgram::create(DwarfInfo& dwarf_info, SeekableStream& stream)
|
||||||
parse_source_files().release_value_but_fixme_should_propagate_errors();
|
{
|
||||||
run_program().release_value_but_fixme_should_propagate_errors();
|
auto offset = TRY(stream.tell());
|
||||||
|
auto program = TRY(adopt_nonnull_own_or_enomem(new (nothrow) LineProgram(dwarf_info, stream, offset)));
|
||||||
|
TRY(program->parse_unit_header());
|
||||||
|
TRY(program->parse_source_directories());
|
||||||
|
TRY(program->parse_source_files());
|
||||||
|
TRY(program->run_program());
|
||||||
|
return program;
|
||||||
}
|
}
|
||||||
|
|
||||||
ErrorOr<void> LineProgram::parse_unit_header()
|
ErrorOr<void> LineProgram::parse_unit_header()
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <AK/DeprecatedFlyString.h>
|
#include <AK/DeprecatedFlyString.h>
|
||||||
|
#include <AK/NonnullOwnPtr.h>
|
||||||
#include <AK/Vector.h>
|
#include <AK/Vector.h>
|
||||||
#include <LibDebug/Dwarf/DwarfTypes.h>
|
#include <LibDebug/Dwarf/DwarfTypes.h>
|
||||||
|
|
||||||
|
@ -108,7 +109,7 @@ class LineProgram {
|
||||||
AK_MAKE_NONMOVABLE(LineProgram);
|
AK_MAKE_NONMOVABLE(LineProgram);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit LineProgram(DwarfInfo& dwarf_info, SeekableStream& stream);
|
static ErrorOr<NonnullOwnPtr<LineProgram>> create(DwarfInfo& dwarf_info, SeekableStream& stream);
|
||||||
|
|
||||||
struct LineInfo {
|
struct LineInfo {
|
||||||
FlatPtr address { 0 };
|
FlatPtr address { 0 };
|
||||||
|
@ -133,6 +134,8 @@ public:
|
||||||
bool looks_like_embedded_resource() const;
|
bool looks_like_embedded_resource() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
LineProgram(DwarfInfo& dwarf_info, SeekableStream& stream, size_t unit_offset);
|
||||||
|
|
||||||
ErrorOr<void> parse_unit_header();
|
ErrorOr<void> parse_unit_header();
|
||||||
ErrorOr<void> parse_source_directories();
|
ErrorOr<void> parse_source_directories();
|
||||||
ErrorOr<void> parse_source_files();
|
ErrorOr<void> parse_source_files();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue