<div dir="ltr"><br><br>On Sunday, February 28, 2016 at 6:12:22 PM UTC-6, Matt Calabrese wrote:<blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">On Sat, Feb 27, 2016 at 8:16 AM, Vicente J. Botet Escriba < <br><a href="javascript:" target="_blank" gdf-obfuscated-mailto="l-XbcKVUIAAJ" rel="nofollow" onmousedown="this.href='javascript:';return true;" onclick="this.href='javascript:';return true;">vicent...@wanadoo.fr</a>> wrote: <br> <br>> Dear Boost community, <br>> <br>> The formal review of Paul Fultz II's Fit library starts on Wednesday, 2nd March and ends on 13th March. <br>> <br>> <br>I'm looking through the documentation right now and it looks great, though <br>I have not used the library yet. Some suggestions -- I think the docs <br>really need a more formal motivation/tutorial section at the very front. It <br>starts with *what* the library is in very general terms, and jumps quickly <br>into what the library can do, but I think a bit of a narrative describing a <br>motivating example would help sell it to those who are not already more <br>familiar with the *why*. This is done a little bit, scattered throughout <br>the docs, but I find that the best docs usually tell something of a story. <br>This is just a request. </blockquote><div><br>Do you have an idea of what kind of problem would make a good motivating<br>example for this library? The quick start guide moves quickly so people can<br>quickly see what the library can do. However, a more in-depth turtorial could<br>be useful as well. I just need to think of a larger problem that stays focus<br>on the functional aspect.<br> </div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">I suggest not using the name FunctionObject for something that is only <br>callable with a const object. This is a little more specific that what most <br>people refer to as a function object in C++ and may cause confusion. <br></blockquote><div><br>Good point. This would also apply to Callable as well.<br> </div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;"> <br>I'm fairly certain that the reinterpret casting involved with <br>BOOST_FIT_STATIC_LAMBDA is UB. <br></blockquote><div><br>Not really, since the objects are empty, there is no data access. I have a<br>static assert to guard against this restriction. Also, on gcc and clang with<br>BOOST_FIT_STATIC_LAMBDA_FUNCTION, the reinterpret cast happens at compile-<br>time.<br><br>Now there could be an insane implementation where this doesn't work(perhaps<br>the lambdas are not empty for some strange reason), which the library would<br>have to apply a different technique to make it work. However, this is quite<br>unlikely considering that C++ will probably get constexpr lambdas and inline<br>variables in the future.<br><br>Paul<br><br></div></div>