HPCToolkit
simple_oo.h
Go to the documentation of this file.
1 // -*-Mode: C++;-*- // technically C99
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 #ifndef SIMPLE_OO_H
48 #define SIMPLE_OO_H
49 
50 // very simple OO for c (mainly to get OO method interface)
51 //
52 // no class structure (so no inheiritance or other sophisticated OO techniques)
53 // object = (pointer to a) struct with components that are function pointers
54 // initializing the object SYSTEM requires setting the method fields to
55 // appropriate functions (ideally these are static functions, but common
56 // functions might be global)
57 //
58 // methods are C functions that take self (a pointer to the object) as
59 // it's first argument.
60 //
61 // Since it is impossible to define macros that define other macros,
62 // each .h file that defines a specific object type will need to
63 // define METHOD_DEF and METHOD_FN macros like the example below
64 // The METHOD_CALL macro, however, is general for all objects that
65 // follow this simple protocol.
66 //
67 // #define METHOD_DEF(retn,name,args...) retn (*name)(struct _obj_s *self,args)
68 //
69 // // abbreviation macro for common case of void methods
70 // #define VMETHOD_DEF(name,args...) METHOD_DEF(void,name,args)
71 
72 // #define METHOD_FN(name,...) name(obj1 *self, ##__VA_ARGS__)
73 
74 //
75 // objects follow the prototype below:
76 //
77 // typedef struct _obj_s {
78 //
79 // METHOD_DEF(void,m1,void); // defines method m1(void)
80 // METHOD_DEF(void,m2,int d); // defines method m2(int d)
81 //
82 // int data[10];
83 // } obj1;
84 
85 // NOTEME: gcc specific use of ##__VA_ARGS__ (necessary for methods w no aux args)
86 
87 #define METHOD_CALL(obj,meth,...) (obj)->meth((obj), ##__VA_ARGS__)
88 
89 #endif // SIMPLE_OO_H