Skip to content

Commit

Permalink
fix(replace package): When a second package of the same type is added…
Browse files Browse the repository at this point in the history
… to a model, the model now checks to see if the package type supports multiple packages. If it does not it automatically removes the first package before adding the second (#767). (#768)
  • Loading branch information
spaulins-usgs authored and langevin-usgs committed Dec 18, 2019
1 parent 51d8064 commit cf3586f
Showing 1 changed file with 23 additions and 12 deletions.
35 changes: 23 additions & 12 deletions flopy/mf6/mfmodel.py
Original file line number Diff line number Diff line change
Expand Up @@ -899,16 +899,29 @@ def register_package(self, package, add_to_package_list=True,
path = package.parent_file.path + (package.package_type,)
else:
path = (self.name, package.package_type)

if add_to_package_list and path in self._package_paths and not \
set_package_name and package.package_name in \
self.package_name_dict:
# package of this type with this name already exists, replace it
if self.simulation_data.verbosity_level.value >= \
VerbosityLevel.normal.value:
print('WARNING: Package with name {} already exists. '
'Replacing existing package.'.format(package.package_name))
self.remove_package(self.package_name_dict[package.package_name])
package_struct = \
self.structure.get_package_struct(package.package_type)
if add_to_package_list and path in self._package_paths:
if not package_struct.multi_package_support:
# package of this type already exists, replace it
self.remove_package(package.package_type)
if self.simulation_data.verbosity_level.value >= \
VerbosityLevel.normal.value:
print('WARNING: Package with type {} already exists. '
'Replacing existing package'
'.'.format(package.package_type))
elif not set_package_name and package.package_name in \
self.package_name_dict:
# package of this type with this name already
# exists, replace it
self.remove_package(
self.package_name_dict[package.package_name])
if self.simulation_data.verbosity_level.value >= \
VerbosityLevel.normal.value:
print(
'WARNING: Package with name {} already exists. '
'Replacing existing package'
'.'.format(package.package_name))

# make sure path is unique
if path in self._package_paths:
Expand All @@ -922,8 +935,6 @@ def register_package(self, package, add_to_package_list=True,
if package.package_type.lower() == 'nam':
return path, self.structure.name_file_struct_obj

package_struct = \
self.structure.get_package_struct(package.package_type)
if set_package_name:
# produce a default package name
if package_struct is not None and \
Expand Down

0 comments on commit cf3586f

Please sign in to comment.