summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
185c56c)
2 Probleme.
1. Booleans wurden beim Parsen in den numeric Slot gesteckt
2. Die zwei-wertige Version von value() hat das zweite Argument nicht
aus dem Stack entfernt, und damit beim goto weitergegeben an die
unterliegenden Rose-Accessoren. Das hat dann das parsen wieder
zunichte gemacht.
my $unparsed = delete $self->{__unparsed_value};
my $unparsed = delete $self->{__unparsed_value};
- if ($type =~ m{^(?:customer|vendor|part|bool|number)}) {
+ if ($type =~ m{^(?:customer|vendor|part|number)}) {
return $self->number_value(defined($unparsed) ? $unparsed * 1 : undef);
}
return $self->number_value(defined($unparsed) ? $unparsed * 1 : undef);
}
+ if ($type =~ m{^(?:bool)}) {
+ return $self->bool_value(defined($unparsed) ? !!$unparsed : undef);
+ }
+
if ($type =~ m{^(?:date|timestamp)}) {
return $self->timestamp_value(defined($unparsed) ? DateTime->from_kivitendo($unparsed) : undef);
}
if ($type =~ m{^(?:date|timestamp)}) {
return $self->timestamp_value(defined($unparsed) ? DateTime->from_kivitendo($unparsed) : undef);
}
if (scalar(@_) > 1) {
$self->unparsed_value($_[1]);
$self->parse_value;
if (scalar(@_) > 1) {
$self->unparsed_value($_[1]);
$self->parse_value;
}
goto &bool_value if $type eq 'bool';
}
goto &bool_value if $type eq 'bool';