Skip to content

Commit

Permalink
fix: Ignore keywords for uppercase=True
Browse files Browse the repository at this point in the history
  • Loading branch information
wugeer committed Sep 11, 2024
1 parent 6928bb3 commit 85eb6d6
Show file tree
Hide file tree
Showing 4 changed files with 160 additions and 107 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
42 changes: 35 additions & 7 deletions src/formatter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,11 @@ use crate::params::Params;
use crate::tokenizer::{Token, TokenKind};
use crate::{FormatOptions, QueryParams};

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();
for (index, token) in tokens.iter().enumerate() {
Expand Down Expand Up @@ -56,13 +60,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 @@ -162,7 +166,15 @@ impl<'a> Formatter<'a> {
{
self.trim_spaces_end(query);
}
if self.options.uppercase {
if self.options.uppercase
&& (self.options.ignore_case_convert.is_none()
|| !self
.options
.ignore_case_convert
.as_ref()
.unwrap()
.contains(&token.value))
{
query.push_str(&token.value.to_uppercase());
} else {
query.push_str(token.value);
Expand All @@ -179,7 +191,15 @@ 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 = if self.options.uppercase {
let value = if self.options.uppercase
&& (self.options.ignore_case_convert.is_none()
|| !self
.options
.ignore_case_convert
.as_ref()
.unwrap()
.contains(&token.value))
{
token.value.to_uppercase()
} else {
token.value.to_string()
Expand Down Expand Up @@ -279,7 +299,15 @@ impl<'a> Formatter<'a> {
}

fn format_reserved_word<'t>(&self, token: &'t str) -> Cow<'t, str> {
if self.options.uppercase {
if self.options.uppercase
&& (self.options.ignore_case_convert.is_none()
|| !self
.options
.ignore_case_convert
.as_ref()
.unwrap()
.contains(&token))
{
Cow::Owned(token.to_uppercase())
} else {
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 85eb6d6

Please sign in to comment.