|typedef struct derived1_private_st_||derived1_private_st|
|my_rc_e||derived1_increase_val4 (derived1_handle derived1_h)|
|void||derived1_friend_delete (derived1_handle derived1_h)|
|void||derived1_delete (derived1_handle derived1_h)|
|base1_handle||derived1_cast_to_base1 (derived1_handle derived1_h)|
|base2_handle||derived1_cast_to_base2 (derived1_handle derived1_h)|
|my_rc_e||derived1_inherit_vtable (const derived1_vtable_st *parent_vtable, derived1_vtable_st *child_vtable, bool do_null_check)|
|my_rc_e||derived1_set_vtable (derived1_handle derived1_h, derived1_vtable_st *vtable)|
|my_rc_e||derived1_init (derived1_handle derived1_h)|
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>.
This is the implements a class that inherits from base1 and base2.
Definition in file derived1.c.
|#define DERIVED1_STR_SIZE 256|
Private variables which cannot be directly accessed by any other class including children.
Allow a friend class to delete the derived1 object. It is assumed that the friend class is managing the memory for the derived1 object and, thus, the object will not be freed. However, members within the derived1 object may be freed. This does not call the virtual function table version of delete, but rather the delete specifically for type derived1.
|derived1_h||The object. If NULL, then this function is a no-op.|
|my_rc_e derived1_inherit_vtable||(||const derived1_vtable_st *||parent_vtable,|
Fill in the child vtable with values inherited from the parent_vtable for all functions left NULL in the child vtable.
|parent_vtable||The parent vtable from which to inherit.|
|child_vtable||The child vtable to which functions may be inherited.|
|do_null_check||Indicates whether an error should be thrown if a function in the child vtable is NULL after inheritance.|
Allows a friend class to initialize their inner derived1 object. Must be called before the derived1 object is used. If an error is returned, any clean-up was handled internally and there is no need to call a delete function.
This is a function used by friend classes to set the virtual table according to which methods they wish to override.
|vtable||The virtual table specification for the friend class. If a function pointer is NULL, then the base1 function is inherited.|