Skip to content

Commit

Permalink
refactor(report): Use native types
Browse files Browse the repository at this point in the history
  • Loading branch information
Ed Page committed Nov 12, 2020
1 parent 482d320 commit 7a1fac7
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 34 deletions.
18 changes: 9 additions & 9 deletions crates/typos/src/checks.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ struct ReportContext<'m, 'r> {

impl<'m, 'r> report::Report for ReportContext<'m, 'r> {
fn report(&self, msg: report::Message) -> bool {
let msg = msg.context(self.context.clone());
let msg = msg.context(Some(self.context.clone()));
self.reporter.report(msg)
}
}
Expand Down Expand Up @@ -188,7 +188,7 @@ impl Check for Typos {
Some(corrections) => {
let byte_offset = ident.offset();
let msg = report::Typo {
context: report::Context::None,
context: None,
buffer: std::borrow::Cow::Borrowed(buffer.as_bytes()),
byte_offset,
typo: ident.token(),
Expand All @@ -203,7 +203,7 @@ impl Check for Typos {
Some(corrections) => {
let byte_offset = word.offset();
let msg = report::Typo {
context: report::Context::None,
context: None,
buffer: std::borrow::Cow::Borrowed(buffer.as_bytes()),
byte_offset,
typo: word.token(),
Expand Down Expand Up @@ -236,7 +236,7 @@ impl Check for Typos {
Some(corrections) => {
let byte_offset = ident.offset();
let msg = report::Typo {
context: report::Context::None,
context: None,
buffer: std::borrow::Cow::Borrowed(buffer),
byte_offset,
typo: ident.token(),
Expand All @@ -251,7 +251,7 @@ impl Check for Typos {
Some(corrections) => {
let byte_offset = word.offset();
let msg = report::Typo {
context: report::Context::None,
context: None,
buffer: std::borrow::Cow::Borrowed(buffer),
byte_offset,
typo: word.token(),
Expand Down Expand Up @@ -300,7 +300,7 @@ impl Check for ParseIdentifiers {
let typos_found = false;

let msg = report::Parse {
context: report::Context::None,
context: None,
kind: report::ParseKind::Identifier,
data: parser.parse_str(buffer).map(|i| i.token()).collect(),
};
Expand All @@ -321,7 +321,7 @@ impl Check for ParseIdentifiers {
let typos_found = false;

let msg = report::Parse {
context: report::Context::None,
context: None,
kind: report::ParseKind::Identifier,
data: parser.parse_bytes(buffer).map(|i| i.token()).collect(),
};
Expand Down Expand Up @@ -363,7 +363,7 @@ impl Check for ParseWords {
let typos_found = false;

let msg = report::Parse {
context: report::Context::None,
context: None,
kind: report::ParseKind::Word,
data: parser
.parse_str(buffer)
Expand All @@ -387,7 +387,7 @@ impl Check for ParseWords {
let typos_found = false;

let msg = report::Parse {
context: report::Context::None,
context: None,
kind: report::ParseKind::Word,
data: parser
.parse_bytes(buffer)
Expand Down
47 changes: 28 additions & 19 deletions crates/typos/src/report.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ impl<'m> Message<'m> {
}
}

pub fn context(self, context: Context<'m>) -> Self {
pub fn context(self, context: Option<Context<'m>>) -> Self {
match self {
Message::Typo(typo) => {
let typo = typo.context(context);
Expand All @@ -65,7 +65,7 @@ pub struct BinaryFile<'m> {
#[non_exhaustive]
pub struct Typo<'m> {
#[serde(flatten)]
pub context: Context<'m>,
pub context: Option<Context<'m>>,
#[serde(skip)]
pub buffer: Cow<'m, [u8]>,
pub byte_offset: usize,
Expand All @@ -76,7 +76,7 @@ pub struct Typo<'m> {
impl<'m> Default for Typo<'m> {
fn default() -> Self {
Self {
context: Context::None,
context: None,
buffer: Cow::Borrowed(&[]),
byte_offset: 0,
typo: "",
Expand All @@ -91,21 +91,13 @@ impl<'m> Default for Typo<'m> {
pub enum Context<'m> {
File(FileContext<'m>),
Path(PathContext<'m>),
None,
}

impl<'m> Default for Context<'m> {
fn default() -> Self {
Context::None
}
}

impl<'m> std::fmt::Display for Context<'m> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::result::Result<(), std::fmt::Error> {
match self {
Context::File(c) => write!(f, "{}:{}", c.path.display(), c.line_num),
Context::Path(c) => write!(f, "{}", c.path.display()),
Context::None => Ok(()),
}
}
}
Expand Down Expand Up @@ -172,15 +164,15 @@ impl<'m> Default for File<'m> {
#[non_exhaustive]
pub struct Parse<'m> {
#[serde(flatten)]
pub context: Context<'m>,
pub context: Option<Context<'m>>,
pub kind: ParseKind,
pub data: Vec<&'m str>,
}

impl<'m> Default for Parse<'m> {
fn default() -> Self {
Self {
context: Context::None,
context: None,
kind: ParseKind::Identifier,
data: vec![],
}
Expand Down Expand Up @@ -294,13 +286,15 @@ fn print_brief_correction(msg: &Typo) {
crate::Status::Invalid => {
println!(
"{}:{}: {} is disallowed",
msg.context, msg.byte_offset, msg.typo,
context_display(&msg.context),
msg.byte_offset,
msg.typo,
);
}
crate::Status::Corrections(corrections) => {
println!(
"{}:{}: {} -> {}",
msg.context,
context_display(&msg.context),
msg.byte_offset,
msg.typo,
itertools::join(corrections.iter(), ", ")
Expand All @@ -318,7 +312,9 @@ fn print_long_correction(msg: &Typo) {
writeln!(
handle,
"{}:{}: {} is disallowed",
msg.context, msg.byte_offset, msg.typo,
context_display(&msg.context),
msg.byte_offset,
msg.typo,
)
.unwrap();
}
Expand All @@ -332,9 +328,15 @@ fn print_long_correction(msg: &Typo) {
.unwrap();
}
}
writeln!(handle, " --> {}:{}", msg.context, msg.byte_offset).unwrap();

if let Context::File(context) = &msg.context {
writeln!(
handle,
" --> {}:{}",
context_display(&msg.context),
msg.byte_offset
)
.unwrap();

if let Some(Context::File(context)) = &msg.context {
let line_num = context.line_num.to_string();
let line_indent: String = itertools::repeat_n(" ", line_num.len()).collect();

Expand All @@ -350,6 +352,13 @@ fn print_long_correction(msg: &Typo) {
}
}

fn context_display<'c>(context: &'c Option<Context<'c>>) -> &'c dyn std::fmt::Display {
context
.as_ref()
.map(|c| c as &dyn std::fmt::Display)
.unwrap_or(&"")
}

#[derive(Copy, Clone, Debug)]
pub struct PrintJson;

Expand Down
12 changes: 6 additions & 6 deletions src/replace.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ impl<'r> typos::report::Report for Replace<'r> {
};

match &typo.context {
typos::report::Context::File(file) => {
Some(typos::report::Context::File(file)) => {
let path = file.path.to_owned();
let line_num = file.line_num;
let correction =
Expand All @@ -82,7 +82,7 @@ impl<'r> typos::report::Report for Replace<'r> {
content.push(correction);
false
}
typos::report::Context::Path(path) => {
Some(typos::report::Context::Path(path)) => {
let path = path.path.to_owned();
let correction =
Correction::new(typo.byte_offset, typo.typo, corrections[0].as_ref());
Expand Down Expand Up @@ -209,12 +209,12 @@ mod test {
let replace = Replace::new(&primary);
replace.report(
typos::report::Typo::default()
.context(
.context(Some(
typos::report::FileContext::default()
.path(input_file.path())
.line_num(1)
.into(),
)
))
.buffer(std::borrow::Cow::Borrowed(b"1 foo 2\n3 4 5"))
.byte_offset(2)
.typo("foo")
Expand All @@ -238,11 +238,11 @@ mod test {
let replace = Replace::new(&primary);
replace.report(
typos::report::Typo::default()
.context(
.context(Some(
typos::report::PathContext::default()
.path(input_file.path())
.into(),
)
))
.buffer(std::borrow::Cow::Borrowed(b"foo.txt"))
.byte_offset(0)
.typo("foo")
Expand Down

0 comments on commit 7a1fac7

Please sign in to comment.