Compare commits

...

2 commits

Author SHA1 Message Date
Bruno BELANYI 67592115e3 Add Multiple Dispatch post
All checks were successful
continuous-integration/drone/push Build is passing
2022-11-02 16:37:48 +01:00
Bruno BELANYI 532e71e87b posts: multiple-dispatch: add expression problem 2022-11-02 16:37:30 +01:00

View file

@ -262,3 +262,35 @@ int main() {
Obviously, the issue with adding a new `SpaceStation` variant is once again 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 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. 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