Group
Extension

JSON-Pointer-Marpa/lib/JSON/Pointer/Marpa/Semantics.pm

use strict;
use warnings;

package JSON::Pointer::Marpa::Semantics;

use subs qw( _index_exists _member_exists );

use constant { ## no critic (ProhibitConstantPragma)
  EMPTY => '',
  SLASH => '/',
  TILDE => '~'
};

# This is a rule evaluation closure of a quantified rule
# https://metacpan.org/pod/distribution/Marpa-R2/pod/Semantics.pod#Quantified-rule-nodes
sub new {
  my ( $class, $crv ) = @_;    # crv == currently referenced value

  bless { crv => $crv }, $class
}

sub concat {
  shift;
  join '', @_
}

sub array_index_dereferencing {
  my ( $self, $index ) = @_;

  my $crv = $self->get_crv;
  my $crt = ref $crv;         # crt == currently referenced type
  if ( $crt eq 'ARRAY' ) {
    $self->set_crv( _index_exists( $crv, $index ) )
  } elsif ( $crt eq 'HASH' ) {
    $self->set_crv( _member_exists( $crv, $index ) )
  } else {
    Marpa::R2::Context::bail(
"Currently referenced type '$crt' isn't a JSON structured type (array or object)!"
    )
  }

  undef
}

sub next_array_index_dereferencing {
  my ( $self, $next_index ) = @_;

  my $crv = $self->get_crv;
  ref $crv eq 'ARRAY'
    ? Marpa::R2::Context::bail(
    "Handling of '$next_index' array index isn't implemented!" )
    : $self->set_crv( $crv->{ $next_index } );

  undef
}

sub object_name_dereferencing {
  my ( $self, $member ) = @_;
  $member = '' if @_ == 1;

  my $crv = $self->get_crv;
  my $crt = ref $crv;         # crt == currently referenced type
  Marpa::R2::Context::bail(
    "Currently referenced type '$crt' isn't a JSON object!" )
    unless $crt eq 'HASH';
  $self->set_crv( _member_exists( $crv, $member ) );

  undef
}

sub set_crv {
  my ( $self, $crv ) = @_;

  $self->{ crv } = $crv;

  undef
}

sub get_crv {
  my ( $self ) = @_;

  $self->{ crv }
}

sub _index_exists ( $$ ) {
  my ( $crv, $index ) = @_;

  $index < @$crv
    ? $crv->[ $index ]
    : Marpa::R2::Context::bail(
"JSON array has been accessed with an index $index that is greater than or equal to the size of the array!"
    )
}

sub _member_exists ( $$ ) {
  my ( $crv, $member ) = @_;

  exists $crv->{ $member }
    ? $crv->{ $member }
    : Marpa::R2::Context::bail(
    "JSON object has been accessed with a member '$member' that does not exist!" )
}

1


Powered by Groonga
Maintained by Kenichi Ishigaki <ishigaki@cpan.org>. If you find anything, submit it on GitHub.