mirror of
https://github.com/nushell/nushell.git
synced 2025-01-23 06:39:17 +01:00
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:
parent
847646e44e
commit
944ebac1c2
@ -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,
|
|
||||||
}
|
|
||||||
|
@ -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");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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()
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user