diff options
author | Julian T <julian@jtle.dk> | 2021-04-25 20:12:25 +0200 |
---|---|---|
committer | Julian T <julian@jtle.dk> | 2021-04-25 20:12:25 +0200 |
commit | 7e93444f28a6790ab66fbdd8cc7eed9ca8970d48 (patch) | |
tree | fec5eb7eb328948d5c30d2e1d56e4c570d5dcc4c /apply/apply.py | |
parent | 0c24ead1cb0126a1847c2ed971649e9ee25e920e (diff) |
Add kind of working delete command
Diffstat (limited to 'apply/apply.py')
-rwxr-xr-x | apply/apply.py | 57 |
1 files changed, 0 insertions, 57 deletions
diff --git a/apply/apply.py b/apply/apply.py deleted file mode 100755 index 974d800..0000000 --- a/apply/apply.py +++ /dev/null @@ -1,57 +0,0 @@ -#!/usr/bin/env python3 - -import os -from pathlib import Path -import argparse - -from .resolv import Resolver -from .writer import Writer -from .state import StateFile - - -class DirReader: - def __init__(self, config, resolv): - self.resolv = resolv - self.config = config - - def read_package(self, name): - package_root = name - - # Walk down and link dir og file - for root, dirs, files in os.walk(package_root): - rootrel = os.path.relpath(root, start=package_root) - - # Check if we can just link this folder - if rootrel not in self.config["do_not_link"]: - ok = self.resolv.do_folder_link(name, Path(rootrel)) - - if ok: - # Do not go further down - dirs.clear() - continue - - # Link files - for f in files: - self.resolv.do_link(name, Path(rootrel, f)) - - -def cmd_args(parser: argparse.ArgumentParser): - parser.add_argument("packages", nargs="*", help="Packages to apply") - - -def cmd_func(args, config): - writer = Writer() - state = StateFile(args.apply_dir) - resolv = Resolver(args.apply_dir, writer, state, - args.override_existing) - - reader = DirReader(config, resolv) - for pack in args.packages: - reader.read_package(pack) - - writer.apply(dry_run=args.dry_run) - if not args.dry_run: - state.dump_state() - - -cmd_help = "Apply modules from current directory" |