From a131c21293f8ff088a5cc08d51c831759b49c1a3 Mon Sep 17 00:00:00 2001 From: Tom Keffer Date: Sat, 2 Dec 2023 16:29:13 -0800 Subject: [PATCH] Delete old util and example directories when upgrading --- src/weecfg/station_config.py | 38 +++++++++++++++++++++++------------- 1 file changed, 24 insertions(+), 14 deletions(-) diff --git a/src/weecfg/station_config.py b/src/weecfg/station_config.py index 1b889029..b4f67c7e 100644 --- a/src/weecfg/station_config.py +++ b/src/weecfg/station_config.py @@ -532,14 +532,16 @@ def copy_examples(config_dict, examples_root=None, dry_run=False, force=False): # examples_root is relative to WEEWX_PATH. Join them to get the absolute path. examples_dir = os.path.join(config_dict['WEEWX_ROOT'], examples_root) - if os.path.isdir(examples_dir) and not force: - print(f"Directory {examples_dir} already exists.") - return None - print(f"Removing directory {examples_dir}") - if not dry_run: - shutil.rmtree(examples_dir, ignore_errors=True) + if os.path.isdir(examples_dir): + if not force: + print(f"Directory {examples_dir} already exists.") + return None + else: + print(f"Removing example directory {examples_dir}") + if not dry_run: + shutil.rmtree(examples_dir, ignore_errors=True) with weeutil.weeutil.get_resource_path('weewx_data', 'examples') as examples_resources: - print(f"Copying new examples into {examples_dir}") + print(f"Copying examples into {examples_dir}") if not dry_run: shutil.copytree(examples_resources, examples_dir) return examples_dir @@ -565,7 +567,7 @@ def copy_user(config_dict, user_root=None, dry_run=False): ignore=shutil.ignore_patterns('*.pyc', '__pycache__', )) -def copy_util(config_path, config_dict, dry_run=False): +def copy_util(config_path, config_dict, dry_run=False, force=False): import weewxd weewxd_path = weewxd.__file__ username = getpass.getuser() @@ -621,18 +623,26 @@ def copy_util(config_path, config_dict, dry_run=False): 'rsyslog.d', 'scripts', 'solaris', 'tmpfiles.d') + util_dir = os.path.join(weewx_root, 'util') + if os.path.isdir(util_dir): + if not force: + print(f"Utility directory {util_dir} already exists. Nothing done.") + return None + else: + print(f"Removing utility directory {util_dir}") + if not dry_run: + shutil.rmtree(util_dir, ignore_errors=True) + with weeutil.weeutil.get_resource_path('weewx_data', 'util') as util_resources: - dstdir = os.path.join(weewx_root, 'util') - print(f"Creating utility files in {dstdir}") + print(f"Copying utility files into {util_dir}") if not dry_run: # Copy the tree rooted in 'util_resources' to 'dstdir', while ignoring files given # by _ignore_function. While copying, use the function _patch_file() to massage # the files. - shutil.copytree(util_resources, dstdir, + shutil.copytree(util_resources, util_dir, ignore=_ignore_function, copy_function=_patch_file) - - return dstdir + return util_dir def station_upgrade(config_path, dist_config_path=None, examples_root=None, @@ -683,7 +693,7 @@ def station_upgrade(config_path, dist_config_path=None, examples_root=None, print(f"Finished upgrading examples at {examples_dir}") if 'util' in what: - util_dir = copy_util(config_path, config_dict, dry_run=dry_run) + util_dir = copy_util(config_path, config_dict, dry_run=dry_run, force=True) if util_dir: print(f"Finished upgrading utilities directory at {util_dir}") else: