Skip to content

Latest commit

 

History

History
102 lines (73 loc) · 3.31 KB

Readme.md

File metadata and controls

102 lines (73 loc) · 3.31 KB

Terse Lambda

Terse lambdas for C++. [] TL(_1.name) == [] (auto&& it) { return it.name; }

Try it online

Motivation

Code size reduction for increased comprehension:

// Old:
[](std::string const& lhs, std::string const& rhs) {
    return lhs.size() < rhs.size();
}
// New:
[] TL(_1.size() < _2.size())

For deeper motivation, read on. Click here to skip straight to the documentation.

Why? C++ already has lambdas. Aren't they good enough?

Not really. See vector-of-bool's blog post Now I Am Become Perl.

C++11's lambdas are much better than no lambdas, but the lambda syntax gets in the way of understanding what the lambda does. C++ lambdas are just barely complex enough to require pushing onto the mental stack, requiring the reader to first analyze the lambda to understand what it does then pop the mental state and finally make sense of the full expression. Abbreviated lambdas make this transition unnecessary in many cases.

Consider the following:

std::sort(my_vector.begin(), my_vector.end(),
    [](std::string const& lhs, std::string const& rhs) {
        return lhs.size() < rhs.size();
    });

When I read this expression, here's my mental state:

  • std::sort(my_vector.begin(), my_vector.end(),. We are sorting a full vector by some custom order.
  • [](std::string const& lhs, std::string const& rhs). Lambda incoming. Do these parameters make sense? *forgets that we are sorting*. Yeah, it makes sense to take the parameters by const&.
  • return lhs.size() < rhs.size(). Return that the left side's size is less than the right side's size.... Oh, so this lambda compares two std::strings by size.
  • Where were we again? *glances up*. Oh yeah, we were sorting a vector.
  • So this sorts the vector by size.

In contrast, abbreviated lambdas don't require this transition:

std::sort(my_vector.begin(), my_vector.end(),
    [][&1.size() < &2.size()]);
  • std::sort(my_vector.begin(), my_vector.end(),. We are sorting a full vector by some custom order.
  • [][&1.size() < &2.size()] we compare the first size to the second size.
  • So this sorts the vector by size.

What does this library do to help this?

vector-of-bool proposes a syntax like [][&1.size() < &2.size()]; roughly the hyper-abbreviated syntax of P0573, which also proposes the more conservative [](lhs, rhs) => lhs.size() < rhs.size(). Neither syntax is in C++ today.

This library gives very similar syntax to the former proposal:

[] TL(_1.size() < _2.size())

Should I use this?

No*. This library changes the very syntax of C++ via use of macros. If you use this library, you risk making your code very hard to read to any unfamiliar readers.

That said, C++'s syntax is lacking in this case, and if you deem the niceness of a terse lambda syntax to outweigh the drawback of increased overhead to learn your codebase, that's your call.

* Rather, this should be your first reaction: skepticism of syntax-changing macros.

Documentation

See the API documentation.

For consuming TerseLambda using package managers, see the package manager documentation.