Settings

Theme

Simple C++11 metaprogramming

pdimov.com

53 points by VeXocide 11 years ago · 10 comments

Reader

jlarocco 11 years ago

This type of C++ code makes me sad. I can follow along and figure out what it's doing, but I really have to slow down and think about it. C++ template metaprogramming has the ugliest syntax of a "real" programming language that I've ever seen. Brainfuck might win for hardest to follow code, but god damn it, C++ is really trying.

IMO, Lisp did metaprogramming the right way, 40 years ago. It's built into the language and doesn't look like a hacked on cluster f*. Anybody familiar with regular Lisp can follow along with Lisp metaprogramming, and it's far more powerful than what's available in C++. And nowadays, the performance is even competitive.

  • igravious 11 years ago

    This type of C++ code also makes me sad. I actually can't follow along. I can't glance at the code and parse what it is doing because the template keyword has many flavours, as does class, as does typename, as does using, as does ..., and so on. < and > seem to be the template equivalent of ( and ). I can't tell the intent of a piece of template code quickly.

    I agree with your Lisp sentiment. It appears that the C++ folks have spent the last 15 (20?) years re-implementing Lisp macros badly. Every time they work out the kinks in the syntax, remove corner cases, and make it more expressive: it becomes more Lisp-like.

    When you compare with the approach Ruby took (granted, Ruby is a dynamic language) you get the feeling that the C++ folks went wrong somewhere. Far be it from me who has never implemented a compiler to criticise them but that's the honest feeling I get. Ruby made everything an object with an associated class. Or what amounts to the same thing, it made every type of thing get-at-able as an object with an associated class. And here is the kicker, including Object and Class itself. Why could the C++ folks not have made type an object with an associated class with compile and runtime methods?

        class Foo {
            ...
        }
    
    is just sugar for

        type Foo = new class();
        Foo.class_eval {
            ...
        }
    • gumby 11 years ago

      > It appears that the C++ folks have spent the last 15 (20?) years re-implementing Lisp macros badly.

      Maybe it will make you and jlarocco happier to know that Stroustrup feels your pain.

      Years ago at a standards meeting (well, having drinks, not during the meeting itself) he and I were talking about C++ and Lisp and I said how much I missed defmacro. He became quite animated that #define had "polluted the ecological niche" and that templating "was the best we could do to bring macros to C++".

      C++ is/was hobbled by its C back compatibility (lucky eventually they became brave enough to snap that link). In retrospect I still think it was a good idea for the sake of growing the C++ user base, but it has had some dreadful implications.

      The syntax is horrible but it is still one of the most expressive languages I have used. And much as I look back fondly to my years as a Lispm hacker, I have to say, times move on.

  • platform 11 years ago

    How did Lisp solve (40 years ago) the problem of generating a compile time errors when types of the arguments into a function call did not match with what the developer of the function anticipated?

    • vadiml 11 years ago

      When you look at error messages of C++ inside of metaprogramming code you understand that the error reporting in case of argument mismatch is still not solved .... :)

    • sklogic 11 years ago

      By allowing developers to implement whatever level of error message reporting they fancy.

zvrba 11 years ago

Cool post. I have always disliked C++ MP because I couldn't see the forest for the trees. Judging by the first few examples (using, mp_rename) C++11 cleans it up and makes it understandable.

ndesaulniers 11 years ago

While I know nothing about metaprogramming in C++, the book Metaprogramming Ruby is one of the most well done and thought provoking programming book I have ever read, one I always recommend. Really, even if you hate Ruby, it's worth your while to see how metaprogramming can be used to problem solve, which is ultimately what all this is about.

The most popular Ruby framework, Ruby on Rails, has quite the learning curve because it's based heavily on conventions enabled by metaprogramming. inb4 lengthy discussion of "convention vs configuration" and "magic."

jokoon 11 years ago

The title seems ironic. Templates are often the part of C++ where I feel like I'm a complete idiot. It's not exactly the C++ I like, but I like C++ anyway.

arithma 11 years ago

On a little less serious note, I hope Haskell and C++ merge into something beautiful. Peak performance (par aliasing) and peak expressivity/safety.

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection