mirror of https://github.com/encounter/objdiff.git
Version 0.2.2
- Add application icon - Fixes for objects containing multiple sections with the same name
This commit is contained in:
parent
d1d6f1101b
commit
7219e72acf
|
@ -1926,9 +1926,10 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "objdiff"
|
name = "objdiff"
|
||||||
version = "0.2.0"
|
version = "0.2.2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
|
"bytes",
|
||||||
"cfg-if",
|
"cfg-if",
|
||||||
"console_error_panic_hook",
|
"console_error_panic_hook",
|
||||||
"const_format",
|
"const_format",
|
||||||
|
@ -1943,6 +1944,7 @@ dependencies = [
|
||||||
"notify",
|
"notify",
|
||||||
"object",
|
"object",
|
||||||
"path-slash",
|
"path-slash",
|
||||||
|
"png",
|
||||||
"ppc750cl",
|
"ppc750cl",
|
||||||
"rabbitizer",
|
"rabbitizer",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
|
@ -1958,6 +1960,7 @@ dependencies = [
|
||||||
"twox-hash",
|
"twox-hash",
|
||||||
"vergen",
|
"vergen",
|
||||||
"winapi",
|
"winapi",
|
||||||
|
"winres",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -3520,6 +3523,15 @@ dependencies = [
|
||||||
"winapi",
|
"winapi",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "winres"
|
||||||
|
version = "0.1.12"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "b68db261ef59e9e52806f688020631e987592bd83619edccda9c47d42cde4f6c"
|
||||||
|
dependencies = [
|
||||||
|
"toml",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wio"
|
name = "wio"
|
||||||
version = "0.2.2"
|
version = "0.2.2"
|
||||||
|
|
11
Cargo.toml
11
Cargo.toml
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "objdiff"
|
name = "objdiff"
|
||||||
version = "0.2.1"
|
version = "0.2.2"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
rust-version = "1.62"
|
rust-version = "1.62"
|
||||||
authors = ["Luke Street <luke@street.dev>"]
|
authors = ["Luke Street <luke@street.dev>"]
|
||||||
|
@ -18,6 +18,7 @@ strip = "debuginfo"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
anyhow = "1.0.66"
|
anyhow = "1.0.66"
|
||||||
|
bytes = "1.3.0"
|
||||||
cfg-if = "1.0.0"
|
cfg-if = "1.0.0"
|
||||||
const_format = "0.2.30"
|
const_format = "0.2.30"
|
||||||
cwdemangle = { git = "https://github.com/encounter/cwdemangle", rev = "286f3d1d29ee2457db89043782725631845c3e4c" }
|
cwdemangle = { git = "https://github.com/encounter/cwdemangle", rev = "286f3d1d29ee2457db89043782725631845c3e4c" }
|
||||||
|
@ -29,22 +30,26 @@ log = "0.4.17"
|
||||||
memmap2 = "0.5.8"
|
memmap2 = "0.5.8"
|
||||||
notify = "5.0.0"
|
notify = "5.0.0"
|
||||||
object = { version = "0.30.0", features = ["read_core", "std", "elf"], default-features = false }
|
object = { version = "0.30.0", features = ["read_core", "std", "elf"], default-features = false }
|
||||||
|
png = "0.17.7"
|
||||||
ppc750cl = { git = "https://github.com/encounter/ppc750cl", rev = "aa631a33de7882c679afca89350898b87cb3ba3f" }
|
ppc750cl = { git = "https://github.com/encounter/ppc750cl", rev = "aa631a33de7882c679afca89350898b87cb3ba3f" }
|
||||||
rabbitizer = { git = "https://github.com/encounter/rabbitizer-rs", rev = "10c279b2ef251c62885b1dcdcfe740b0db8e9956" }
|
rabbitizer = { git = "https://github.com/encounter/rabbitizer-rs", rev = "10c279b2ef251c62885b1dcdcfe740b0db8e9956" }
|
||||||
|
reqwest = "0.11.13"
|
||||||
rfd = { version = "0.10.0" } # , default-features = false, features = ['xdg-portal']
|
rfd = { version = "0.10.0" } # , default-features = false, features = ['xdg-portal']
|
||||||
self_update = "0.32.0"
|
self_update = "0.32.0"
|
||||||
serde = { version = "1", features = ["derive"] }
|
serde = { version = "1", features = ["derive"] }
|
||||||
|
tempfile = "3.3.0"
|
||||||
thiserror = "1.0.37"
|
thiserror = "1.0.37"
|
||||||
time = { version = "0.3.17", features = ["formatting", "local-offset"] }
|
time = { version = "0.3.17", features = ["formatting", "local-offset"] }
|
||||||
toml = "0.5.9"
|
toml = "0.5.9"
|
||||||
twox-hash = "1.6.3"
|
twox-hash = "1.6.3"
|
||||||
tempfile = "3.3.0"
|
|
||||||
reqwest = "0.11.13"
|
|
||||||
|
|
||||||
[target.'cfg(windows)'.dependencies]
|
[target.'cfg(windows)'.dependencies]
|
||||||
path-slash = "0.2.1"
|
path-slash = "0.2.1"
|
||||||
winapi = "0.3.9"
|
winapi = "0.3.9"
|
||||||
|
|
||||||
|
[target.'cfg(windows)'.build-dependencies]
|
||||||
|
winres = "0.1.12"
|
||||||
|
|
||||||
[target.'cfg(unix)'.dependencies]
|
[target.'cfg(unix)'.dependencies]
|
||||||
exec = "0.3.1"
|
exec = "0.3.1"
|
||||||
|
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 36 KiB |
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
Binary file not shown.
After Width: | Height: | Size: 8.9 KiB |
8
build.rs
8
build.rs
|
@ -1,4 +1,10 @@
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use vergen::{vergen, Config};
|
use vergen::{vergen, Config};
|
||||||
|
|
||||||
fn main() -> Result<()> { vergen(Config::default()) }
|
fn main() -> Result<()> {
|
||||||
|
#[cfg(windows)]
|
||||||
|
{
|
||||||
|
winres::WindowsResource::new().set_icon("assets/icon.ico").compile()?;
|
||||||
|
}
|
||||||
|
vergen(Config::default())
|
||||||
|
}
|
||||||
|
|
|
@ -79,6 +79,11 @@ impl Default for ViewConfig {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub struct SymbolReference {
|
||||||
|
pub symbol_name: String,
|
||||||
|
pub section_index: usize,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(serde::Deserialize, serde::Serialize)]
|
#[derive(serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(default)]
|
#[serde(default)]
|
||||||
pub struct ViewState {
|
pub struct ViewState {
|
||||||
|
@ -89,7 +94,7 @@ pub struct ViewState {
|
||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
pub highlighted_symbol: Option<String>,
|
pub highlighted_symbol: Option<String>,
|
||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
pub selected_symbol: Option<String>,
|
pub selected_symbol: Option<SymbolReference>,
|
||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
pub current_view: View,
|
pub current_view: View,
|
||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
|
|
28
src/main.rs
28
src/main.rs
|
@ -3,9 +3,27 @@
|
||||||
|
|
||||||
use std::{path::PathBuf, rc::Rc, sync::Mutex};
|
use std::{path::PathBuf, rc::Rc, sync::Mutex};
|
||||||
|
|
||||||
|
use anyhow::{Error, Result};
|
||||||
use cfg_if::cfg_if;
|
use cfg_if::cfg_if;
|
||||||
|
use eframe::IconData;
|
||||||
use time::UtcOffset;
|
use time::UtcOffset;
|
||||||
|
|
||||||
|
fn load_icon() -> Result<IconData> {
|
||||||
|
use bytes::Buf;
|
||||||
|
let decoder = png::Decoder::new(include_bytes!("../assets/icon_64.png").reader());
|
||||||
|
let mut reader = decoder.read_info()?;
|
||||||
|
let mut buf = vec![0; reader.output_buffer_size()];
|
||||||
|
let info = reader.next_frame(&mut buf)?;
|
||||||
|
if info.bit_depth != png::BitDepth::Eight {
|
||||||
|
return Err(Error::msg("Invalid bit depth"));
|
||||||
|
}
|
||||||
|
if info.color_type != png::ColorType::Rgba {
|
||||||
|
return Err(Error::msg("Invalid color type"));
|
||||||
|
}
|
||||||
|
buf.truncate(info.buffer_size());
|
||||||
|
Ok(IconData { rgba: buf, width: info.width, height: info.height })
|
||||||
|
}
|
||||||
|
|
||||||
// When compiling natively:
|
// When compiling natively:
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(not(target_arch = "wasm32"))]
|
||||||
fn main() {
|
fn main() {
|
||||||
|
@ -19,7 +37,15 @@ fn main() {
|
||||||
|
|
||||||
let exec_path: Rc<Mutex<Option<PathBuf>>> = Rc::new(Mutex::new(None));
|
let exec_path: Rc<Mutex<Option<PathBuf>>> = Rc::new(Mutex::new(None));
|
||||||
let exec_path_clone = exec_path.clone();
|
let exec_path_clone = exec_path.clone();
|
||||||
let native_options = eframe::NativeOptions::default();
|
let mut native_options = eframe::NativeOptions::default();
|
||||||
|
match load_icon() {
|
||||||
|
Ok(data) => {
|
||||||
|
native_options.icon_data = Some(data);
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
log::warn!("Failed to load application icon: {}", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
// native_options.renderer = eframe::Renderer::Wgpu;
|
// native_options.renderer = eframe::Renderer::Wgpu;
|
||||||
eframe::run_native(
|
eframe::run_native(
|
||||||
"objdiff",
|
"objdiff",
|
||||||
|
|
|
@ -9,7 +9,7 @@ use object::{
|
||||||
R_PPC_EMB_SDA21, R_PPC_REL14, R_PPC_REL24,
|
R_PPC_EMB_SDA21, R_PPC_REL14, R_PPC_REL24,
|
||||||
},
|
},
|
||||||
Architecture, File, Object, ObjectSection, ObjectSymbol, RelocationKind, RelocationTarget,
|
Architecture, File, Object, ObjectSection, ObjectSymbol, RelocationKind, RelocationTarget,
|
||||||
SectionKind, Symbol, SymbolKind, SymbolSection,
|
SectionIndex, SectionKind, Symbol, SymbolKind, SymbolSection,
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::obj::{
|
use crate::obj::{
|
||||||
|
@ -192,9 +192,7 @@ fn relocations_by_section(
|
||||||
obj_file: &File<'_>,
|
obj_file: &File<'_>,
|
||||||
section: &mut ObjSection,
|
section: &mut ObjSection,
|
||||||
) -> Result<Vec<ObjReloc>> {
|
) -> Result<Vec<ObjReloc>> {
|
||||||
let obj_section = obj_file
|
let obj_section = obj_file.section_by_index(SectionIndex(section.index))?;
|
||||||
.section_by_name(§ion.name)
|
|
||||||
.ok_or_else(|| anyhow::Error::msg("Failed to locate section"))?;
|
|
||||||
let mut relocations = Vec::<ObjReloc>::new();
|
let mut relocations = Vec::<ObjReloc>::new();
|
||||||
for (address, reloc) in obj_section.relocations() {
|
for (address, reloc) in obj_section.relocations() {
|
||||||
let symbol = match reloc.target() {
|
let symbol = match reloc.target() {
|
||||||
|
|
|
@ -5,7 +5,7 @@ use egui_extras::{Size, StripBuilder, TableBuilder};
|
||||||
use time::format_description;
|
use time::format_description;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
app::{View, ViewConfig, ViewState},
|
app::{SymbolReference, View, ViewConfig, ViewState},
|
||||||
jobs::Job,
|
jobs::Job,
|
||||||
obj::{ObjDataDiff, ObjDataDiffKind, ObjInfo, ObjSection},
|
obj::{ObjDataDiff, ObjDataDiffKind, ObjInfo, ObjSection},
|
||||||
views::{write_text, COLOR_RED},
|
views::{write_text, COLOR_RED},
|
||||||
|
@ -13,8 +13,8 @@ use crate::{
|
||||||
|
|
||||||
const BYTES_PER_ROW: usize = 16;
|
const BYTES_PER_ROW: usize = 16;
|
||||||
|
|
||||||
fn find_section<'a>(obj: &'a ObjInfo, section_name: &str) -> Option<&'a ObjSection> {
|
fn find_section<'a>(obj: &'a ObjInfo, selected_symbol: &SymbolReference) -> Option<&'a ObjSection> {
|
||||||
obj.sections.iter().find(|s| s.name == section_name)
|
obj.sections.get(selected_symbol.section_index)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn data_row_ui(ui: &mut egui::Ui, address: usize, diffs: &[ObjDataDiff], config: &ViewConfig) {
|
fn data_row_ui(ui: &mut egui::Ui, address: usize, diffs: &[ObjDataDiff], config: &ViewConfig) {
|
||||||
|
@ -132,11 +132,11 @@ fn data_table_ui(
|
||||||
table: TableBuilder<'_>,
|
table: TableBuilder<'_>,
|
||||||
left_obj: &ObjInfo,
|
left_obj: &ObjInfo,
|
||||||
right_obj: &ObjInfo,
|
right_obj: &ObjInfo,
|
||||||
section_name: &str,
|
selected_symbol: &SymbolReference,
|
||||||
config: &ViewConfig,
|
config: &ViewConfig,
|
||||||
) -> Option<()> {
|
) -> Option<()> {
|
||||||
let left_section = find_section(left_obj, section_name)?;
|
let left_section = find_section(left_obj, selected_symbol)?;
|
||||||
let right_section = find_section(right_obj, section_name)?;
|
let right_section = find_section(right_obj, selected_symbol)?;
|
||||||
|
|
||||||
let total_bytes = left_section.data_diff.iter().fold(0usize, |accum, item| accum + item.len);
|
let total_bytes = left_section.data_diff.iter().fold(0usize, |accum, item| accum + item.len);
|
||||||
if total_bytes == 0 {
|
if total_bytes == 0 {
|
||||||
|
@ -219,7 +219,7 @@ pub fn data_diff_ui(ui: &mut egui::Ui, view_state: &mut ViewState) -> bool {
|
||||||
ui.style_mut().override_text_style =
|
ui.style_mut().override_text_style =
|
||||||
Some(egui::TextStyle::Monospace);
|
Some(egui::TextStyle::Monospace);
|
||||||
ui.style_mut().wrap = Some(false);
|
ui.style_mut().wrap = Some(false);
|
||||||
ui.colored_label(Color32::WHITE, selected_symbol);
|
ui.colored_label(Color32::WHITE, &selected_symbol.symbol_name);
|
||||||
ui.label("Diff target:");
|
ui.label("Diff target:");
|
||||||
ui.separator();
|
ui.separator();
|
||||||
});
|
});
|
||||||
|
|
|
@ -7,7 +7,7 @@ use ppc750cl::Argument;
|
||||||
use time::format_description;
|
use time::format_description;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
app::{View, ViewConfig, ViewState},
|
app::{SymbolReference, View, ViewConfig, ViewState},
|
||||||
jobs::Job,
|
jobs::Job,
|
||||||
obj::{
|
obj::{
|
||||||
ObjInfo, ObjIns, ObjInsArg, ObjInsArgDiff, ObjInsDiff, ObjInsDiffKind, ObjReloc,
|
ObjInfo, ObjIns, ObjInsArg, ObjInsArgDiff, ObjInsDiff, ObjInsDiffKind, ObjReloc,
|
||||||
|
@ -240,9 +240,9 @@ fn ins_context_menu(ui: &mut egui::Ui, ins: &ObjIns) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
fn find_symbol<'a>(obj: &'a ObjInfo, section_name: &str, name: &str) -> Option<&'a ObjSymbol> {
|
fn find_symbol<'a>(obj: &'a ObjInfo, selected_symbol: &SymbolReference) -> Option<&'a ObjSymbol> {
|
||||||
let section = obj.sections.iter().find(|s| s.name == section_name)?;
|
let section = obj.sections.get(selected_symbol.section_index)?;
|
||||||
section.symbols.iter().find(|s| s.name == name)
|
section.symbols.iter().find(|s| s.name == selected_symbol.symbol_name)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn asm_row_ui(ui: &mut egui::Ui, ins_diff: &ObjInsDiff, symbol: &ObjSymbol, config: &ViewConfig) {
|
fn asm_row_ui(ui: &mut egui::Ui, ins_diff: &ObjInsDiff, symbol: &ObjSymbol, config: &ViewConfig) {
|
||||||
|
@ -296,11 +296,11 @@ fn asm_table_ui(
|
||||||
table: TableBuilder<'_>,
|
table: TableBuilder<'_>,
|
||||||
left_obj: &ObjInfo,
|
left_obj: &ObjInfo,
|
||||||
right_obj: &ObjInfo,
|
right_obj: &ObjInfo,
|
||||||
fn_name: &str,
|
selected_symbol: &SymbolReference,
|
||||||
config: &ViewConfig,
|
config: &ViewConfig,
|
||||||
) -> Option<()> {
|
) -> Option<()> {
|
||||||
let left_symbol = find_symbol(left_obj, ".text", fn_name);
|
let left_symbol = find_symbol(left_obj, selected_symbol);
|
||||||
let right_symbol = find_symbol(right_obj, ".text", fn_name);
|
let right_symbol = find_symbol(right_obj, selected_symbol);
|
||||||
let instructions_len = left_symbol.or(right_symbol).map(|s| s.instructions.len())?;
|
let instructions_len = left_symbol.or(right_symbol).map(|s| s.instructions.len())?;
|
||||||
table.body(|body| {
|
table.body(|body| {
|
||||||
body.rows(config.code_font.size, instructions_len, |row_index, mut row| {
|
body.rows(config.code_font.size, instructions_len, |row_index, mut row| {
|
||||||
|
@ -372,7 +372,7 @@ pub fn function_diff_ui(ui: &mut egui::Ui, view_state: &mut ViewState) -> bool {
|
||||||
});
|
});
|
||||||
strip.strip(|builder| {
|
strip.strip(|builder| {
|
||||||
builder.sizes(Size::remainder(), 2).horizontal(|mut strip| {
|
builder.sizes(Size::remainder(), 2).horizontal(|mut strip| {
|
||||||
let demangled = demangle(selected_symbol, &Default::default());
|
let demangled = demangle(&selected_symbol.symbol_name, &Default::default());
|
||||||
strip.cell(|ui| {
|
strip.cell(|ui| {
|
||||||
ui.scope(|ui| {
|
ui.scope(|ui| {
|
||||||
ui.style_mut().override_text_style =
|
ui.style_mut().override_text_style =
|
||||||
|
@ -380,7 +380,7 @@ pub fn function_diff_ui(ui: &mut egui::Ui, view_state: &mut ViewState) -> bool {
|
||||||
ui.style_mut().wrap = Some(false);
|
ui.style_mut().wrap = Some(false);
|
||||||
ui.colored_label(
|
ui.colored_label(
|
||||||
Color32::WHITE,
|
Color32::WHITE,
|
||||||
demangled.as_ref().unwrap_or(selected_symbol),
|
demangled.as_ref().unwrap_or(&selected_symbol.symbol_name),
|
||||||
);
|
);
|
||||||
ui.label("Diff target:");
|
ui.label("Diff target:");
|
||||||
ui.separator();
|
ui.separator();
|
||||||
|
@ -394,7 +394,7 @@ pub fn function_diff_ui(ui: &mut egui::Ui, view_state: &mut ViewState) -> bool {
|
||||||
if let Some(match_percent) = result
|
if let Some(match_percent) = result
|
||||||
.second_obj
|
.second_obj
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.and_then(|obj| find_symbol(obj, ".text", selected_symbol))
|
.and_then(|obj| find_symbol(obj, selected_symbol))
|
||||||
.and_then(|symbol| symbol.match_percent)
|
.and_then(|symbol| symbol.match_percent)
|
||||||
{
|
{
|
||||||
ui.colored_label(
|
ui.colored_label(
|
||||||
|
|
|
@ -4,7 +4,7 @@ use egui::{
|
||||||
use egui_extras::{Size, StripBuilder};
|
use egui_extras::{Size, StripBuilder};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
app::{View, ViewConfig, ViewState},
|
app::{SymbolReference, View, ViewConfig, ViewState},
|
||||||
jobs::objdiff::BuildStatus,
|
jobs::objdiff::BuildStatus,
|
||||||
obj::{ObjInfo, ObjSection, ObjSectionKind, ObjSymbol, ObjSymbolFlags},
|
obj::{ObjInfo, ObjSection, ObjSectionKind, ObjSymbol, ObjSymbolFlags},
|
||||||
views::write_text,
|
views::write_text,
|
||||||
|
@ -56,9 +56,9 @@ fn symbol_hover_ui(ui: &mut Ui, symbol: &ObjSymbol) {
|
||||||
fn symbol_ui(
|
fn symbol_ui(
|
||||||
ui: &mut Ui,
|
ui: &mut Ui,
|
||||||
symbol: &ObjSymbol,
|
symbol: &ObjSymbol,
|
||||||
section: Option<&ObjSection>,
|
section: Option<(usize, &ObjSection)>,
|
||||||
highlighted_symbol: &mut Option<String>,
|
highlighted_symbol: &mut Option<String>,
|
||||||
selected_symbol: &mut Option<String>,
|
selected_symbol: &mut Option<SymbolReference>,
|
||||||
current_view: &mut View,
|
current_view: &mut View,
|
||||||
config: &ViewConfig,
|
config: &ViewConfig,
|
||||||
) {
|
) {
|
||||||
|
@ -97,12 +97,14 @@ fn symbol_ui(
|
||||||
.context_menu(|ui| symbol_context_menu_ui(ui, symbol))
|
.context_menu(|ui| symbol_context_menu_ui(ui, symbol))
|
||||||
.on_hover_ui_at_pointer(|ui| symbol_hover_ui(ui, symbol));
|
.on_hover_ui_at_pointer(|ui| symbol_hover_ui(ui, symbol));
|
||||||
if response.clicked() {
|
if response.clicked() {
|
||||||
if let Some(section) = section {
|
if let Some((section_index, section)) = section {
|
||||||
if section.kind == ObjSectionKind::Code {
|
if section.kind == ObjSectionKind::Code {
|
||||||
*selected_symbol = Some(symbol.name.clone());
|
*selected_symbol =
|
||||||
|
Some(SymbolReference { symbol_name: symbol.name.clone(), section_index });
|
||||||
*current_view = View::FunctionDiff;
|
*current_view = View::FunctionDiff;
|
||||||
} else if section.kind == ObjSectionKind::Data {
|
} else if section.kind == ObjSectionKind::Data {
|
||||||
*selected_symbol = Some(section.name.clone());
|
*selected_symbol =
|
||||||
|
Some(SymbolReference { symbol_name: section.name.clone(), section_index });
|
||||||
*current_view = View::DataDiff;
|
*current_view = View::DataDiff;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -126,7 +128,7 @@ fn symbol_list_ui(
|
||||||
ui: &mut Ui,
|
ui: &mut Ui,
|
||||||
obj: &ObjInfo,
|
obj: &ObjInfo,
|
||||||
highlighted_symbol: &mut Option<String>,
|
highlighted_symbol: &mut Option<String>,
|
||||||
selected_symbol: &mut Option<String>,
|
selected_symbol: &mut Option<SymbolReference>,
|
||||||
current_view: &mut View,
|
current_view: &mut View,
|
||||||
reverse_function_order: bool,
|
reverse_function_order: bool,
|
||||||
search: &mut String,
|
search: &mut String,
|
||||||
|
@ -156,7 +158,7 @@ fn symbol_list_ui(
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
for section in &obj.sections {
|
for (section_index, section) in obj.sections.iter().enumerate() {
|
||||||
CollapsingHeader::new(format!("{} ({:x})", section.name, section.size))
|
CollapsingHeader::new(format!("{} ({:x})", section.name, section.size))
|
||||||
.default_open(true)
|
.default_open(true)
|
||||||
.show(ui, |ui| {
|
.show(ui, |ui| {
|
||||||
|
@ -168,7 +170,7 @@ fn symbol_list_ui(
|
||||||
symbol_ui(
|
symbol_ui(
|
||||||
ui,
|
ui,
|
||||||
symbol,
|
symbol,
|
||||||
Some(section),
|
Some((section_index, section)),
|
||||||
highlighted_symbol,
|
highlighted_symbol,
|
||||||
selected_symbol,
|
selected_symbol,
|
||||||
current_view,
|
current_view,
|
||||||
|
@ -183,7 +185,7 @@ fn symbol_list_ui(
|
||||||
symbol_ui(
|
symbol_ui(
|
||||||
ui,
|
ui,
|
||||||
symbol,
|
symbol,
|
||||||
Some(section),
|
Some((section_index, section)),
|
||||||
highlighted_symbol,
|
highlighted_symbol,
|
||||||
selected_symbol,
|
selected_symbol,
|
||||||
current_view,
|
current_view,
|
||||||
|
|
Loading…
Reference in New Issue