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: flag to suppress existing diagnostics #4008

Merged
merged 67 commits into from
Oct 21, 2024
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
67 commits
Select commit Hold shift + click to select a range
62e46bc
WIP
anthonyshew Sep 20, 2024
9c50af1
WIP
anthonyshew Sep 20, 2024
a87006b
WIP
anthonyshew Sep 20, 2024
a39718d
WIP
anthonyshew Sep 20, 2024
cf0b9c0
WIP
anthonyshew Sep 22, 2024
02115cc
WIP
anthonyshew Sep 23, 2024
3b613f0
WIP
anthonyshew Sep 23, 2024
2eb7cdc
WIP
anthonyshew Sep 23, 2024
c378a77
WIP
anthonyshew Sep 26, 2024
dd05b07
WIP
anthonyshew Sep 26, 2024
c28db57
WIP
anthonyshew Sep 26, 2024
0cedb3e
WIP
anthonyshew Sep 26, 2024
a797a87
WIP
anthonyshew Sep 26, 2024
f1707a4
WIP
anthonyshew Sep 29, 2024
046e120
WIP
anthonyshew Sep 29, 2024
8bb572f
WIP
anthonyshew Sep 29, 2024
09889d0
WIP
anthonyshew Sep 29, 2024
25af91c
WIP
anthonyshew Sep 29, 2024
3611db0
WIP
anthonyshew Sep 29, 2024
6c6431b
WIP
anthonyshew Sep 29, 2024
8ddedf4
WIP
anthonyshew Sep 30, 2024
35e2145
WIP
anthonyshew Oct 2, 2024
86560e9
WIP
anthonyshew Oct 2, 2024
1b44843
WIP
anthonyshew Oct 2, 2024
88bfa71
WIP
anthonyshew Oct 2, 2024
f754916
WIP
anthonyshew Oct 2, 2024
0e1a789
WIP
anthonyshew Oct 2, 2024
e6b406d
WIP
anthonyshew Oct 2, 2024
cc81046
WIP
anthonyshew Oct 2, 2024
071d024
WIP
anthonyshew Oct 2, 2024
e43e9af
WIP
anthonyshew Oct 2, 2024
de33eab
Merge branch 'main' of https://github.com/anthonyshew/biome into shew…
anthonyshew Oct 2, 2024
3030687
WIP
anthonyshew Oct 2, 2024
f19cee6
Fix codegen.
anthonyshew Oct 2, 2024
2838190
WIP
anthonyshew Oct 2, 2024
82fd461
Update crates/biome_cli/src/commands/mod.rs
anthonyshew Oct 2, 2024
616b5da
WIP
anthonyshew Oct 2, 2024
1dfc0dc
Tests pass and behavior looks correct here. Write some more tests.
anthonyshew Oct 2, 2024
704cc59
Cleanup.
anthonyshew Oct 2, 2024
143db55
Wrote some tests.
anthonyshew Oct 2, 2024
063cb77
Fix codegen.
anthonyshew Oct 2, 2024
e5424b0
Reset codegen.
anthonyshew Oct 3, 2024
358bb87
codegen pls
anthonyshew Oct 3, 2024
66c9e9f
codegen pls
anthonyshew Oct 3, 2024
df889ec
WIP
anthonyshew Oct 3, 2024
497abd8
WIP
anthonyshew Oct 3, 2024
b870607
WIP
anthonyshew Oct 3, 2024
4ba4097
WIP
anthonyshew Oct 3, 2024
0aa9783
Fix JS API.
anthonyshew Oct 3, 2024
d5d8768
Merge branch 'main' into shew-d3bfe
anthonyshew Oct 3, 2024
23eaae2
Update crates/biome_cli/src/commands/mod.rs
anthonyshew Oct 5, 2024
f205f49
Update crates/biome_service/src/file_handlers/json.rs
anthonyshew Oct 5, 2024
50d5d17
Update crates/biome_service/src/file_handlers/graphql.rs
anthonyshew Oct 5, 2024
c143abd
Update crates/biome_service/src/file_handlers/css.rs
anthonyshew Oct 5, 2024
adeeb02
Fixes from review.
anthonyshew Oct 5, 2024
b497bd6
Merge branch 'shew-d3bfe' of https://github.com/anthonyshew/biome int…
anthonyshew Oct 5, 2024
6cd1584
Format.
anthonyshew Oct 5, 2024
9e8285f
Undo codegen since option is no longer there.
anthonyshew Oct 5, 2024
f6ce7b6
Merge branch 'main' into shew-d3bfe
anthonyshew Oct 5, 2024
5638e9a
Fix codegen?
anthonyshew Oct 5, 2024
e39b50a
Merge branch 'shew-d3bfe' of https://github.com/anthonyshew/biome int…
anthonyshew Oct 5, 2024
497a7e1
WIP
anthonyshew Oct 5, 2024
eaeebd4
WIP
anthonyshew Oct 5, 2024
aa121eb
WIP
anthonyshew Oct 5, 2024
45c26f4
WIP
anthonyshew Oct 5, 2024
b2a4ba3
Update snapshot.
anthonyshew Oct 5, 2024
0ccd3d0
Fix merge conflicts.
anthonyshew Oct 17, 2024
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
3 changes: 3 additions & 0 deletions crates/biome_cli/src/commands/check.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ pub(crate) struct CheckCommandPayload {
pub(crate) apply: bool,
pub(crate) apply_unsafe: bool,
pub(crate) write: bool,
pub(crate) write_suppressions: bool,
pub(crate) fix: bool,
pub(crate) unsafe_: bool,
pub(crate) cli_options: CliOptions,
Expand All @@ -52,6 +53,7 @@ pub(crate) fn check(
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_,
cli_options,
Expand All @@ -73,6 +75,7 @@ pub(crate) fn check(
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_,
},
Expand Down
3 changes: 3 additions & 0 deletions crates/biome_cli/src/commands/format.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ pub(crate) struct FormatCommandPayload {
pub(crate) files_configuration: Option<PartialFilesConfiguration>,
pub(crate) stdin_file_path: Option<String>,
pub(crate) write: bool,
pub(crate) write_suppressions: bool,
pub(crate) fix: bool,
pub(crate) cli_options: CliOptions,
pub(crate) paths: Vec<OsString>,
Expand All @@ -55,6 +56,7 @@ pub(crate) fn format(
stdin_file_path,
files_configuration,
write,
write_suppressions,
fix,
mut json_formatter,
css_formatter,
Expand All @@ -69,6 +71,7 @@ pub(crate) fn format(
apply: false,
apply_unsafe: false,
write,
write_suppressions,
fix,
unsafe_: false,
})?;
Expand Down
4 changes: 4 additions & 0 deletions crates/biome_cli/src/commands/lint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ pub(crate) struct LintCommandPayload {
pub(crate) apply: bool,
pub(crate) apply_unsafe: bool,
pub(crate) write: bool,
pub(crate) write_suppressions: bool,
pub(crate) fix: bool,
pub(crate) unsafe_: bool,
pub(crate) cli_options: CliOptions,
Expand Down Expand Up @@ -70,6 +71,7 @@ pub(crate) fn lint(session: CliSession, payload: LintCommandPayload) -> Result<(
css_linter,
json_linter,
graphql_linter,
write_suppressions,
} = payload;
setup_cli_subscriber(cli_options.log_level, cli_options.log_kind);

Expand All @@ -78,6 +80,7 @@ pub(crate) fn lint(session: CliSession, payload: LintCommandPayload) -> Result<(
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_,
},
Expand Down Expand Up @@ -181,6 +184,7 @@ pub(crate) fn lint(session: CliSession, payload: LintCommandPayload) -> Result<(
only,
skip,
vcs_targeted: VcsTargeted { staged, changed },
write_suppressions,
})
.set_report(&cli_options),
session,
Expand Down
2 changes: 2 additions & 0 deletions crates/biome_cli/src/commands/migrate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ pub(crate) fn migrate(
session: CliSession,
cli_options: CliOptions,
write: bool,
write_suppressions: bool,
fix: bool,
sub_command: Option<MigrateSubCommand>,
) -> Result<(), CliDiagnostic> {
Expand All @@ -29,6 +30,7 @@ pub(crate) fn migrate(
apply: false,
apply_unsafe: false,
write,
write_suppressions,
fix,
unsafe_: false,
})?;
Expand Down
31 changes: 31 additions & 0 deletions crates/biome_cli/src/commands/mod.rs
anthonyshew marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,10 @@ pub enum BiomeCommand {
#[bpaf(long("write"), switch)]
write: bool,

/// Writes inline biome-ignore comments to ignore existing diagnostics
#[bpaf(long("write"), switch)]
write_suppressions: bool,

/// Allow to do unsafe fixes, should be used with `--write` or `--fix`
#[bpaf(long("unsafe"), switch)]
unsafe_: bool,
Expand Down Expand Up @@ -220,6 +224,9 @@ pub enum BiomeCommand {
#[bpaf(external(partial_graphql_linter), optional, hide_usage, hide)]
graphql_linter: Option<PartialGraphqlLinter>,

#[bpaf(long("write-suppressions"))]
write_suppressions: bool,

#[bpaf(external, hide_usage)]
cli_options: CliOptions,

Expand Down Expand Up @@ -298,6 +305,7 @@ pub enum BiomeCommand {
/// Writes formatted files to file system.
#[bpaf(long("write"), switch)]
write: bool,
write_suppressions: bool,

/// Alias of `--write`, writes formatted files to file system.
#[bpaf(long("fix"), switch, hide_usage)]
Expand Down Expand Up @@ -408,6 +416,10 @@ pub enum BiomeCommand {
#[bpaf(long("write"), switch)]
write: bool,

/// Writes inline biome-ignore comments to ignore existing diagnostics
#[bpaf(long("write"), switch)]
write_suppressions: bool,

/// Alias of `--write`, writes the new configuration file to disk
#[bpaf(long("fix"), switch, hide_usage)]
fix: bool,
Expand Down Expand Up @@ -724,6 +736,7 @@ pub(crate) struct FixFileModeOptions {
apply: bool,
apply_unsafe: bool,
write: bool,
write_suppressions: bool,
fix: bool,
unsafe_: bool,
}
Expand All @@ -740,6 +753,7 @@ pub(crate) fn determine_fix_file_mode(
apply_unsafe,
write,
fix,
write_suppressions,
unsafe_,
} = options;

Expand All @@ -764,6 +778,8 @@ pub(crate) fn determine_fix_file_mode(
Ok(Some(FixFileMode::SafeAndUnsafeFixes))
} else if safe_fixes {
Ok(Some(FixFileMode::SafeFixes))
} else if write_suppressions {
Ok(Some(FixFileMode::ApplySuppressions))
} else {
Ok(None)
}
Expand All @@ -775,6 +791,7 @@ fn check_fix_incompatible_arguments(options: FixFileModeOptions) -> Result<(), C
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_,
} = options;
Expand All @@ -800,6 +817,16 @@ fn check_fix_incompatible_arguments(options: FixFileModeOptions) -> Result<(), C
));
} else if write && fix {
return Err(CliDiagnostic::incompatible_arguments("--write", "--fix"));
} else if write_suppressions && write {
return Err(CliDiagnostic::incompatible_arguments(
"--write-suppressions",
"--write",
));
} else if write_suppressions && fix {
return Err(CliDiagnostic::incompatible_arguments(
"--write-suppressions",
"--fix",
));
}
Ok(())
}
Expand All @@ -825,6 +852,7 @@ mod tests {
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_
})
Expand All @@ -847,6 +875,7 @@ mod tests {
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_
},
Expand All @@ -873,6 +902,7 @@ mod tests {
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_
},
Expand All @@ -895,6 +925,7 @@ mod tests {
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_
},
Expand Down
14 changes: 14 additions & 0 deletions crates/biome_cli/src/execute/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,7 @@ pub enum TraversalMode {
skip: Vec<RuleSelector>,
/// A flag to know vcs integrated options such as `--staged` or `--changed` are enabled
vcs_targeted: VcsTargeted,
write_suppressions: bool,
},
/// This mode is enabled when running the command `biome ci`
CI {
Expand Down Expand Up @@ -304,6 +305,19 @@ impl Execution {
}
}

pub(crate) fn as_write_suppressions_mode(&self) -> Option<&bool> {
match &self.traversal_mode {
TraversalMode::Lint {
write_suppressions, ..
} => Some(write_suppressions),
TraversalMode::Check { .. }
| TraversalMode::Format { .. }
| TraversalMode::CI { .. }
| TraversalMode::Migrate { .. }
| TraversalMode::Search { .. } => None,
}
}

pub(crate) fn as_diagnostic_category(&self) -> &'static Category {
match self.traversal_mode {
TraversalMode::Check { .. } => category!("check"),
Expand Down
1 change: 1 addition & 0 deletions crates/biome_cli/src/execute/process_file.rs
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@ impl<'ctx, 'app> Deref for SharedTraversalOptions<'ctx, 'app> {
/// content of the file and emit a diff or write the new content to the disk if
/// write mode is enabled
pub(crate) fn process_file(ctx: &TraversalOptions, biome_path: &BiomePath) -> FileResult {
ctx.execution.as_write_suppressions_mode();
tracing::trace_span!("process_file", path = ?biome_path).in_scope(move || {
let file_features = ctx
.workspace
Expand Down
16 changes: 15 additions & 1 deletion crates/biome_cli/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,7 @@ impl<'app> CliSession<'app> {
apply,
apply_unsafe,
write,
write_suppressions,
fix,
unsafe_,
cli_options,
Expand All @@ -109,6 +110,7 @@ impl<'app> CliSession<'app> {
apply_unsafe,
apply,
write,
write_suppressions,
fix,
unsafe_,
cli_options,
Expand Down Expand Up @@ -145,6 +147,7 @@ impl<'app> CliSession<'app> {
javascript_linter,
json_linter,
graphql_linter,
write_suppressions,
} => commands::lint::lint(
self,
LintCommandPayload {
Expand All @@ -168,6 +171,7 @@ impl<'app> CliSession<'app> {
javascript_linter,
json_linter,
graphql_linter,
write_suppressions,
},
),
BiomeCommand::Ci {
Expand Down Expand Up @@ -199,6 +203,7 @@ impl<'app> CliSession<'app> {
formatter_configuration,
stdin_file_path,
write,
write_suppressions,
fix,
cli_options,
paths,
Expand All @@ -217,6 +222,7 @@ impl<'app> CliSession<'app> {
formatter_configuration,
stdin_file_path,
write,
write_suppressions,
fix,
cli_options,
paths,
Expand All @@ -241,9 +247,17 @@ impl<'app> CliSession<'app> {
BiomeCommand::Migrate {
cli_options,
write,
write_suppressions,
fix,
sub_command,
} => commands::migrate::migrate(self, cli_options, write, fix, sub_command),
} => commands::migrate::migrate(
self,
cli_options,
write,
write_suppressions,
fix,
sub_command,
),
BiomeCommand::Search {
cli_options,
files_configuration,
Expand Down
3 changes: 3 additions & 0 deletions crates/biome_service/src/file_handlers/css.rs
Original file line number Diff line number Diff line change
Expand Up @@ -563,6 +563,9 @@ pub(crate) fn fix_all(params: FixAllParams) -> Result<FixFileResult, WorkspaceEr
return ControlFlow::Break(action);
}
}
FixFileMode::ApplySuppressions => {
println!("No-op'ing in CSS.")
}
}
}

Expand Down
3 changes: 3 additions & 0 deletions crates/biome_service/src/file_handlers/graphql.rs
Original file line number Diff line number Diff line change
Expand Up @@ -529,6 +529,9 @@ pub(crate) fn fix_all(params: FixAllParams) -> Result<FixFileResult, WorkspaceEr
return ControlFlow::Break(action);
}
}
FixFileMode::ApplySuppressions => {
println!("No-op'ing in JSON.")
}
anthonyshew marked this conversation as resolved.
Show resolved Hide resolved
}
}

Expand Down
8 changes: 6 additions & 2 deletions crates/biome_service/src/file_handlers/javascript.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ use crate::{
};
use biome_analyze::options::PreferredQuote;
use biome_analyze::{
AnalysisFilter, AnalyzerConfiguration, AnalyzerOptions, ControlFlow, Never, QueryMatch,
AnalysisFilter, AnalyzerConfiguration, AnalyzerOptions, ControlFlow, Never, QueryMatch, Rule,
RuleCategoriesBuilder, RuleCategory, RuleError, RuleFilter,
};
use biome_configuration::javascript::JsxRuntime;
Expand Down Expand Up @@ -659,7 +659,6 @@ pub(crate) fn fix_all(params: FixAllParams) -> Result<FixFileResult, WorkspaceEr
}

for action in signal.actions() {
// suppression actions should not be part of the fixes (safe or suggested)
if action.is_suppression() {
continue;
}
Expand All @@ -683,6 +682,11 @@ pub(crate) fn fix_all(params: FixAllParams) -> Result<FixFileResult, WorkspaceEr
return ControlFlow::Break(action);
}
}
FixFileMode::ApplySuppressions => {
// TODO: Now where do I get ctx, text_range, and suppression_action
// from...?
Rule::suppress();
}
anthonyshew marked this conversation as resolved.
Show resolved Hide resolved
}
}

Expand Down
3 changes: 3 additions & 0 deletions crates/biome_service/src/file_handlers/json.rs
Original file line number Diff line number Diff line change
Expand Up @@ -584,6 +584,9 @@ fn fix_all(params: FixAllParams) -> Result<FixFileResult, WorkspaceError> {
return ControlFlow::Break(action);
}
}
FixFileMode::ApplySuppressions => {
println!("No-op'ing in JSON.")
}
}
}

Expand Down
1 change: 1 addition & 0 deletions crates/biome_service/src/workspace.rs
Original file line number Diff line number Diff line change
Expand Up @@ -627,6 +627,7 @@ pub enum FixFileMode {
SafeFixes,
/// Applies [safe](biome_diagnostics::Applicability::Always) and [unsafe](biome_diagnostics::Applicability::MaybeIncorrect) fixes
SafeAndUnsafeFixes,
ApplySuppressions,
anthonyshew marked this conversation as resolved.
Show resolved Hide resolved
}

#[derive(Debug, serde::Serialize, serde::Deserialize)]
Expand Down
Loading