Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:33230 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 59420 invoked by uid 1010); 18 Nov 2007 01:20:19 -0000 Delivered-To: ezmlm-scan-internals@lists.php.net Delivered-To: ezmlm-internals@lists.php.net Received: (qmail 59405 invoked from network); 18 Nov 2007 01:20:19 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 18 Nov 2007 01:20:19 -0000 Authentication-Results: pb1.pair.com smtp.mail=mehmet.yavuz.selim@gmail.com; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=mehmet.yavuz.selim@gmail.com; sender-id=pass; domainkeys=bad Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.146.180 as permitted sender) DomainKey-Status: bad X-DomainKeys: Ecelerity dk_validate implementing draft-delany-domainkeys-base-01 X-PHP-List-Original-Sender: mehmet.yavuz.selim@gmail.com X-Host-Fingerprint: 209.85.146.180 wa-out-1112.google.com Received: from [209.85.146.180] ([209.85.146.180:41269] helo=wa-out-1112.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id A2/C5-14070-2539F374 for ; Sat, 17 Nov 2007 20:20:19 -0500 Received: by wa-out-1112.google.com with SMTP id l24so1644922waf for ; Sat, 17 Nov 2007 17:20:15 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=beta; h=domainkey-signature:received:received:message-id:date:from:to:subject:cc:in-reply-to:mime-version:content-type:content-transfer-encoding:content-disposition:references; bh=3q5JWLLhwmR90HeALiCzhVP2pLU9htw4WZVRhk/syGc=; b=JJJMZ7z21xY2NDh3SVT2XlSfjK4njemINPr3uxbDqLZ+f3zZgz1YuBdhrIi99vmmAH3bk5xR2tkO+iRwCMLhjBZOUPidt+KLvedFseKiRk1GWw0QeI/on1Ioep+TpR5tnc2lMS1xXpKw7pYwD0yBe2bn5NY0yGU1WmoZxZXpoBM= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=beta; h=received:message-id:date:from:to:subject:cc:in-reply-to:mime-version:content-type:content-transfer-encoding:content-disposition:references; b=bqWZ9sV/0Rv1z0qJ5I1YGcaCrvNpDzayZPZ8n8X3ByLNte6KC7evHvLeoXHka2BJ0AAWYudkWEgN5c1ptd+B5JWgHsfkM4XYmsMZDqdjC8mr96fYKBg1Yf6pvtVZ7M64rasbCeyHBT7mOBkzkpRt8R3bY8uxtKmitZoKZNwCO2k= Received: by 10.115.95.1 with SMTP id x1mr686043wal.1195348815770; Sat, 17 Nov 2007 17:20:15 -0800 (PST) Received: by 10.114.59.16 with HTTP; Sat, 17 Nov 2007 17:20:15 -0800 (PST) Message-ID: <1abd9eb20711171720wa80dcb7i58610d2f5ce6796a@mail.gmail.com> Date: Sun, 18 Nov 2007 02:20:15 +0100 To: "Evert | Rooftop" Cc: internals@lists.php.net In-Reply-To: <473F8996.9010807@rooftopsolutions.nl> MIME-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Content-Disposition: inline References: <1abd9eb20711171436w4b797bffu4cab758407beebf6@mail.gmail.com> <473F8996.9010807@rooftopsolutions.nl> Subject: Re: [PHP-DEV] Restore output buffer in case of exceptions From: mehmet.yavuz.selim@gmail.com ("Mehmet Yavuz Selim Soyturk") On Nov 18, 2007 1:38 AM, Evert | Rooftop wrote: > Generally I make sure that the parts of my code that start an output > buffer are also responsible for closing the output buffer.. so something > like this wouldn't be uncommon in my code.. > > > ob_start(); > try { > do_something(); > } catch (Exception $e) { > ob_end_clean(); > throw $e; > } > > $data = ob_get_clean(); > Thanks for the answers. I wasn't aware of the fact that ob's could nest. So one can manually translate the first try-catch to the second: try { // ... code } catch (Exception $e) { // ... code } ob_start(); try { // ... code ob_end_flush(); } catch (Exception $e) { ob_end_clean(); // ... code } More verbose, but works. -- Mehmet