Skip to content

Commit

Permalink
xtask: Check for licenses that are duplicated instead of being symlin…
Browse files Browse the repository at this point in the history
…ked (#11777)

This PR updates `cargo xtask licenses` to also check for license files
that are not symlinks.

Release Notes:

- N/A
  • Loading branch information
maxdeviant authored May 13, 2024
1 parent b01878a commit 172cb81
Showing 1 changed file with 10 additions and 7 deletions.
17 changes: 10 additions & 7 deletions tooling/xtask/src/tasks/licenses.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,18 @@ use crate::workspace::load_workspace;
pub struct LicensesArgs {}

pub fn run_licenses(_args: LicensesArgs) -> Result<()> {
const LICENSE_FILES: &[&'static str] = &["LICENSE-APACHE", "LICENSE-GPL", "LICENSE-AGPL"];

let workspace = load_workspace()?;

for member in workspace.members {
let crate_dir = PathBuf::from(&member);

if has_any_license_file(
&crate_dir,
&["LICENSE-APACHE", "LICENSE-GPL", "LICENSE-AGPL"],
) {
if let Some(license_file) = first_license_file(&crate_dir, &LICENSE_FILES) {
if !license_file.is_symlink() {
println!("{} is not a symlink", license_file.display());
}

continue;
}

Expand All @@ -27,13 +30,13 @@ pub fn run_licenses(_args: LicensesArgs) -> Result<()> {
Ok(())
}

fn has_any_license_file(path: &Path, license_files: &[&str]) -> bool {
fn first_license_file(path: &Path, license_files: &[&str]) -> Option<PathBuf> {
for license_file in license_files {
let path_to_license = path.join(license_file);
if path_to_license.exists() {
return true;
return Some(path_to_license);
}
}

false
None
}

0 comments on commit 172cb81

Please sign in to comment.