From 7b88122ce7a1855f5c640d8235cfe18ab3355c01 Mon Sep 17 00:00:00 2001 From: Oliver Ruebel Date: Sun, 22 Dec 2024 02:20:23 -0800 Subject: [PATCH] Add note to docs to clarify non-virtual DEFINE_FIELD --- docs/pages/devdocs/registered_types.dox | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/docs/pages/devdocs/registered_types.dox b/docs/pages/devdocs/registered_types.dox index 7c376ac8..6d4d8ae1 100644 --- a/docs/pages/devdocs/registered_types.dox +++ b/docs/pages/devdocs/registered_types.dox @@ -79,6 +79,13 @@ * typename value and the `ElectrodesTable.getTypeName` automatic override returning * the indicated typename instead of the classname. * + * \note + * ``DEFINE_FIELD`` creates templated, non-virtual read functions. This means if we + * want to "redefine" a field in a child class by calling ``DEFINE_FIELD`` again, then + * the function will be "hidden" instead of "override". This is important to remember + * when casting a pointer to a base type, as in this case the implementation from the + * base type will be used since the function created by ``DEFINE_FIELD`` is not virtual. + * * * @subsection implement_registered_type_example Example: Implementing a new type *