⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.93
Server IP:
65.108.141.171
Server:
Linux server.heloix.com 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
Server Software:
Apache
PHP Version:
7.4.33
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
usr
/
share
/
perl5
/
Specio
/
Edit File: DeclaredAt.pm
package Specio::DeclaredAt; use strict; use warnings; our $VERSION = '0.45'; use Specio::OO; { my $attrs = { package => { isa => 'Str', required => 1, }, filename => { isa => 'Str', required => 1, }, line => { isa => 'Int', required => 1, }, subroutine => { isa => 'Str', predicate => 'has_subroutine', }, }; ## no critic (Subroutines::ProhibitUnusedPrivateSubroutines) sub _attrs { return $attrs; } } sub new_from_caller { my $class = shift; my $depth = shift; my %p; @p{qw( package filename line )} = ( caller($depth) )[ 0, 1, 2 ]; my $sub = ( caller( $depth + 1 ) )[3]; $p{subroutine} = $sub if defined $sub; return $class->new(%p); } sub description { my $self = shift; my $package = $self->package; my $filename = $self->filename; my $line = $self->line; my $desc = "declared in package $package ($filename) at line $line"; if ( $self->has_subroutine ) { $desc .= ' in sub named ' . $self->subroutine; } return $desc; } __PACKAGE__->_ooify; 1; # ABSTRACT: A class to represent where a type or coercion was declared __END__ =pod =encoding UTF-8 =head1 NAME Specio::DeclaredAt - A class to represent where a type or coercion was declared =head1 VERSION version 0.45 =head1 SYNOPSIS my $declared = Specio::DeclaredAt->new_from_caller(1); print $declared->description; =head1 DESCRIPTION This class provides a thin wrapper around some of the return values from Perl's C<caller> built-in. It's used internally to identify where types and coercions are being declared, which is useful when generating error messages. =head1 API This class provides the following methods. =head2 Specio::DeclaredAt->new_from_caller($depth) Given a call stack depth, this method returns a new C<Specio::DeclaredAt> object. =head2 $declared_at->package, $declared_at->filename, $declared_at->line Returns the call stack information recorded when the object was created. These values are always populated. =head2 $declared_at->subroutine Returns the subroutine from the call stack. This may be an C<udnef> =head2 $declared_at->has_subroutine Returns true if there is a subroutine name associated with this object. =head2 $declared_at->description Puts all the information together into a single string like "declared in package Foo::Bar (.../Foo/Bar.pm) at line 42 in sub named blah". =head1 SUPPORT Bugs may be submitted at L<https://github.com/houseabsolute/Specio/issues>. I am also usually active on IRC as 'autarch' on C<irc://irc.perl.org>. =head1 SOURCE The source code repository for Specio can be found at L<https://github.com/houseabsolute/Specio>. =head1 AUTHOR Dave Rolsky <autarch@urth.org> =head1 COPYRIGHT AND LICENSE This software is Copyright (c) 2012 - 2019 by Dave Rolsky. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible) The full text of the license can be found in the F<LICENSE> file included with this distribution. =cut
Simpan