Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: xtask themelint #3234

Merged
merged 36 commits into from
Sep 19, 2022
Merged
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
324c11a
feat: cargo xtask themelint <theme>
AlexanderBrevig Jul 28, 2022
5a09b77
fix: add docs and print json error status
AlexanderBrevig Jul 28, 2022
a931e61
fix: refactor paths -> path
AlexanderBrevig Jul 29, 2022
d4946fa
Merge remote-tracking branch 'upstream/master' into xtask-themelint
AlexanderBrevig Jul 30, 2022
b90f318
fix: remove unused function
AlexanderBrevig Jul 30, 2022
a11bc22
fix: only report one err per scope (ui.statusline is reported if none…
AlexanderBrevig Jul 31, 2022
b4edea4
fix: save work for later
AlexanderBrevig Aug 4, 2022
80f7b1d
Merge remote-tracking branch 'origin/master' into xtask-themelint
AlexanderBrevig Aug 25, 2022
7ccb816
fix: finally decided on a design
AlexanderBrevig Aug 25, 2022
10cda98
fix: ready for discussion
AlexanderBrevig Aug 25, 2022
943c421
fix: better rules
AlexanderBrevig Aug 27, 2022
16a5f87
fix: lint precision
AlexanderBrevig Aug 29, 2022
336e901
fix: String -> &'static str
AlexanderBrevig Aug 29, 2022
90ca345
fix: allowlist not denylist for file type
AlexanderBrevig Aug 29, 2022
d160366
fix: add missing and indication of what's needed
AlexanderBrevig Aug 29, 2022
6ffba6b
fix: copy pasteable errors
AlexanderBrevig Aug 29, 2022
237f706
fix: use Loader:read_names
AlexanderBrevig Aug 29, 2022
50662cf
Update xtask/src/helpers.rs
AlexanderBrevig Aug 29, 2022
af2011d
fix: remove into and clone for str
AlexanderBrevig Aug 31, 2022
0632c3f
Update book/src/themes.md
AlexanderBrevig Aug 31, 2022
b2f6540
fix: better lint output
AlexanderBrevig Sep 1, 2022
1a8d812
fix: cleaner logic for lint reporting
AlexanderBrevig Sep 1, 2022
1cf35e7
style: use explicit imports
AlexanderBrevig Sep 1, 2022
917aec4
Pascal support (#3542)
ath3 Aug 25, 2022
464d7c5
fix: add difference check for statusline normal,insert,select
AlexanderBrevig Sep 5, 2022
f64c587
fix: fg for whitespace and early exit if and one is ok
AlexanderBrevig Sep 5, 2022
726f85b
chore: cleaning up, no idea how these got here or how this will look
AlexanderBrevig Sep 9, 2022
91bb2f5
chore: revert from older commit?
AlexanderBrevig Sep 9, 2022
4ce09f7
refactor: use static fn to equalize api between difference and existance
AlexanderBrevig Sep 9, 2022
4c157aa
Merge branch 'master' into xtask-themelint
AlexanderBrevig Sep 9, 2022
a264aef
refactor: querycheck and clippy
AlexanderBrevig Sep 9, 2022
434c35d
refactor: clippy fixes
AlexanderBrevig Sep 9, 2022
11840be
fix: query-check behaves as before
AlexanderBrevig Sep 9, 2022
6e2b7b3
fix: error with x of y message, not total count
AlexanderBrevig Sep 11, 2022
886206f
fix: consistent reporting and less mutable state
AlexanderBrevig Sep 14, 2022
0f0282f
fix: selection difference ref #3942 ref #1833
AlexanderBrevig Sep 14, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
72 changes: 44 additions & 28 deletions xtask/src/themelint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -69,33 +69,56 @@ impl Rule {
check_both: true,
}
}
fn validate(&self, theme: &Theme, messages: &mut Vec<String>) {
let mut found_fg = true;
let mut found_bg = true;
let mut fg_name = "";
let mut bg_name = "";
if let Some(fg) = &self.fg {
fg_name = fg;
fn found_impl(theme: &Theme, find: Option<&'static str>) -> bool {
if let Some(fg) = &find {
if theme.get(fg).fg.is_none() && theme.get(fg).add_modifier == Modifier::empty() {
found_fg = false;
return false;
}
}
if let Some(bg) = &self.bg {
bg_name = bg;
if theme.get(bg).bg.is_none() && theme.get(bg).add_modifier == Modifier::empty() {
found_bg = false;
}
return true;
}
fn found_fg(&self, theme: &Theme) -> bool {
return Rule::found_impl(theme, self.fg);
}
fn found_bg(&self, theme: &Theme) -> bool {
return Rule::found_impl(theme, self.bg);
}
AlexanderBrevig marked this conversation as resolved.
Show resolved Hide resolved
fn rule_name(&self) -> &'static str {
if self.fg.is_some() {
self.fg.unwrap()
} else if self.bg.is_some() {
self.bg.unwrap()
} else {
"LINTER_ERROR_NO_RULE"
}
}

fn validate(&self, theme: &Theme, messages: &mut Vec<String>) {
let mut missing = vec![];

let found_fg = self.found_fg(theme);
let found_bg = self.found_bg(theme);
if self.check_both {
if !found_fg {
messages.push(format!("\"{}\"={{\"fg\"=\"missing\"}}", fg_name));
missing.push("`fg`");
}
if !found_bg {
messages.push(format!("\"{}\"={{\"bg\"=\"missing\"}}", bg_name));
missing.push("`bg`");
}
if !found_fg || !found_bg {
messages.push(format!(
"$THEME: missing {} for `{}`",
missing.join(" and "),
self.rule_name()
));
}
} else {
if !found_fg && !found_bg {
messages.push(format!("\"{}\"=\"missing\"", fg_name))
messages.push(format!(
"$THEME: missing {} for `{}`",
"entry",
self.rule_name()
))
}
}
}
Expand All @@ -116,18 +139,11 @@ pub fn lint(file: String) -> Result<(), DynError> {
.for_each(|rule| rule.validate(&theme, &mut messages));

if messages.len() > 0 {
let message: String = messages
.iter()
.map(|m| {
let mut msg = file.clone();
msg.push_str(":");
msg.push_str(m);
msg
})
.collect::<Vec<String>>()
.join(" ")
.into();
println!("{}", message.replace(" ", "\n"));
messages.iter().for_each(|m| {
let theme = file.clone();
let message = m.replace("$THEME", theme.as_str());
println!("{}", message);
});
Err(messages.len().to_string().into())
} else {
Ok(())
Expand Down