allow value scalarref, refactor
[scpubgit/DKit.git] / lib / DX / Op / Prop.pm
CommitLineData
896fd92e 1package DX::Op::Prop;
2
3use Moo;
4
5with 'DX::Role::Op';
6
7has of => (is => 'ro', required => 1);
8has name => (is => 'ro', required => 1);
9has value => (is => 'ro', required => 1);
10
11sub run {
12 my ($self, $state) = @_;
13 ($state, my %args) = $self->_expand_args(
14 $state, map +($_ => $self->$_), qw(of name value)
15 );
16 die "property name must be bound" unless $args{name}->is_bound;
17 my $name = $args{name}->bound_value;
18 if ($args{of}->is_bound) {
19 if ($args{value}->is_bound) {
20 if ($args{of}->bound_value->$name eq $args{value}->bound_value) {
21 return $state->then($self->next);
22 }
23 return $state->backtrack;
24 }
25 my $value = $args{of}->bound_value;
26 if ($value->can("has_${name}") and not $value->${\"has_${name}"}) {
27 return $state->backtrack;
28 }
29 return $state->bind_value($args{value}->id, $value->$name);
30 }
31 die "Can't yet handle unbound 'of' argument";
32}
33
341;