EVOLUTION-MANAGER
Edit File: ScopedTimer.pm
# Helper code to debug dependencies and their versions. # <@LICENSE> # Licensed to the Apache Software Foundation (ASF) under one or more # contributor license agreements. See the NOTICE file distributed with # this work for additional information regarding copyright ownership. # The ASF licenses this file to you under the Apache License, Version 2.0 # (the "License"); you may not use this file except in compliance with # the License. You may obtain a copy of the License at: # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # </@LICENSE> package Mail::SpamAssassin::Util::ScopedTimer; use strict; use warnings; use bytes; use re 'taint'; our @ISA = qw(); sub new { my $class = shift; my $self = { main => shift, timer => shift, }; $self->{main}->timer_start($self->{timer}); return bless ($self, $class); } # OO hack: when the object goes out of scope, the timer ends. neat! sub DESTROY { my $self = shift; # best practices: prevent potential calls to eval and to system routines # in code of a DESTROY method from clobbering global variables $@ and $! local($@,$!); # keep outer error handling unaffected by DESTROY $self->{main} && $self->{timer} && $self->{main}->timer_end($self->{timer}); } 1;