From b32c1b99f22120de6a4464f3564bfd0ae1c8b9b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABl=20Berthaud-M=C3=BCller?= Date: Wed, 25 Aug 2021 15:49:49 +0200 Subject: [PATCH] make reason read only --- lib/Zonemaster/Backend/Errors.pm | 27 +++++++++------------------ 1 file changed, 9 insertions(+), 18 deletions(-) diff --git a/lib/Zonemaster/Backend/Errors.pm b/lib/Zonemaster/Backend/Errors.pm index 9d310e99d..cc25cf877 100644 --- a/lib/Zonemaster/Backend/Errors.pm +++ b/lib/Zonemaster/Backend/Errors.pm @@ -65,8 +65,7 @@ has '+code' => ( has 'reason' => ( isa => 'Str', - is => 'rw', - initializer => 'reason', + is => 'ro' ); has 'method' => ( @@ -89,24 +88,16 @@ sub _build_method { return $c[3]; } -around 'reason' => sub { - my $orig = shift; - my $self = shift; - - my ( $value, $setter, $attr ) = @_; - - # reader - return $self->$orig if not $value; +around 'BUILDARGS', sub { + my ($orig, $class, %args) = @_; - # trim new lines - $value =~ s/\n/ /g; - $value =~ s/^\s+|\s+$//g; - - # initializer - return $setter->($value) if $setter; + if(exists $args{reason}) { + # trim new lines + $args{reason} =~ s/\n/ /g; + $args{reason} =~ s/^\s+|\s+$//g; + } - # writer - $self->$orig($value); + $class->$orig(%args); }; sub as_string {