351 lines
4.8 KiB
Text
351 lines
4.8 KiB
Text
# #!/usr/bin/perl
|
|
snippet #!
|
|
#!/usr/bin/env perl
|
|
|
|
# Hash Pointer
|
|
snippet .
|
|
=>
|
|
# Function
|
|
snippet sub
|
|
sub ${1:function_name} {
|
|
${0}
|
|
}
|
|
# Conditional
|
|
snippet if
|
|
if (${1}) {
|
|
${0}
|
|
}
|
|
# Conditional if..else
|
|
snippet ife
|
|
if (${1}) {
|
|
${2}
|
|
}
|
|
else {
|
|
${0}
|
|
}
|
|
# Conditional if..elsif..else
|
|
snippet ifee
|
|
if (${1}) {
|
|
${2}
|
|
}
|
|
elsif (${3}) {
|
|
${4:# elsif...}
|
|
}
|
|
else {
|
|
${0}
|
|
}
|
|
snippet eif
|
|
elsif (${1}) {
|
|
${0}
|
|
}
|
|
# Conditional One-line
|
|
snippet xif
|
|
${1:expression} if ${2:condition};
|
|
# Unless conditional
|
|
snippet unless
|
|
unless (${1}) {
|
|
${0}
|
|
}
|
|
# Unless conditional One-line
|
|
snippet xunless
|
|
${1:expression} unless ${2:condition};
|
|
# Try/Except
|
|
snippet eval
|
|
local $@;
|
|
eval {
|
|
${1:# do something risky...}
|
|
};
|
|
if (my $e = $@) {
|
|
${0:# handle failure...}
|
|
}
|
|
# While Loop
|
|
snippet wh
|
|
while (${1}) {
|
|
${0}
|
|
}
|
|
# While Loop One-line
|
|
snippet xwh
|
|
${1:expression} while ${2:condition};
|
|
# C-style For Loop
|
|
snippet cfor
|
|
for (my $${2:var} = 0; $$2 < ${1:count}; $$2${3:++}) {
|
|
${0}
|
|
}
|
|
# For loop one-line
|
|
snippet xfor
|
|
${1:expression} for @${2:array};
|
|
# Foreach Loop
|
|
snippet for
|
|
foreach my $${1:x} (@${2:array}) {
|
|
${0}
|
|
}
|
|
# Foreach Loop One-line
|
|
snippet fore
|
|
${1:expression} foreach @${2:array};
|
|
# Package
|
|
snippet package
|
|
package ${1:`substitute(vim_snippets#Filename('', 'Page Title'), '^.', '\u&', '')`};
|
|
|
|
${0}
|
|
|
|
1;
|
|
|
|
__END__
|
|
# Package syntax perl >= 5.14
|
|
snippet packagev514
|
|
package ${1:`substitute(vim_snippets#Filename('', 'Page Title'), '^.', '\u&', '')`} ${2:0.99};
|
|
|
|
${0}
|
|
|
|
1;
|
|
|
|
__END__
|
|
#moose
|
|
snippet moose
|
|
use Moose;
|
|
use namespace::autoclean;
|
|
${1:#}BEGIN {extends '${2:ParentClass}'};
|
|
|
|
${0}
|
|
# parent
|
|
snippet parent
|
|
use parent qw(${0:Parent Class});
|
|
# Read File
|
|
snippet slurp
|
|
my $${1:var} = do { local $/; open my $file, '<', "${2:file}"; <$file> };
|
|
${0}
|
|
# strict warnings
|
|
snippet strwar
|
|
use strict;
|
|
use warnings;
|
|
# older versioning with perlcritic bypass
|
|
snippet vers
|
|
## no critic
|
|
our $VERSION = '${0:version}';
|
|
eval $VERSION;
|
|
## use critic
|
|
# new 'switch' like feature
|
|
snippet switch
|
|
use feature 'switch';
|
|
|
|
# Anonymous subroutine
|
|
snippet asub
|
|
sub {
|
|
${0}
|
|
}
|
|
|
|
|
|
|
|
# Begin block
|
|
snippet begin
|
|
BEGIN {
|
|
${0}
|
|
}
|
|
|
|
# call package function with some parameter
|
|
snippet pkgmv
|
|
__PACKAGE__->${1:package_method}(${0:var})
|
|
|
|
# call package function without a parameter
|
|
snippet pkgm
|
|
__PACKAGE__->${0:package_method}()
|
|
|
|
# call package "get_" function without a parameter
|
|
snippet pkget
|
|
__PACKAGE__->get_${0:package_method}()
|
|
|
|
# call package function with a parameter
|
|
snippet pkgetv
|
|
__PACKAGE__->get_${1:package_method}(${0:var})
|
|
|
|
# complex regex
|
|
snippet qrx
|
|
qr/
|
|
${0:regex}
|
|
/xms
|
|
|
|
#simpler regex
|
|
snippet qr/
|
|
qr/${0:regex}/x
|
|
|
|
#given
|
|
snippet given
|
|
given ($${1:var}) {
|
|
${2:# cases}
|
|
${0:# default}
|
|
}
|
|
|
|
# switch-like case
|
|
snippet when
|
|
when (${1:case}) {
|
|
${0}
|
|
}
|
|
|
|
# hash slice
|
|
snippet hslice
|
|
@{ ${1:hash} }{ ${0:array} }
|
|
|
|
|
|
# map
|
|
snippet map
|
|
map { ${0: body } } ${1: @array } ;
|
|
|
|
|
|
|
|
# Pod stub
|
|
snippet ppod
|
|
=head1 NAME
|
|
|
|
${1:ClassName} - ${2:ShortDesc}
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
use $1;
|
|
|
|
${3:# synopsis...}
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
${0:# longer description...}
|
|
|
|
|
|
=head1 INTERFACE
|
|
|
|
|
|
=head1 DEPENDENCIES
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
|
# Heading for a subroutine stub
|
|
snippet psub
|
|
=head2 ${1:MethodName}
|
|
|
|
${0:Summary....}
|
|
|
|
# Heading for inline subroutine pod
|
|
snippet psubi
|
|
=head2 ${1:MethodName}
|
|
|
|
${0:Summary...}
|
|
|
|
|
|
=cut
|
|
# inline documented subroutine
|
|
snippet subpod
|
|
=head2 $1
|
|
|
|
Summary of $1
|
|
|
|
=cut
|
|
|
|
sub ${1:subroutine_name} {
|
|
${0}
|
|
}
|
|
# Subroutine signature
|
|
snippet parg
|
|
=over 2
|
|
|
|
=item
|
|
Arguments
|
|
|
|
|
|
=over 3
|
|
|
|
=item
|
|
C<${1:DataStructure}>
|
|
|
|
${2:Sample}
|
|
|
|
|
|
=back
|
|
|
|
|
|
=item
|
|
Return
|
|
|
|
=over 3
|
|
|
|
|
|
=item
|
|
C<${0:...return data}>
|
|
|
|
|
|
=back
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
# Moose has
|
|
snippet has
|
|
has ${1:attribute} => (
|
|
is => '${2:ro|rw}',
|
|
isa => '${3:Str|Int|HashRef|ArrayRef|etc}',
|
|
default => sub {
|
|
${4:defaultvalue}
|
|
},
|
|
${0:# other attributes}
|
|
);
|
|
|
|
|
|
# override
|
|
snippet override
|
|
override ${1:attribute} => sub {
|
|
${2:# my $self = shift;};
|
|
${0:# my ($self, $args) = @_;};
|
|
};
|
|
|
|
|
|
# use test classes
|
|
snippet tuse
|
|
use Test::More;
|
|
use Test::Deep; # (); # uncomment to stop prototype errors
|
|
use Test::Exception;
|
|
|
|
# local test lib
|
|
snippet tlib
|
|
use lib qw{ ./t/lib };
|
|
|
|
#test methods
|
|
snippet tmeths
|
|
$ENV{TEST_METHOD} = '${0:regex}';
|
|
|
|
# runtestclass
|
|
snippet trunner
|
|
use ${0:test_class};
|
|
$1->runtests();
|
|
|
|
# Test::Class-style test
|
|
snippet tsub
|
|
sub t${1:number}_${2:test_case} :Test(${3:num_of_tests}) {
|
|
my $self = shift;
|
|
${0}
|
|
|
|
}
|
|
|
|
# Test::Routine-style test
|
|
snippet trsub
|
|
test ${1:test_name} => { description => '${2:Description of test.}'} => sub {
|
|
my ($self) = @_;
|
|
${0}
|
|
};
|
|
|
|
#prep test method
|
|
snippet tprep
|
|
sub prep${1:number}_${2:test_case} :Test(startup) {
|
|
my $self = shift;
|
|
${0}
|
|
}
|
|
|
|
# cause failures to print stack trace
|
|
snippet debug_trace
|
|
use Carp; # 'verbose';
|
|
# cloak "die"
|
|
# warn "warning"
|
|
$SIG{'__DIE__'} = sub {
|
|
require Carp; Carp::confess
|
|
};
|
|
|