3e63ac83dcee2efb523cbb52ee77fb3d052bcb4d
[platform/core/uifw/dali-core.git] / dali / internal / event / common / demangler.h
1 #ifndef DALI_DEMANGLER_H
2 #define DALI_DEMANGLER_H
3
4 /*
5  * Copyright (c) 2019 Samsung Electronics Co., Ltd.
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  */
20
21 // EXTERNAL INCLUDES
22 #include <string>
23
24 // INTERNAL INCLUDES
25 #include <dali/public-api/common/vector-wrapper.h>
26
27 namespace Dali
28 {
29
30 namespace Internal
31 {
32
33 /**
34  * Demangle a nested typeid name into its component parts.
35  * A nested type name is one containing namespaces and class names only.
36  *   eg DemangleNestedNames(typeid(Dali::Actor).name());
37  * @param[in] typeIdName The type id name string to demangle.
38  * @returns the demangled list of names ie ["Dali","Actor"] or an empty list
39  */
40 std::vector<std::string> DemangleNestedNames(const char *typeIdName);
41
42 /**
43  * Demangle a nested typeid name to its class name.
44  * @param[in] typeIdName The type id name string to demangle.
45  * @returns the class name ie "Actor" or an empty string
46  */
47 const std::string DemangleClassName(const char *typeIdName);
48
49 } // namespace Internal
50
51 } // namespace Dali
52
53 #endif // DALI_DEMANGLER_H