- foreach my $path ( sort { $b cmp $a } glob '/tmp/changes/*' ) {
- if ( $path =~ m{/((\d+\.\d+)\.data\.(.+))$} ) {
- my ( $uid, $t, $action ) = ( $1, $2, $3 );
- $actions->{$action}++;
- next if $action_regex && $action !~ m/^($action_regex)$/;
- push @$changes, { uid => $uid, t => $t, action => $action }
- if $#$changes < $max;
+ my $stats;
+ my $glob = $self->_changes_path . '/*';
+ my $status = 'unknown';
+ foreach my $t ( sort { $a cmp $b } glob $glob ) {
+ my $e = retrieve($t);
+ $e->{old} = [ $e->{old} ] unless ref $e->{old} eq 'ARRAY';
+ if ( $items && exists $e->{unique} ) {
+ my ($pk,$id) = %{ $e->{unique} };
+ if ( ! $pk ) {
+ $e->{_status} = 'skip';
+ $stats->{skip}++;
+ push @$changes, $e;
+ next;
+ }
+ if ( ! defined $unique2id->{$pk} ) {
+ warn "unique2id $pk on ", $#$items + 1 ," items\n";
+ foreach my $i ( 0 .. $#$items ) {
+ $unique2id->{$pk}->{ $items->[$i]->{$pk}->[0] } = $i;
+ }
+ }
+ $status = 'missing';
+ if ( my $i = $unique2id->{$pk}->{$id} ) {
+ if ( _hash_eq( $e->{old}, $items->[$i]->{$e->{column}} ) ) {
+ $status = 'found';
+ if ( $commit ) {
+ my $column = $e->{column} or die "no column";
+ $items->[$i]->{$column} = $e->{new};
+ warn "# commit $i $column ",dump( $e->{new} );
+ $invalidate_columns->{$column}++;
+ }
+ } else {
+ $status = 'source-changed';
+ }
+ }
+ } elsif ( my $code = $e->{code} ) {
+ if ( $commit ) {
+ my $commit_changed;
+ my $t = time();
+ foreach my $i ( 0 .. $#$items ) {
+ MojoFacets::Data::__commit_path_code( $on_path, $i, $code, \$commit_changed );
+ }
+ $t = time() - $t;
+ $self->stash( 'commit_changed', $commit_changed );
+ warn "commit_changed in $t s ",dump( $e->{commit_changed}, $commit_changed );
+ $e->{commit_changed_this} = $commit_changed;
+ MojoFacets::Data::__invalidate_path_column( $on_path, $_ ) foreach keys %$commit_changed;
+ MojoFacets::Data::__path_rebuild_stats( $on_path );
+ }
+ $status = 'code';
+ if ( ( $apply || $commit ) && $e->{commit_changed} ) {
+ $status = 'found';
+ foreach my $c ( keys %{ $e->{commit_changed} } ) {
+ $status = 'missing' unless defined $MojoFacets::Data::loaded->{$path}->{stats}->{$c};
+ }
+ }