public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Dan Aloni <da-x@gmx.net>
To: linux-kernel <linux-kernel@vger.kernel.org>
Subject: Re: [RFC] [PATCH] C exceptions in kernel
Date: 23 Feb 2002 19:00:16 +0200	[thread overview]
Message-ID: <1014483618.3085.37.camel@callisto.yi.org> (raw)
In-Reply-To: <20020223082211.Z11156@work.bitmover.com>
In-Reply-To: <1014412325.1074.36.camel@callisto.yi.org> <20020223162100.A1952@outpost.ds9a.nl> <1014480355.1844.16.camel@callisto.yi.org>  <20020223082211.Z11156@work.bitmover.com>

On Sat, 2002-02-23 at 18:22, Larry McVoy wrote:
> On Sat, Feb 23, 2002 at 06:05:48PM +0200, Dan Aloni wrote:
> > But, it CAN be used in *local* driver call branches. Writing a new
> > driver? have a lot of local nested calls? Hate goto's? You can use
> > exceptions.
> 
> Is this really anything other than syntactic sugar?  Maybe it's 
> different in drivers, but I find myself doing the following in user 
> space all the time
> 
> 	#define	unless(x)	if (!(x))	/* perl/BCPL corrupted me */
> 
> 	function(...)
> 	{
> 		char	*foo = 0, *bar = 0;
> 		int	locked = 0;
> 		int	rc = -1;
> 
> 		if (bad args or something) {
> 	out:		if (foo) free(foo);
> 			if (bar) free(bar);
> 			if (locked) unlock();
> 			return (rc);
> 		}
> 
> 		unless (locked = get_the_lock()) goto out;
> 		unless (foo = allocate_foo()) goto out;
> 		unless (bar = allocate_bar()) goto out;
> 
> 		more code....
> 
> 		rc = 0;
> 		goto out;
> 	}
> 
> It seems ugly at first but it has some nice attributes:
> 
>     a) all the cleanup is in one place, for both the error path and
the 
>        non-error path.  I could put it at the bottom, I like it at the
>        top because that's where I tend to have the list of things
needed
>        to be cleaned.
> 
>     b) all the error cases are branches, the normal path is
straightline.
> 
>     c) it's as dense as I can make it.
> 
> So how would you do the same thing with exceptions?

Like this:

function(...)
{
	char	*foo = 0, *bar = 0;
	int	locked = 0;
	int	rc = -1;
 
	try {
		if (bad args or something) 
			throw;
 
		locked = get_the_lock();
		foo = allocate_foo();
		bar = allocate_bar();

		more code....

		rc = 0;
	}	
	cleanup {
		if (foo) free(foo);
		if (bar) free(bar);
		if (locked) unlock();
	}  
	return rc;
}

Looks much better, IMHO.

The cleanup() block will run after the try block even if an exception 
did not occur, and will run also if the exception occured, passing the
exception to the next catch() or cleanup() block in stack.


  reply	other threads:[~2002-02-23 17:05 UTC|newest]

Thread overview: 29+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2002-02-22 21:12 [RFC] [PATCH] C exceptions in kernel Dan Aloni
2002-02-22 21:28 ` Davide Libenzi
2002-02-22 22:10 ` Richard B. Johnson
2002-02-22 22:34 ` David B. Stevens
2002-02-22 22:48   ` Davide Libenzi
2002-02-23  3:37 ` Edgar Toernig
     [not found] ` <mailman.1014437101.26721.linux-kernel2news@redhat.com>
2002-02-23 10:11   ` Pete Zaitcev
2002-02-23 12:26     ` Keith Owens
2002-02-23 12:50       ` Pete Zaitcev
2002-02-23 23:07         ` Jes Sorensen
2002-02-23 23:40           ` Keith Owens
2002-02-24  1:02             ` Jes Sorensen
2002-02-24 23:45               ` Richard Gooch
2002-02-23 23:50         ` Bill Huey
2002-02-24  1:31           ` Davide Libenzi
2002-02-24  2:55             ` Bill Huey
2002-02-23 15:13 ` Felix von Leitner
2002-02-23 15:21 ` bert hubert
2002-02-23 16:05   ` Dan Aloni
2002-02-23 16:22     ` Larry McVoy
2002-02-23 17:00       ` Dan Aloni [this message]
2002-02-23 17:52         ` Francois Romieu
2002-02-23 17:07       ` bert hubert
2002-02-23 17:47   ` Alexander Viro
2002-02-23 18:21     ` bert hubert
2002-02-23 18:31       ` Larry McVoy
2002-02-23 18:38         ` bert hubert
2002-02-23 19:12           ` Kurt Ferreira
2002-02-23 23:05       ` Jes Sorensen

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1014483618.3085.37.camel@callisto.yi.org \
    --to=da-x@gmx.net \
    --cc=linux-kernel@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox