Eliminate dead code in nu-explore (#12735)

# Description
Nightly clippy found some unused fields leading me down a rabbit hole of
dead code hidden behind `pub`

Generally removing any already dead code or premature configurability
that is not exposed to the user.

# User-Facing Changes

None in effect.

Removed some options from the `$env.config.explore.hex-dump` record that
were only read into a struct but never used and also not validated.
This commit is contained in:
Stefan Holderbach 2024-05-03 02:36:58 +02:00 committed by GitHub
parent 847646e44e
commit 944ebac1c2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 36 additions and 171 deletions

View File

@ -51,10 +51,3 @@ pub trait ViewCommand {
value: Option<Value>, value: Option<Value>,
) -> Result<Self::View>; ) -> Result<Self::View>;
} }
#[derive(Debug, Default, Clone)]
pub struct Shortcode {
pub code: &'static str,
pub context: &'static str,
pub description: &'static str,
}

View File

@ -4,7 +4,7 @@ use ratatui::{
buffer::Buffer, buffer::Buffer,
layout::Rect, layout::Rect,
text::Span, text::Span,
widgets::{Paragraph, StatefulWidget, Widget}, widgets::{Paragraph, Widget},
}; };
use crate::{ use crate::{
@ -12,10 +12,6 @@ use crate::{
views::util::{nu_style_to_tui, text_style_to_tui_style}, views::util::{nu_style_to_tui, text_style_to_tui_style},
}; };
use super::Layout;
type OptStyle = Option<NuStyle>;
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct BinaryWidget<'a> { pub struct BinaryWidget<'a> {
data: &'a [u8], data: &'a [u8],
@ -73,7 +69,7 @@ impl BinarySettings {
#[derive(Debug, Default, Clone)] #[derive(Debug, Default, Clone)]
pub struct BinaryStyle { pub struct BinaryStyle {
colors: BinaryStyleColors, color_index: Option<NuStyle>,
indent_index: Indent, indent_index: Indent,
indent_data: Indent, indent_data: Indent,
indent_ascii: Indent, indent_ascii: Indent,
@ -83,7 +79,7 @@ pub struct BinaryStyle {
impl BinaryStyle { impl BinaryStyle {
pub fn new( pub fn new(
colors: BinaryStyleColors, color_index: Option<NuStyle>,
indent_index: Indent, indent_index: Indent,
indent_data: Indent, indent_data: Indent,
indent_ascii: Indent, indent_ascii: Indent,
@ -91,7 +87,7 @@ impl BinaryStyle {
show_split: bool, show_split: bool,
) -> Self { ) -> Self {
Self { Self {
colors, color_index,
indent_index, indent_index,
indent_data, indent_data,
indent_ascii, indent_ascii,
@ -113,61 +109,8 @@ impl Indent {
} }
} }
#[derive(Debug, Default, Clone)] impl Widget for BinaryWidget<'_> {
pub struct BinaryStyleColors { fn render(self, area: Rect, buf: &mut Buffer) {
pub split_left: OptStyle,
pub split_right: OptStyle,
pub index: OptStyle,
pub data: SymbolColor,
pub ascii: SymbolColor,
}
#[derive(Debug, Default, Clone)]
pub struct SymbolColor {
pub default: OptStyle,
pub zero: OptStyle,
pub unknown: OptStyle,
}
impl SymbolColor {
pub fn new(default: OptStyle, zero: OptStyle, unknown: OptStyle) -> Self {
Self {
default,
zero,
unknown,
}
}
}
impl BinaryStyleColors {
pub fn new(
index: OptStyle,
data: SymbolColor,
ascii: SymbolColor,
split_left: OptStyle,
split_right: OptStyle,
) -> Self {
Self {
split_left,
split_right,
index,
data,
ascii,
}
}
}
#[derive(Debug, Default)]
pub struct BinaryWidgetState {
pub layout_index: Layout,
pub layout_data: Layout,
pub layout_ascii: Layout,
}
impl StatefulWidget for BinaryWidget<'_> {
type State = BinaryWidgetState;
fn render(self, area: Rect, buf: &mut Buffer, state: &mut Self::State) {
let min_width = get_widget_width(&self); let min_width = get_widget_width(&self);
if (area.width as usize) < min_width { if (area.width as usize) < min_width {
@ -178,12 +121,12 @@ impl StatefulWidget for BinaryWidget<'_> {
return; return;
} }
render_hexdump(area, buf, state, self); render_hexdump(area, buf, self);
} }
} }
// todo: indent color // todo: indent color
fn render_hexdump(area: Rect, buf: &mut Buffer, _state: &mut BinaryWidgetState, w: BinaryWidget) { fn render_hexdump(area: Rect, buf: &mut Buffer, w: BinaryWidget) {
const MIN_INDEX_SIZE: usize = 8; const MIN_INDEX_SIZE: usize = 8;
let show_index = !w.opts.disable_index; let show_index = !w.opts.disable_index;
@ -211,7 +154,7 @@ fn render_hexdump(area: Rect, buf: &mut Buffer, _state: &mut BinaryWidgetState,
if show_index { if show_index {
x += render_space(buf, x, y, 1, w.style.indent_index.left); x += render_space(buf, x, y, 1, w.style.indent_index.left);
x += render_hex_usize(buf, x, y, address, index_width, false, get_index_style(&w)); x += render_hex_usize(buf, x, y, address, index_width, get_index_style(&w));
x += render_space(buf, x, y, 1, w.style.indent_index.right); x += render_space(buf, x, y, 1, w.style.indent_index.right);
} }
@ -251,7 +194,7 @@ fn render_hexdump(area: Rect, buf: &mut Buffer, _state: &mut BinaryWidgetState,
if show_index { if show_index {
x += render_space(buf, x, y, 1, w.style.indent_index.left); x += render_space(buf, x, y, 1, w.style.indent_index.left);
x += render_hex_usize(buf, x, y, address, index_width, false, get_index_style(&w)); x += render_hex_usize(buf, x, y, address, index_width, get_index_style(&w));
x += render_space(buf, x, y, 1, w.style.indent_index.right); x += render_space(buf, x, y, 1, w.style.indent_index.right);
} }
@ -313,7 +256,7 @@ fn render_segment(buf: &mut Buffer, x: u16, y: u16, line: &[u8], w: &BinaryWidge
} }
let (_, style) = get_segment_char(w, n); let (_, style) = get_segment_char(w, n);
size += render_hex_u8(buf, x + size, y, n, false, style); size += render_hex_u8(buf, x + size, y, n, style);
count -= 1; count -= 1;
} }
@ -346,7 +289,7 @@ fn render_ascii_line(buf: &mut Buffer, x: u16, y: u16, line: &[u8], w: &BinaryWi
size size
} }
fn render_ascii_char(buf: &mut Buffer, x: u16, y: u16, n: char, style: OptStyle) -> u16 { fn render_ascii_char(buf: &mut Buffer, x: u16, y: u16, n: char, style: Option<NuStyle>) -> u16 {
let text = n.to_string(); let text = n.to_string();
let mut p = Paragraph::new(text); let mut p = Paragraph::new(text);
@ -362,8 +305,8 @@ fn render_ascii_char(buf: &mut Buffer, x: u16, y: u16, n: char, style: OptStyle)
1 1
} }
fn render_hex_u8(buf: &mut Buffer, x: u16, y: u16, n: u8, big: bool, style: OptStyle) -> u16 { fn render_hex_u8(buf: &mut Buffer, x: u16, y: u16, n: u8, style: Option<NuStyle>) -> u16 {
render_hex_usize(buf, x, y, n as usize, 2, big, style) render_hex_usize(buf, x, y, n as usize, 2, style)
} }
fn render_hex_usize( fn render_hex_usize(
@ -372,10 +315,9 @@ fn render_hex_usize(
y: u16, y: u16,
n: usize, n: usize,
width: u16, width: u16,
big: bool, style: Option<NuStyle>,
style: OptStyle,
) -> u16 { ) -> u16 {
let text = usize_to_hex(n, width as usize, big); let text = usize_to_hex(n, width as usize);
let mut p = Paragraph::new(text); let mut p = Paragraph::new(text);
if let Some(style) = style { if let Some(style) = style {
let style = nu_style_to_tui(style); let style = nu_style_to_tui(style);
@ -389,7 +331,7 @@ fn render_hex_usize(
width width
} }
fn get_ascii_char(_w: &BinaryWidget, n: u8) -> (char, OptStyle) { fn get_ascii_char(_w: &BinaryWidget, n: u8) -> (char, Option<NuStyle>) {
let (style, c) = categorize_byte(&n); let (style, c) = categorize_byte(&n);
let c = c.unwrap_or(n as char); let c = c.unwrap_or(n as char);
let style = if style.is_plain() { None } else { Some(style) }; let style = if style.is_plain() { None } else { Some(style) };
@ -397,7 +339,7 @@ fn get_ascii_char(_w: &BinaryWidget, n: u8) -> (char, OptStyle) {
(c, style) (c, style)
} }
fn get_segment_char(_w: &BinaryWidget, n: u8) -> (char, OptStyle) { fn get_segment_char(_w: &BinaryWidget, n: u8) -> (char, Option<NuStyle>) {
let (style, c) = categorize_byte(&n); let (style, c) = categorize_byte(&n);
let c = c.unwrap_or(n as char); let c = c.unwrap_or(n as char);
let style = if style.is_plain() { None } else { Some(style) }; let style = if style.is_plain() { None } else { Some(style) };
@ -405,8 +347,8 @@ fn get_segment_char(_w: &BinaryWidget, n: u8) -> (char, OptStyle) {
(c, style) (c, style)
} }
fn get_index_style(w: &BinaryWidget) -> OptStyle { fn get_index_style(w: &BinaryWidget) -> Option<NuStyle> {
w.style.colors.index w.style.color_index
} }
fn render_space(buf: &mut Buffer, x: u16, y: u16, height: u16, padding: u16) -> u16 { fn render_space(buf: &mut Buffer, x: u16, y: u16, height: u16, padding: u16) -> u16 {
@ -443,7 +385,7 @@ fn get_max_index_size(w: &BinaryWidget) -> usize {
let line_size = w.opts.count_segments * (w.opts.segment_size * 2); let line_size = w.opts.count_segments * (w.opts.segment_size * 2);
let count_lines = w.data.len() / line_size; let count_lines = w.data.len() / line_size;
let max_index = w.opts.index_offset + count_lines * line_size; let max_index = w.opts.index_offset + count_lines * line_size;
usize_to_hex(max_index, 0, false).len() usize_to_hex(max_index, 0).len()
} }
fn get_widget_width(w: &BinaryWidget) -> usize { fn get_widget_width(w: &BinaryWidget) -> usize {
@ -453,7 +395,7 @@ fn get_widget_width(w: &BinaryWidget) -> usize {
let count_lines = w.data.len() / line_size; let count_lines = w.data.len() / line_size;
let max_index = w.opts.index_offset + count_lines * line_size; let max_index = w.opts.index_offset + count_lines * line_size;
let index_size = usize_to_hex(max_index, 0, false).len(); let index_size = usize_to_hex(max_index, 0).len();
let index_size = index_size.max(MIN_INDEX_SIZE); let index_size = index_size.max(MIN_INDEX_SIZE);
let data_split_size = w.opts.count_segments.saturating_sub(1) * w.style.indent_segment; let data_split_size = w.opts.count_segments.saturating_sub(1) * w.style.indent_segment;
@ -479,17 +421,11 @@ fn get_widget_width(w: &BinaryWidget) -> usize {
min_width min_width
} }
fn usize_to_hex(n: usize, width: usize, big: bool) -> String { fn usize_to_hex(n: usize, width: usize) -> String {
if width == 0 { if width == 0 {
match big { format!("{:x}", n)
true => format!("{:X}", n),
false => format!("{:x}", n),
}
} else { } else {
match big { format!("{:0>width$x}", n, width = width)
true => format!("{:0>width$X}", n, width = width),
false => format!("{:0>width$x}", n, width = width),
}
} }
} }
@ -499,9 +435,8 @@ mod tests {
#[test] #[test]
fn test_to_hex() { fn test_to_hex() {
assert_eq!(usize_to_hex(1, 2, false), "01"); assert_eq!(usize_to_hex(1, 2), "01");
assert_eq!(usize_to_hex(16, 2, false), "10"); assert_eq!(usize_to_hex(16, 2), "10");
assert_eq!(usize_to_hex(29, 2, false), "1d"); assert_eq!(usize_to_hex(29, 2), "1d");
assert_eq!(usize_to_hex(29, 2, true), "1D");
} }
} }

View File

@ -19,29 +19,17 @@ use crate::{
util::create_map, util::create_map,
}; };
use self::binary_widget::{ use self::binary_widget::{BinarySettings, BinaryStyle, BinaryWidget, Indent};
BinarySettings, BinaryStyle, BinaryStyleColors, BinaryWidget, BinaryWidgetState, Indent,
SymbolColor,
};
use super::{cursor::XYCursor, Layout, View, ViewConfig}; use super::{cursor::XYCursor, Layout, View, ViewConfig};
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct BinaryView { pub struct BinaryView {
data: Vec<u8>, data: Vec<u8>,
mode: Option<CursorMode>,
cursor: XYCursor, cursor: XYCursor,
settings: Settings, settings: Settings,
} }
#[allow(dead_code)] // todo:
#[derive(Debug, Clone, Copy)]
enum CursorMode {
Index,
Data,
Ascii,
}
#[derive(Debug, Default, Clone)] #[derive(Debug, Default, Clone)]
struct Settings { struct Settings {
opts: BinarySettings, opts: BinarySettings,
@ -52,7 +40,6 @@ impl BinaryView {
pub fn new(data: Vec<u8>) -> Self { pub fn new(data: Vec<u8>) -> Self {
Self { Self {
data, data,
mode: None,
cursor: XYCursor::default(), cursor: XYCursor::default(),
settings: Settings::default(), settings: Settings::default(),
} }
@ -61,9 +48,8 @@ impl BinaryView {
impl View for BinaryView { impl View for BinaryView {
fn draw(&mut self, f: &mut Frame, area: Rect, _cfg: ViewConfig<'_>, _layout: &mut Layout) { fn draw(&mut self, f: &mut Frame, area: Rect, _cfg: ViewConfig<'_>, _layout: &mut Layout) {
let mut state = BinaryWidgetState::default();
let widget = create_binary_widget(self); let widget = create_binary_widget(self);
f.render_stateful_widget(widget, area, &mut state); f.render_widget(widget, area);
} }
fn handle_input( fn handle_input(
@ -77,7 +63,7 @@ impl View for BinaryView {
let result = handle_event_view_mode(self, &key); let result = handle_event_view_mode(self, &key);
if matches!(&result, Some(Transition::Ok)) { if matches!(&result, Some(Transition::Ok)) {
let report = create_report(self.mode, self.cursor); let report = create_report(self.cursor);
info.status = Some(report); info.status = Some(report);
} }
@ -206,21 +192,7 @@ fn settings_from_config(config: &ConfigMap) -> Settings {
0, 0,
), ),
style: BinaryStyle::new( style: BinaryStyle::new(
BinaryStyleColors::new( colors.get("color_index").cloned(),
colors.get("color_index").cloned(),
SymbolColor::new(
colors.get("color_segment").cloned(),
colors.get("color_segment_zero").cloned(),
colors.get("color_segment_unknown").cloned(),
),
SymbolColor::new(
colors.get("color_ascii").cloned(),
colors.get("color_ascii_zero").cloned(),
colors.get("color_ascii_unknown").cloned(),
),
colors.get("color_split_left").cloned(),
colors.get("color_split_right").cloned(),
),
Indent::new( Indent::new(
config_get_usize(config, "padding_index_left", 2) as u16, config_get_usize(config, "padding_index_left", 2) as u16,
config_get_usize(config, "padding_index_right", 2) as u16, config_get_usize(config, "padding_index_right", 2) as u16,
@ -254,22 +226,17 @@ fn config_get_usize(config: &ConfigMap, key: &str, default: usize) -> usize {
.unwrap_or(default) .unwrap_or(default)
} }
fn create_report(mode: Option<CursorMode>, cursor: XYCursor) -> Report { fn create_report(cursor: XYCursor) -> Report {
let covered_percent = report_row_position(cursor); let covered_percent = report_row_position(cursor);
let cursor = report_cursor_position(cursor); let cursor = report_cursor_position(cursor);
let mode = report_mode_name(mode); let mode = report_mode_name();
let msg = String::new(); let msg = String::new();
Report::new(msg, Severity::Info, mode, cursor, covered_percent) Report::new(msg, Severity::Info, mode, cursor, covered_percent)
} }
fn report_mode_name(cursor: Option<CursorMode>) -> String { fn report_mode_name() -> String {
match cursor { String::from("VIEW")
Some(CursorMode::Index) => String::from("ADDR"),
Some(CursorMode::Data) => String::from("DUMP"),
Some(CursorMode::Ascii) => String::from("TEXT"),
None => String::from("VIEW"),
}
} }
fn report_row_position(cursor: XYCursor) -> String { fn report_row_position(cursor: XYCursor) -> String {

View File

@ -32,25 +32,10 @@ impl XYCursor {
self.x.index() self.x.index()
} }
#[allow(dead_code)]
pub fn row_offset(&self) -> usize {
self.y.offset()
}
#[allow(dead_code)]
pub fn column_limit(&self) -> usize {
self.x.end()
}
pub fn row_limit(&self) -> usize { pub fn row_limit(&self) -> usize {
self.y.end() self.y.end()
} }
#[allow(dead_code)]
pub fn column_offset(&self) -> usize {
self.x.offset()
}
pub fn row_starts_at(&self) -> usize { pub fn row_starts_at(&self) -> usize {
self.y.starts_at() self.y.starts_at()
} }
@ -67,11 +52,6 @@ impl XYCursor {
self.x.offset() self.x.offset()
} }
#[allow(dead_code)]
pub fn row_window_size(&self) -> usize {
self.y.window()
}
pub fn column_window_size(&self) -> usize { pub fn column_window_size(&self) -> usize {
self.x.window() self.x.window()
} }
@ -80,11 +60,6 @@ impl XYCursor {
self.y.next(1) self.y.next(1)
} }
#[allow(dead_code)]
pub fn next_row_by(&mut self, i: usize) -> bool {
self.y.next(i)
}
pub fn next_row_page(&mut self) -> bool { pub fn next_row_page(&mut self) -> bool {
self.y.next_window() self.y.next_window()
} }
@ -101,11 +76,6 @@ impl XYCursor {
self.y.prev(1) self.y.prev(1)
} }
#[allow(dead_code)]
pub fn prev_row_by(&mut self, i: usize) -> bool {
self.y.prev(i)
}
pub fn prev_row_page(&mut self) -> bool { pub fn prev_row_page(&mut self) -> bool {
self.y.prev_window() self.y.prev_window()
} }