Don't keep the _qp around - just pass it in to each hook.
git-svn-id: https://svn.perl.org/qpsmtpd/trunk@179 958fd67b-6ff1-0310-b445-bb7760255be9
This commit is contained in:
parent
b442d002f1
commit
03b8cda2b5
@ -2,7 +2,7 @@ package Qpsmtpd;
|
|||||||
use strict;
|
use strict;
|
||||||
|
|
||||||
$Qpsmtpd::VERSION = "0.27-dev";
|
$Qpsmtpd::VERSION = "0.27-dev";
|
||||||
sub TRACE_LEVEL { 6 }
|
sub TRACE_LEVEL () { 6 }
|
||||||
|
|
||||||
use Sys::Hostname;
|
use Sys::Hostname;
|
||||||
use Qpsmtpd::Constants;
|
use Qpsmtpd::Constants;
|
||||||
@ -88,7 +88,6 @@ sub get_qmail_config {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
sub load_plugins {
|
sub load_plugins {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my @plugins = $self->config('plugins');
|
my @plugins = $self->config('plugins');
|
||||||
@ -100,7 +99,7 @@ sub load_plugins {
|
|||||||
for my $plugin (@plugins) {
|
for my $plugin (@plugins) {
|
||||||
$self->log(7, "Loading $plugin");
|
$self->log(7, "Loading $plugin");
|
||||||
($plugin, my @args) = split /\s+/, $plugin;
|
($plugin, my @args) = split /\s+/, $plugin;
|
||||||
|
|
||||||
my $plugin_name = $plugin;
|
my $plugin_name = $plugin;
|
||||||
|
|
||||||
# Escape everything into valid perl identifiers
|
# Escape everything into valid perl identifiers
|
||||||
@ -116,7 +115,7 @@ sub load_plugins {
|
|||||||
|
|
||||||
# don't reload plugins if they are already loaded
|
# don't reload plugins if they are already loaded
|
||||||
next if defined &{"Qpsmtpd::Plugin::${plugin_name}::register"};
|
next if defined &{"Qpsmtpd::Plugin::${plugin_name}::register"};
|
||||||
|
|
||||||
my $sub;
|
my $sub;
|
||||||
open F, "$dir/$plugin" or die "could not open $dir/$plugin: $!";
|
open F, "$dir/$plugin" or die "could not open $dir/$plugin: $!";
|
||||||
{
|
{
|
||||||
@ -163,7 +162,7 @@ sub run_hooks {
|
|||||||
my @r;
|
my @r;
|
||||||
for my $code (@{$self->{_hooks}->{$hook}}) {
|
for my $code (@{$self->{_hooks}->{$hook}}) {
|
||||||
$self->log(5, "running plugin ", $code->{name});
|
$self->log(5, "running plugin ", $code->{name});
|
||||||
eval { (@r) = &{$code->{code}}($self->can('transaction') ? $self->transaction : {}, @_); };
|
eval { (@r) = $code->{code}->($self, $self->can('transaction') ? $self->transaction : {}, @_); };
|
||||||
$@ and $self->log(0, "FATAL PLUGIN ERROR: ", $@) and next;
|
$@ and $self->log(0, "FATAL PLUGIN ERROR: ", $@) and next;
|
||||||
!defined $r[0]
|
!defined $r[0]
|
||||||
and $self->log(1, "plugin ".$code->{name}
|
and $self->log(1, "plugin ".$code->{name}
|
||||||
|
@ -12,10 +12,11 @@ sub register_hook {
|
|||||||
my ($plugin, $hook, $method) = @_;
|
my ($plugin, $hook, $method) = @_;
|
||||||
# I can't quite decide if it's better to parse this code ref or if
|
# I can't quite decide if it's better to parse this code ref or if
|
||||||
# we should pass the plugin object and method name ... hmn.
|
# we should pass the plugin object and method name ... hmn.
|
||||||
$plugin->qp->_register_hook($hook, { code => sub { $plugin->$method(@_) },
|
$plugin->qp->_register_hook($hook, { code => sub { local $plugin->{_qp} = shift; $plugin->$method(@_) },
|
||||||
name => $plugin->plugin_name
|
name => $plugin->plugin_name
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
delete $plugin->{_qp};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub qp {
|
sub qp {
|
||||||
|
Loading…
Reference in New Issue
Block a user