-
Notifications
You must be signed in to change notification settings - Fork 15
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
script to detect dangling imports, generates explicit multirepo impor…
…ts from the nav Signed-off-by: Jason Madigan <[email protected]>
- Loading branch information
1 parent
df183be
commit be6536c
Showing
3 changed files
with
117 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
# Generate an explicit set of multirepo plugin imports, from the nav | ||
# Run: python3 validate_imports.py | ||
|
||
import yaml | ||
|
||
def generate_explicit_nav_repos(mkdocs_file): | ||
with open(mkdocs_file, 'r') as f: | ||
raw_content = f.read() | ||
|
||
# Preprocess to remove problematic syntax (e.g. !!python/name) | ||
sanitized_content = clean(raw_content) | ||
config = yaml.safe_load(sanitized_content) | ||
|
||
# Extract files from nav | ||
nav_files = set(extract_files_from_nav(config['nav'])) | ||
|
||
# Build new multirepo impiorts | ||
explicit_imports = generate_imports(config['plugins'], nav_files) | ||
|
||
print("Updated nav_repos:") | ||
print(yaml.dump(explicit_imports, default_flow_style=False, sort_keys=False)) | ||
|
||
def clean(content): | ||
return "\n".join([line for line in content.splitlines() if '!!python/name:' not in line]) | ||
|
||
def extract_files_from_nav(nav): | ||
files = [] | ||
for item in nav: | ||
if isinstance(item, dict): | ||
for key, value in item.items(): | ||
if isinstance(value, list): | ||
files.extend(extract_files_from_nav(value)) | ||
else: | ||
files.append(value) | ||
else: | ||
files.append(item) | ||
return files | ||
|
||
def generate_imports(plugins, nav_files): | ||
new_imports = [] | ||
for plugin in plugins: | ||
if isinstance(plugin, dict) and 'multirepo' in plugin: | ||
for repo in plugin['multirepo']['nav_repos']: | ||
repo_name = repo['name'] | ||
repo_import_url = repo['import_url'] | ||
repo_explicit_imports = [] | ||
|
||
for pattern in repo['imports']: | ||
matching_files = match_files_to_pattern(nav_files, pattern, repo_name) | ||
|
||
repo_explicit_imports.extend( | ||
add_leading_slash(remove_repo_name_prefix(matching_files, repo_name)) | ||
) | ||
|
||
# dedupe imports (may be used multiple times in nav) | ||
repo_explicit_imports = sorted(set(repo_explicit_imports)) | ||
|
||
new_imports.append({ | ||
'name': repo_name, | ||
'import_url': repo_import_url, | ||
'imports': repo_explicit_imports, | ||
}) | ||
return new_imports | ||
|
||
|
||
def match_files_to_pattern(nav_files, pattern, repo_name): | ||
base_path = f"{repo_name}/" | ||
if pattern.startswith('/'): | ||
pattern = pattern[1:] # Remove leading slash | ||
if '*' in pattern or '?' in pattern: | ||
prefix = base_path + pattern.split('*')[0] | ||
return {file for file in nav_files if file.startswith(prefix)} | ||
return {file for file in nav_files if file == base_path + pattern} | ||
|
||
def remove_repo_name_prefix(files, repo_name): | ||
# remove the repo name prefix from file paths | ||
prefix = f"{repo_name}/" | ||
return [file[len(prefix):] for file in files if file.startswith(prefix)] | ||
|
||
def add_leading_slash(files): | ||
return [f"/{file}" if not file.startswith("/") else file for file in files] | ||
|
||
# Run | ||
generate_explicit_nav_repos('mkdocs.yml') |