This is the mail archive of the elfutils-devel@sourceware.org mailing list for the elfutils project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [PATCH] For clang use Blocks instead of nested functions.


On Fri, 2015-09-11 at 13:08 +0200, Petr Machata wrote:
> Having a custom syntax to bridge the differences between LLVM and GCC
> seems over the top.  It introduces a layer of indirection that is not
> familiar to C coders, and the usage mode is not immediately obvious
> (viz the __BLOCK annotations).  It's also fragile--people will forget
> how to use this and that it's supposed to be used at all, so __BLOCK
> annotations and variable ordering will go out of sync with
> requirements.

I agree. I should have said something earlier. But wanted to sleep on it
a bit before shooting the idea down. Nobody wants to be the bad guy.
Sorry for not speaking up earlier.

The proposed replacement is clever, but too verbose and has too
many/duplicate annotations that have to be kept in sync by hand. That
really destroys the whole reason why we use nested functions in the
first place.

We use nested functions as a simpler, more (type) safe, way of using
macros. With the added benefit that they can just use the locally
lexical scoped variables. So you don't need to mark them all up or pass
them all through to some static function. It really makes the code much
less cluttered/readable.

Any proposed replacement should really not make the code much more
cluttered/verbose. It wouldn't be bad if there is a little preprocessor
magic used (see for example INTUSE/DEF/DECL). But it shouldn't require
so much magic that it will be hard to read and maintain/keep up to date
when changing the code.

Thanks,

Mark

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]