1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>process (RFilter::DeliveryAgent)</title>
<link rel=StyleSheet href="../../.././rdoc-style.css" type="text/css" media="screen" />
</head>
<body bgcolor="white">
<pre><span class="cmt"># File lib/rfilter/delivery_agent.rb, line 309</span>
<span class="kw">def</span> process(input, logfile)
<span class="kw">begin</span>
lda = RFilter::DeliveryAgent.new(input, logfile)
<span class="kw">yield</span> lda
lda.defer(<span class="str">"finished without a final delivery"</span>)
<span class="kw">rescue</span> Exception => exception
<span class="kw">if</span> exception.class <= DeliveryComplete
raise exception
<span class="kw">else</span>
<span class="kw">begin</span>
lda.log(0, <span class="str">"uncaught exception: "</span> + exception.inspect)
lda.log(0, <span class="str">"uncaught exception backtrace:\n "</span> +
exception.backtrace.join(<span class="str">"\n "</span>))
lda.defer(<span class="str">"uncaught exception"</span>)
<span class="kw">rescue</span> Exception
<span class="kw">if</span> $!.class <= DeliveryComplete
<span class="cmt"># The lda.defer above will generate this, just re-raise</span>
<span class="cmt"># the delivery status exception.</span>
raise
<span class="kw">else</span>
<span class="cmt"># Any errors logging in the uncaught exception and we</span>
<span class="cmt"># just re-raise the original exception</span>
raise exception
<span class="kw">end</span>
<span class="kw">end</span>
<span class="kw">end</span>
<span class="kw">end</span>
<span class="kw">end</span></pre>
</body>
</html>
|