allow value scalarref, refactor
[scpubgit/DKit.git] / lib / DX / Op / ProposeAction.pm
CommitLineData
71217e42 1package DX::Op::ProposeAction;
2
3use DX::ObservationRequired;
4use Moo;
5
6with 'DX::Role::Op';
7
8has vars => (is => 'ro', required => 1);
9has builder => (is => 'ro', required => 1);
10
11has _arg_map => (is => 'lazy', builder => sub {
12 my ($self) = @_;
13 my $name = 'arg0';
14 +{ map +($name++, $_), @{$self->vars} };
15});
16
17sub run {
18 my ($self, $state) = @_;
19 ($state, my %args) = $self->_expand_args($state, %{$self->_arg_map});
20 my @vars = @args{sort keys %args};
21 my $action = $self->builder->(@vars);
22 my ($id, $value) = $action->expected_effect;
23 my $var = $state->by_id->{$id}->with_value($value)->with_action($action);
24 $state->but(by_id => { %{$state->by_id}, $id => $var })
25 ->then($self->next);
26}
27
281;