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::Core::Mixin(3) User Contributed Perl Documentation Venus::Core::Mixin(3)

Venus::Core::Mixin - Mixin Base Class

Mixin Base Class for Perl 5

  package Person;
  use base 'Venus::Core::Mixin';
  package User;
  use base 'Venus::Core::Class';
  package main;
  my $user = User->MIXIN('Person')->new(
    fname => 'Elliot',
    lname => 'Alderson',
  );
  # bless({fname => 'Elliot', lname => 'Alderson'}, 'User')

This package provides a mixin base class with mixin building and object construction lifecycle hooks.

This package inherits behaviors from:

Venus::Core

This package provides the following methods:

  does(string $name) (boolean)

The does method returns true if the object is composed of the role provided.

Since 1.02

does example 1
  package Employee;
  use base 'Venus::Core::Role';
  Employee->MIXIN('Person');
  package main;
  my $user = User->ROLE('Employee')->new(
    fname => 'Elliot',
    lname => 'Alderson',
  );
  my $does = $user->does('Employee');
  # 1
    

  import(any @args) (any)

The import method throws a fatal exception whenever the "use" in perlfunc declaration is used with mixins as they are meant to be consumed via the "mixin" keyword function.

Since 2.91

import example 1
  package main;
  use Person;
  # Exception! (isa Venus::Fault)
    

  meta() (Venus::Meta)

The meta method returns a Venus::Meta objects which describes the package's configuration.

Since 1.02

meta example 1
  package main;
  my $user = User->ROLE('Person')->new(
    fname => 'Elliot',
    lname => 'Alderson',
  );
  my $meta = Person->meta;
  # bless({...}, 'Venus::Meta')
    

  unimport(any @args) (any)

The unimport method invokes the "UNIMPORT" lifecycle hook and is invoked whenever the "no" in perlfunc declaration is used.

Since 2.91

unimport example 1
  package main;
  no 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.