Skip to content

Commit

Permalink
Allow SPDX license headers to exceed the line length (#10481)
Browse files Browse the repository at this point in the history
Closes #10465.
  • Loading branch information
charliermarsh authored Mar 19, 2024
1 parent 42d4216 commit f7740a8
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -82,3 +82,8 @@ class Bar:
"""
This is a long sentence that ends with a shortened URL and, therefore, could easily be broken across multiple lines ([source](https://ruff.rs))
"""


# OK
# SPDX-FileCopyrightText: Copyright 2012-2015 Charlie Marsh <[email protected]>
# SPDX-License-Identifier: a very long license identifier that exceeds the line length limit
11 changes: 10 additions & 1 deletion crates/ruff_linter/src/rules/pycodestyle/overlong.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ impl Overlong {
};

let mut chunks = line.split_whitespace();
let (Some(_), Some(second_chunk)) = (chunks.next(), chunks.next()) else {
let (Some(first_chunk), Some(second_chunk)) = (chunks.next(), chunks.next()) else {
// Single word / no printable chars - no way to make the line shorter.
return None;
};
Expand All @@ -67,6 +67,15 @@ impl Overlong {
}
}

// Do not enforce the line length limit for SPDX license headers, which are machine-readable
// and explicitly _not_ recommended to wrap over multiple lines.
if matches!(
(first_chunk, second_chunk),
("#", "SPDX-License-Identifier:" | "SPDX-FileCopyrightText:")
) {
return None;
}

// Obtain the start offset of the part of the line that exceeds the limit.
let mut start_offset = line.start();
let mut start_width = LineWidthBuilder::new(tab_size);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,9 @@ use crate::settings::LinterSettings;
/// line-length threshold. That is, a line will not be flagged as
/// overlong if a pragma comment _causes_ it to exceed the line length.
/// (This behavior aligns with that of the Ruff formatter.)
/// 4. Ignores SPDX license identifiers and copyright notices
/// (e.g., `# SPDX-License-Identifier: MIT`), which are machine-readable
/// and should _not_ wrap over multiple lines.
///
/// If [`lint.pycodestyle.ignore-overlong-task-comments`] is `true`, this rule will
/// also ignore comments that start with any of the specified [`lint.task-tags`]
Expand Down

0 comments on commit f7740a8

Please sign in to comment.