From c78d31fc3467c6d8752a12b16c568cd49ba17434 Mon Sep 17 00:00:00 2001 From: Chris Mackey Date: Wed, 24 Jul 2024 13:07:16 -0700 Subject: [PATCH] fix(face): Include the room display name in exception message --- honeybee/face.py | 32 +++++++++++++++++++++----------- 1 file changed, 21 insertions(+), 11 deletions(-) diff --git a/honeybee/face.py b/honeybee/face.py index 01254fd9..6c3431a6 100644 --- a/honeybee/face.py +++ b/honeybee/face.py @@ -573,9 +573,13 @@ def set_adjacency(self, other_face, tolerance=0.01): adj_info = {'adjacent_apertures': [], 'adjacent_doors': []} # set the apertures to be adjacent to one another - assert len(self._apertures) == len(other_face._apertures), \ - 'Number of apertures does not match between {} and {}.'.format( + if len(self._apertures) != len(other_face._apertures): + msg = 'Number of apertures does not match between {} and {}.'.format( self.display_name, other_face.display_name) + if self.has_parent and other_face.has_parent: + msg = '{} Relevant rooms: {}, {}'.format( + msg, self.parent.display_name, other_face.parent.display_name) + raise AssertionError(msg) if len(self._apertures) > 0: found_adjacencies = 0 for aper_1 in self._apertures: @@ -585,10 +589,13 @@ def set_adjacency(self, other_face, tolerance=0.01): adj_info['adjacent_apertures'].append((aper_1, aper_2)) found_adjacencies += 1 break - assert len(self._apertures) == found_adjacencies, \ - 'Not all apertures of {} were found to be adjacent to apertures in {}.' \ - '\nTry increasing the tolerance.'.format( - self.display_name, other_face.display_name) + if len(self._apertures) != found_adjacencies: + msg = 'Not all apertures of {} were found to be adjacent to ' \ + 'apertures in {}.'.format(self.display_name, other_face.display_name) + if self.has_parent and other_face.has_parent: + msg = '{} Relevant rooms: {}, {}'.format( + msg, self.parent.display_name, other_face.parent.display_name) + raise AssertionError(msg) # set the doors to be adjacent to one another assert len(self._doors) == len(other_face._doors), \ @@ -603,10 +610,13 @@ def set_adjacency(self, other_face, tolerance=0.01): adj_info['adjacent_doors'].append((door_1, door_2)) found_adjacencies += 1 break - assert len(self._doors) == found_adjacencies, \ - 'Not all doors of {} were found to be adjacent to doors in {}.' \ - '\nTry increasing the tolerance.'.format( - self.display_name, other_face.display_name) + if len(self._doors) != found_adjacencies: + msg = 'Not all doors of {} were found to be adjacent to ' \ + 'doors in {}.'.format(self.display_name, other_face.display_name) + if self.has_parent and other_face.has_parent: + msg = '{} Relevant rooms: {}, {}'.format( + msg, self.parent.display_name, other_face.parent.display_name) + raise AssertionError(msg) return adj_info @@ -1135,7 +1145,7 @@ def apertures_by_ratio(self, ratio, tolerance=0.01, rect_split=True): concave and an attempt to subdivide the face into a rectangle is made. It does not affect the ability to produce apertures for convex Faces. Default: 0.01, suitable for objects in meters. - rect_split: Boolean to not whether rectangular portions of base Face + rect_split: Boolean to note whether rectangular portions of base Face should be extracted before scaling them to create apertures. For gabled geometries, the resulting apertures will consist of one rectangle and one triangle, which can often look more realistic