GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
Venus::Role::Coercible(3) User Contributed Perl Documentation Venus::Role::Coercible(3)

Venus::Role::Coercible - Coercible Role

Coercible Role for Perl 5

  package Person;
  use Venus::Class;
  with 'Venus::Role::Coercible';
  attr 'name';
  attr 'father';
  attr 'mother';
  attr 'siblings';
  sub coercers {
    {
      father => 'Person',
      mother => 'Person',
      name => 'Venus/String',
      siblings => 'Person',
    }
  }
  sub coerce_name {
    my ($self, $code, @args) = @_;
    return $self->$code(@args);
  }
  sub coerce_siblings {
    my ($self, $code, $class, $value) = @_;
    return [map $self->$code($class, $_), @$value];
  }
  package main;
  my $person = Person->new(
    name => 'me',
    father => {name => 'father'},
    mother => {name => 'mother'},
    siblings => [{name => 'brother'}, {name => 'sister'}],
  );
  # $person
  # bless({...}, 'Person')
  # $person->name
  # bless({...}, 'Venus::String')
  # $person->father
  # bless({...}, 'Person')
  # $person->mother
  # bless({...}, 'Person')
  # $person->siblings
  # [bless({...}, 'Person'), bless({...}, 'Person'), ...]

This package modifies the consuming package and provides methods for hooking into object construction and coercing arguments into objects and values.

This package provides the following methods:

  coerce_args(hashref $data, hashref $spec) (hashref)

The coerce_args method replaces values in the data provided with objects corresponding to the specification provided. The specification should contains key/value pairs where the keys map to class attributes (or input parameters) and the values are Venus::Space compatible package names.

Since 0.07

coerce_args example 1
  package main;
  my $person = Person->new;
  my $data = $person->coerce_args(
    {
      father => { name => 'father' }
    },
    {
      father => 'Person',
    },
  );
  # {
  #   father   => bless({...}, 'Person'),
  # }
    

  coerce_attr(string $name, any $value) (any)

The coerce_attr method is a surrogate accessor and gets and/or sets an instance attribute based on the coercion rules, returning the coerced value.

Since 1.23

coerce_attr example 1
  # given: synopsis
  package main;
  $person = Person->new(
    name => 'me',
  );
  my $coerce_name = $person->coerce_attr('name');
  # bless({value => "me"}, "Venus::String")
    
coerce_attr example 2
  # given: synopsis
  package main;
  $person = Person->new(
    name => 'me',
  );
  my $coerce_name = $person->coerce_attr('name', 'myself');
  # bless({value => "myself"}, "Venus::String")
    

  coerce_into(string $class, any $value) (object)

The coerce_into method attempts to build and return an object based on the class name and value provided, unless the value provided is already an object derived from the specified class.

Since 0.07

coerce_into example 1
  package main;
  my $person = Person->new;
  my $friend = $person->coerce_into('Person', {
    name => 'friend',
  });
  # bless({...}, 'Person')
    

  coerce_onto(hashref $data, string $name, string $class, any $value) (object)

The coerce_onto method attempts to build and assign an object based on the class name and value provided, as the value corresponding to the name specified, in the data provided. If the $value is omitted, the value corresponding to the name in the $data will be used.

Since 0.07

coerce_onto example 1
  package main;
  my $person = Person->new;
  my $data = { friend => { name => 'friend' } };
  my $friend = $person->coerce_onto($data, 'friend', 'Person');
  # bless({...}, 'Person'),
  # $data was updated
  #
  # {
  #   friend => bless({...}, 'Person'),
  # }
    
coerce_onto example 2
  package Player;
  use Venus::Class;
  with 'Venus::Role::Coercible';
  attr 'name';
  attr 'teammates';
  sub coercers {
    {
      teammates => 'Person',
    }
  }
  sub coerce_into_person {
    my ($self, $class, $value) = @_;
    return $class->new($value);
  }
  sub coerce_into_venus_string {
    my ($self, $class, $value) = @_;
    return $class->new($value);
  }
  sub coerce_teammates {
    my ($self, $code, $class, $value) = @_;
    return [map $self->$code($class, $_), @$value];
  }
  package main;
  my $player = Player->new;
  my $data = { teammates => [{ name => 'player2' }, { name => 'player3' }] };
  my $teammates = $player->coerce_onto($data, 'teammates', 'Person');
  # [bless({...}, 'Person'), bless({...}, 'Person')]
  # $data was updated
  #
  # {
  #   teammates => [bless({...}, 'Person'), bless({...}, 'Person')],
  # }
    

  coercers() (hashref)

The coercers method, if defined, is called during object construction, or by the "coercion" method, and returns key/value pairs where the keys map to class attributes (or input parameters) and the values are Venus::Space compatible package names.

Since 0.02

coercers example 1
  package main;
  my $person = Person->new(
    name => 'me',
  );
  my $coercers = $person->coercers;
  # {
  #   father   => "Person",
  #   mother   => "Person",
  #   name     => "Venus/String",
  #   siblings => "Person",
  # }
    

  coercion(hashref $data) (hashref)

The coercion method is called automatically during object construction but can be called manually as well, and is passed a hashref to coerce and return.

Since 0.02

coercion example 1
  package main;
  my $person = Person->new;
  my $coercion = $person->coercion({
    name => 'me',
  });
  # $coercion
  # {...}
  # $coercion->{name}
  # bless({...}, 'Venus::String')
  # $coercion->{father}
  # undef
  # $coercion->{mother}
  # undef
  # $coercion->{siblings}
  # undef
    
coercion example 2
  package main;
  my $person = Person->new;
  my $coercion = $person->coercion({
    name => 'me',
    mother => {name => 'mother'},
    siblings => [{name => 'brother'}, {name => 'sister'}],
  });
  # $coercion
  # {...}
  # $coercion->{name}
  # bless({...}, 'Venus::String')
  # $coercion->{father}
  # undef
  # $coercion->{mother}
  # bless({...}, 'Person')
  # $coercion->{siblings}
  # [bless({...}, 'Person'), bless({...}, 'Person'), ...]
    

Awncorp, "awncorp@cpan.org"

Copyright (C) 2022, Awncorp, "awncorp@cpan.org".

This program is free software, you can redistribute it and/or modify it under the terms of the Apache license version 2.0.

2023-11-27 perl v5.40.2

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.