diff --git a/content/posts/2022-11-02-multiple-dispatch-in-c++/index.md b/content/posts/2022-11-02-multiple-dispatch-in-c++/index.md index ba1a01d..e092cd0 100644 --- a/content/posts/2022-11-02-multiple-dispatch-in-c++/index.md +++ b/content/posts/2022-11-02-multiple-dispatch-in-c++/index.md @@ -262,3 +262,35 @@ int main() { Obviously, the issue with adding a new `SpaceStation` variant is once again apparent in this implementation. You will get a compile error unless you handle this new `SpaceStation` variant at every point you `visit` the `SpaceObject`s. + +## The Expression Problem + +One issue we have not been able to move past in these exemples is the +[Expression Problem][expression-problem]. In two words, this means that we can't +add a new data type (e.g: `SpaceStation`), or a new operation (e.g: `land_on`) +to our current code without re-compiling it. + +[expression-problem]: https://en.wikipedia.org/wiki/Expression_problem + +This is the downside I was pointing out in our previous sections: + +* Data type extension: one can easily add a new `SpaceObject` child-class in the + OOP version, but needs to modify each implementation if we want to add a new + method to the `SpaceObject` interface to implement a new operation. +* Operation extension: one can easily create a new function when using the + `std::variant` based representation, as pattern-matching easily allows us to + only handle the kinds of values we are interested in. But adding new + `SpaceObject` variant means we need to modify and/or re-compile every + `std::visit` call to handle the new variant. + +There is currently no (good) way in standard C++ to tackle the Expression +Problem. A paper ([Open Multi Methods for C++][N2216]) was written to propose +a new language feature to improve the situation. However it looks quite complex, +and never got followed up on for standardization. + +[N2216]: https://open-std.org/jtc1/sc22/wg21/docs/papers/2007/n2216.pdf + +In the mean-time, one can find some libraries (like [`yomm2`][yomm2]) that +reduce the amount of boiler-plate needed to emulate this feature. + +[yomm2]: https://github.com/jll63/yomm2