Name Mode Size
..
crany.cpp 100644 1 kb
README.md
# [`crany`][] **C**oncept-based **R**elaying **Any** C++14 type. For a usage example, see `tests/crany.cpp`. For a diagram visualizing the implementation, see `doc/crany.dot.png`. [`crany`]: https://git.rcrnstn.net/rcrnstn/crany ## References The references below focus on the timeline and online resources. This work builds on that of many others: - Chris Cleeland, Douglas Schmidt, Timothy Harrison - External Polymorphism - 1996, Proceedings of the 3rd Pattern Languages of Programming Conference, [paper](https://www.dre.vanderbilt.edu/~schmidt/PDF/C++-EP.pdf) - Kevlin Henney - Valued Conversions - 2000, C++ Report, [paper](https://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.374.2252&rep=rep1&type=pdf) - Sean Parent - Runtime Concepts: Generic Programming and Runtime Polymorphism - Unpublished, [paper](https://stlab.cc/legacy/runtime-concepts.html) - Concept-Based Runtime Polymorphism - 2007, BoostCon, [slides](https://stlab.cc/legacy/figures/Boost_poly.pdf) - Value Semantics and Concept-based Polymorphism - 2012, C++Now, [talk](https://www.youtube.com/watch?v=_BpMYeUFXv8), [slides](https://sean-parent.stlab.cc/papers-and-presentations/#value-semantics-and-concept-based-polymorphism) - Inheritance Is The Base Class of Evil - 2013, GoingNative, [talk](https://www.youtube.com/watch?v=bIhUE5uUFOA), [slides](https://sean-parent.stlab.cc/papers-and-presentations/#inheritance-is-the-base-class-of-evil) - Better Code: Runtime Polymorphism - 2017, NDC, [talk](https://www.youtube.com/watch?v=QGcVXgEVMJg), [slides](https://sean-parent.stlab.cc/papers-and-presentations/#better-code-runtime-polymorphism) - Louis Dionne - Runtime Polymorphism: Back to the Basics - 2017, CppCon, [talk](https://www.youtube.com/watch?v=gVGtNFg4ay0), [slides](https://ldionne.com/cppcon-2017-runtime-polymorphism) - 2018, ACCU, [talk](https://www.youtube.com/watch?v=H8lFldGvt9w), [slides](https://ldionne.com/accu-2018-runtime-polymorphism) - 2018, C++Now, [talk](https://www.youtube.com/watch?v=OtU51Ytfe04), [slides](https://ldionne.com/cppnow-2018-runtime-polymorphism) Other related work: - Zach Laine - Pragmatic Type Erasure: Solving OOP Problems w/ Elegant Design Pattern - 2014, CppCon, [talk](https://www.youtube.com/watch?v=0I0FD3N5cgM) - Sy Brand - Dynamic Polymorphism with Metaclasses and Code Injection - 2020, CppCon, [talk](https://www.youtube.com/watch?v=8c6BAQcYF_E) - Klaus Igelberger - Breaking Dependencies: Type Erasure - A Design Analysis - 2021, CppCon, [talk](https://www.youtube.com/watch?v=4eeESJQk-mw&t=23m26s) Related projects: - Adobe's [Poly](https://stlab.adobe.com/group__poly__related.html) (of which Sean Parent was a principal contributor) - Louis Dionne's [Dyno](https://github.com/ldionne/dyno) - Facebook's [Folly Poly](https://github.com/facebook/folly/blob/main/folly/docs/Poly.md) Related patterns: - Adapter pattern - [Wikipedia](https://en.wikipedia.org/wiki/Adapter_pattern) - [GoF Design Patterns](https://en.wikipedia.org/wiki/Design_Patterns) - Decorator pattern - [Wikipedia](https://en.wikipedia.org/wiki/Decorator_pattern) - [GoF Design Patterns](https://en.wikipedia.org/wiki/Design_Patterns) - External Polymorphism pattern - [WikiWikiWeb](https://wiki.c2.com/?ExternalPolymorphism) ## Build system This project supports [CMake][] and uses [`cmake-common`][]. There are several ways to use it in other CMake-based projects: - With [`find_package`][]: ([Package][] and) [install][] it on the system. - With [`add_subdirectory`][]: Bundle it. - With [`FetchContent`][]: Download it as part of the CMake configure step. - With [`cmake-common`][]: Use any of the above methods through a simplified interface. As usual, use [`add_dependencies`][] or [`target_link_libraries`][] (or `cmake-common`'s `DEPENDENCIES_*`) to declare the dependency. [CMake]: https://cmake.org [`cmake-common`]: https://git.rcrnstn.net/rcrnstn/cmake-common [`FetchContent`]: https://cmake.org/cmake/help/v3.14/module/FetchContent.html [`add_subdirectory`]: https://cmake.org/cmake/help/v3.14/command/add_subdirectory.html [`find_package`]: https://cmake.org/cmake/help/v3.14/command/find_package.html [Package]: #Package [Install]: #Install [`add_dependencies`]: https://cmake.org/cmake/help/v3.14/command/add_dependencies.html [`target_link_libraries`]: https://cmake.org/cmake/help/v3.14/command/target_link_libraries.html ### Configure and generate To configure and generate a build tree, use `cmake`: ```sh cmake -B _build ``` To set the build type, pass e.g. `-D`[`CMAKE_BUILD_TYPE`][]`=Release`. [`cmake`]: https://cmake.org/cmake/help/v3.14/manual/cmake.1.html#generate-a-project-buildsystem [`CMAKE_BUILD_TYPE`]: https://cmake.org/cmake/help/v3.14/variable/CMAKE_BUILD_TYPE.html ### Build To build, use [`cmake --build`][]: ```sh cmake --build _build ``` To disable building tests, pass `-D`[`BUILD_TESTING`][]`=OFF`. [`cmake --build`]: https://cmake.org/cmake/help/v3.14/manual/cmake.1.html#build-a-project [`BUILD_TESTING`]: https://cmake.org/cmake/help/v3.14/module/CTest.html ### Test To run tests, use [`ctest`][]: ```sh (cd _build && ctest) ``` To show output from failing tests, pass `--output-on-failure`. To show output from all tests, pass `--verbose`. [`ctest`]: https://cmake.org/cmake/help/v3.14/manual/ctest.1.html ### Package To package, use [`cpack`][]: ```sh (cd _build && cpack) ``` [`cpack`]: https://cmake.org/cmake/help/v3.14/manual/cpack.1.html ### Install To install onto the current system, use [`cmake --install`][]: ```sh cmake --install _build ``` To set the prefix, pass e.g. `-D`[`CMAKE_INSTALL_PREFIX`][]`="$HOME/.local"`. [`cmake --install`]: https://cmake.org/cmake/help/v3.14/manual/cmake.1.html#install-a-project [`CMAKE_INSTALL_PREFIX`]: https://cmake.org/cmake/help/v3.14/variable/CMAKE_INSTALL_PREFIX.html ## License Licensed under the [ISC License][] unless otherwise noted, see the [`LICENSE`][] file. [ISC License]: https://choosealicense.com/licenses/isc [`LICENSE`]: LICENSE