Update dependencies

This commit is contained in:
Jon Staab
2024-08-21 12:02:34 -07:00
parent 18d7cf279c
commit fcbaa67ade
4 changed files with 29 additions and 40 deletions
+23 -40
View File
@@ -2,59 +2,42 @@
import os
import json
from collections import defaultdict
def parse_package_json(file_path):
with open(file_path, 'r') as f:
return json.load(f)
def get_deps(package):
with open(os.path.join('packages', package, 'package.json'), 'r') as f:
package_data = json.load(f)
def get_dependencies(package_data):
dependencies = set()
for dep_type in ['dependencies', 'devDependencies', 'peerDependencies']:
if dep_type in package_data:
dependencies.update(package_data[dep_type].keys())
return dependencies
def topological_sort(graph):
visited = set()
stack = []
def dfs(node):
visited.add(node)
for neighbor in graph[node]:
if neighbor not in visited:
dfs(neighbor)
stack.append(node)
for node in graph:
if node not in visited:
dfs(node)
return stack[::-1]
return [
dep.replace('@welshman/', '')
for dep in dependencies
if dep.startswith('@welshman/')
]
def main():
packages_dir = 'packages'
package_graph = defaultdict(set)
all_packages = set()
sorted_packages = []
remaining_packages = {}
for package in os.listdir('packages'):
deps = get_deps(package)
# Walk through the packages directory
for package_name in os.listdir(packages_dir):
package_path = os.path.join(packages_dir, package_name)
if os.path.isdir(package_path):
package_json_path = os.path.join(package_path, 'package.json')
if os.path.exists(package_json_path):
all_packages.add(package_name)
package_data = parse_package_json(package_json_path)
dependencies = get_dependencies(package_data)
if not deps:
sorted_packages.append(package)
else:
remaining_packages[package] = deps
# Only consider dependencies that are in the packages directory
internal_dependencies = dependencies.intersection(all_packages)
package_graph[package_name].update(internal_dependencies)
while remaining_packages:
for package, deps in remaining_packages.items():
if all([dep in sorted_packages for dep in deps]):
sorted_packages.append(package)
# Perform topological sort
sorted_packages = topological_sort(package_graph)
for package in sorted_packages:
if package in remaining_packages:
del remaining_packages[package]
# Output the result
for package in sorted_packages:
print(package)