Skip to content

Commit

Permalink
more rustc
Browse files Browse the repository at this point in the history
  • Loading branch information
wugeer committed Sep 17, 2024
2 parents 89ef179 + 4fcfa0d commit 689a31a
Show file tree
Hide file tree
Showing 4 changed files with 195 additions and 118 deletions.
16 changes: 8 additions & 8 deletions benches/bench.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ fn simple_query(c: &mut Criterion) {
format(
black_box(input),
black_box(&QueryParams::None),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand All @@ -21,7 +21,7 @@ fn complex_query(c: &mut Criterion) {
format(
black_box(input),
black_box(&QueryParams::None),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand All @@ -39,7 +39,7 @@ fn query_with_named_params(c: &mut Criterion) {
format(
black_box(input),
black_box(&QueryParams::Named(params.clone())),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand All @@ -53,7 +53,7 @@ fn query_with_explicit_indexed_params(c: &mut Criterion) {
format(
black_box(input),
black_box(&QueryParams::Indexed(params.clone())),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand All @@ -67,7 +67,7 @@ fn query_with_implicit_indexed_params(c: &mut Criterion) {
format(
black_box(input),
black_box(&QueryParams::Indexed(params.clone())),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand Down Expand Up @@ -135,7 +135,7 @@ VALUES
format(
black_box(&input),
black_box(&QueryParams::None),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand All @@ -149,7 +149,7 @@ fn issue_633_2(c: &mut Criterion) {
format(
black_box(input),
black_box(&QueryParams::Indexed(params.clone())),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand All @@ -175,7 +175,7 @@ fn issue_633_3(c: &mut Criterion) {
format(
black_box(&input),
black_box(&QueryParams::None),
black_box(FormatOptions::default()),
black_box(&FormatOptions::default()),
)
})
});
Expand Down
82 changes: 67 additions & 15 deletions src/formatter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,11 @@ pub(crate) fn check_fmt_off(s: &str) -> Option<bool> {
.map(|matched| matched.as_str().eq_ignore_ascii_case("off"))
}

pub(crate) fn format(tokens: &[Token<'_>], params: &QueryParams, options: FormatOptions) -> String {
pub(crate) fn format(
tokens: &[Token<'_>],
params: &QueryParams,
options: &FormatOptions,
) -> String {
let mut formatter = Formatter::new(tokens, params, options);
let mut formatted_query = String::new();
let mut is_fmt_enabled = true;
Expand Down Expand Up @@ -85,13 +89,13 @@ struct Formatter<'a> {
previous_reserved_word: Option<&'a Token<'a>>,
tokens: &'a [Token<'a>],
params: Params<'a>,
options: FormatOptions,
indentation: Indentation,
options: &'a FormatOptions<'a>,
indentation: Indentation<'a>,
inline_block: InlineBlock,
}

impl<'a> Formatter<'a> {
fn new(tokens: &'a [Token<'a>], params: &'a QueryParams, options: FormatOptions) -> Self {
fn new(tokens: &'a [Token<'a>], params: &'a QueryParams, options: &'a FormatOptions) -> Self {
Formatter {
index: 0,
previous_reserved_word: None,
Expand Down Expand Up @@ -182,11 +186,28 @@ impl<'a> Formatter<'a> {
{
self.trim_spaces_end(query);
}
let value = match self.options.uppercase {
Some(true) => token.value.to_uppercase(),
Some(false) => token.value.to_lowercase(),
_ => token.value.to_string(),

let value = match (
self.options.uppercase,
self.options.ignore_case_convert.as_ref(),
) {
(Some(uppercase), Some(values)) if !values.contains(&token.value) => {
if uppercase {
Cow::Owned(token.value.to_uppercase())
} else {
Cow::Owned(token.value.to_lowercase())
}
}
(Some(uppercase), None) => {
if uppercase {
Cow::Owned(token.value.to_uppercase())
} else {
Cow::Owned(token.value.to_lowercase())
}
}
_ => Cow::Borrowed(token.value),
};

query.push_str(&value);

self.inline_block.begin_if_possible(self.tokens, self.index);
Expand All @@ -200,11 +221,27 @@ impl<'a> Formatter<'a> {
// Closing parentheses decrease the block indent level
fn format_closing_parentheses(&mut self, token: &Token<'_>, query: &mut String) {
let mut token = token.clone();
let value = match self.options.uppercase {
Some(true) => token.value.to_uppercase(),
Some(false) => token.value.to_lowercase(),
_ => token.value.to_string(),
let value = match (
self.options.uppercase,
self.options.ignore_case_convert.as_ref(),
) {
(Some(uppercase), Some(values)) if !values.contains(&token.value) => {
if uppercase {
Cow::Owned(token.value.to_uppercase())
} else {
Cow::Owned(token.value.to_lowercase())
}
}
(Some(uppercase), None) => {
if uppercase {
Cow::Owned(token.value.to_uppercase())
} else {
Cow::Owned(token.value.to_lowercase())
}
}
_ => Cow::Borrowed(token.value),
};

token.value = &value;

if self.inline_block.is_active() {
Expand Down Expand Up @@ -300,9 +337,24 @@ impl<'a> Formatter<'a> {
}

fn format_reserved_word<'t>(&self, token: &'t str) -> Cow<'t, str> {
match self.options.uppercase {
Some(true) => Cow::Owned(token.to_uppercase()),
Some(false) => Cow::Owned(token.to_lowercase()),
match (
self.options.uppercase,
self.options.ignore_case_convert.as_ref(),
) {
(Some(uppercase), Some(values)) if !values.contains(&token) => {
if uppercase {
Cow::Owned(token.to_uppercase())
} else {
Cow::Owned(token.to_lowercase())
}
}
(Some(uppercase), None) => {
if uppercase {
Cow::Owned(token.to_uppercase())
} else {
Cow::Owned(token.to_lowercase())
}
}
_ => Cow::Borrowed(token),
}
}
Expand Down
8 changes: 4 additions & 4 deletions src/indentation.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
use crate::{FormatOptions, Indent};

pub(crate) struct Indentation {
options: FormatOptions,
pub(crate) struct Indentation<'a> {
options: &'a FormatOptions<'a>,
indent_types: Vec<IndentType>,
}

Expand All @@ -11,8 +11,8 @@ enum IndentType {
BlockLevel,
}

impl Indentation {
pub fn new(options: FormatOptions) -> Self {
impl<'a> Indentation<'a> {
pub fn new(options: &'a FormatOptions) -> Self {
Indentation {
options,
indent_types: Vec::new(),
Expand Down
Loading

0 comments on commit 689a31a

Please sign in to comment.