method.h
Go to the documentation of this file.
1/************************************************************************************
2* *
3* Copyright (c) 2014 - 2018 Axel Menzel <info@rttr.org> *
4* *
5* This file is part of RTTR (Run Time Type Reflection) *
6* License: MIT License *
7* *
8* Permission is hereby granted, free of charge, to any person obtaining *
9* a copy of this software and associated documentation files (the "Software"), *
10* to deal in the Software without restriction, including without limitation *
11* the rights to use, copy, modify, merge, publish, distribute, sublicense, *
12* and/or sell copies of the Software, and to permit persons to whom the *
13* Software is furnished to do so, subject to the following conditions: *
14* *
15* The above copyright notice and this permission notice shall be included in *
16* all copies or substantial portions of the Software. *
17* *
18* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
19* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
20* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
21* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
22* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, *
23* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE *
24* SOFTWARE. *
25* *
26*************************************************************************************/
27
28#ifndef RTTR_METHOD_H_
29#define RTTR_METHOD_H_
30
31#include "rttr/detail/base/core_prerequisites.h"
32#include "rttr/detail/misc/class_item_mapper.h"
33#include "rttr/parameter_info.h"
34#include "rttr/access_levels.h"
35#include "rttr/array_range.h"
36#include "rttr/string_view.h"
37
38#include <string>
39#include <vector>
40
41namespace rttr
42{
43
44class variant;
45class type;
46class instance;
47class argument;
48class method;
49
50namespace detail
51{
52 class method_wrapper_base;
53}
54
121{
122 public:
129
136
143
153
162 bool is_static() const RTTR_NOEXCEPT;
163
169 type get_return_type() const RTTR_NOEXCEPT;
170
179 type get_declaring_type() const RTTR_NOEXCEPT;
180
187
194
203 variant get_metadata(const variant& key) const;
204
214 variant invoke(instance object) const;
215
230
245
260
275
291
307
323 variant invoke_variadic(instance object, std::vector<argument> args) const;
324
331
338
339 private:
341
343 friend T detail::create_item(const detail::class_item_to_wrapper_t<T>* wrapper);
345 friend T detail::create_invalid_item();
346
347 private:
348 const detail::method_wrapper_base* m_wrapper;
349};
350
351} // end namespace rttr
352
353#endif // RTTR_METHOD_H_
The argument class is used for forwarding arguments to properties or methods.
Definition argument.h:52
The array_range class provides a view into an underlying data structure with lower and upper limits.
Definition array_range.h:64
The instance class is used for forwarding the instance of an object to invoke a property or method.
Definition instance.h:48
The method class provides several meta information about a method and can be invoked.
Definition method.h:121
bool is_valid() const noexcept
Returns true if this method is valid, otherwise false.
The parameter_info class provides several meta information about a parameter.
Definition parameter_info.h:109
The type class holds the type information for any arbitrary object.
Definition type.h:171
The variant class allows to store data of any type and convert between these types transparently.
Definition variant.h:198
Definition access_levels.h:34
access_levels
The access_levels enum represents the three access modifiers, which can be used in classes to encapsu...
Definition access_levels.h:46