Revision 49b00f2c
Von Bernd Bleßmann vor mehr als 9 Jahren hinzugefügt
SL/DB/CustomVariable.pm | ||
---|---|---|
4 | 4 |
package SL::DB::CustomVariable; |
5 | 5 |
|
6 | 6 |
use strict; |
7 |
|
|
8 |
use List::MoreUtils qw(any); |
|
9 |
|
|
7 | 10 |
use SL::DB::MetaSetup::CustomVariable; |
8 | 11 |
|
9 | 12 |
__PACKAGE__->meta->initialize; |
... | ... | |
36 | 39 |
my $unparsed = delete $self->{__unparsed_value}; |
37 | 40 |
|
38 | 41 |
if ($type =~ m{^(?:customer|vendor|part|number)}) { |
39 |
return $self->number_value(defined($unparsed) ? $unparsed * 1 : undef); |
|
42 |
return $self->number_value(!defined($unparsed) ? undef |
|
43 |
: (any { ref($unparsed) eq $_ } qw(SL::DB::Customer SL::DB::Vendor SL::DB::Part)) ? $unparsed->id * 1 |
|
44 |
: $unparsed * 1); |
|
40 | 45 |
} |
41 | 46 |
|
42 | 47 |
if ($type =~ m{^(?:bool)}) { |
Auch abrufbar als: Unified diff
CVar-Helper: Beim Parsen darauf achten, ob unparsed_value ein Objekt enthält.
Um Objekte mit der value-Methode einer CVar vom Typ Customer, Vendor oder Part
zuweisen zu können, muss beim Parsen die Id des Objekts ermittelt werden.
Dieses wird z.B. im Helper (SL::DB::Helper::CustomVariables.pm) verwendet, um
bei neuen cvars eines sub-modules den Wert der Basis-CVar zu setzen, denn die
value-Methode der CVar (hier der Basis-CVar) liefert ein Objekt zurück.
Ohne diesen Patch gab es einen Fehler in der Art:
"No such SL::DB::Part where id = 111286144 at SL/DB/Helper/CustomVariables.pm
line 198"