1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  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,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 #ifndef _CFSTRINGUTILITIES_HXX_
25 #define _CFSTRINGUTILITIES_HXX_
26 
27 #include <premac.h>
28 #include <Carbon/Carbon.h>
29 #include <Cocoa/Cocoa.h>
30 #include <postmac.h>
31 #include <rtl/ustring.hxx>
32 #include <sal/types.h>
33 #include <osl/diagnose.h>
34 
35 enum InfoType {
36     FULLPATH,
37     FILENAME,
38     PATHWITHOUTLASTCOMPONENT
39 };
40 
41 rtl::OUString CFStringToOUString(const CFStringRef sOrig);
42 rtl::OUString FSRefToOUString(FSRef fsRef, InfoType info = FULLPATH);
43 rtl::OUString CFURLRefToOUString(CFURLRef aUrlRef, InfoType info);
44 CFStringRef CFStringCreateWithOUString(const rtl::OUString& aString);
45 
46 //debug utils
47 #define PARAMFILLER "\n                    "
48 
DBG_PRINT_ENTRY()49 inline void DBG_PRINT_ENTRY() {
50     OSL_TRACE(">>> %s", __func__);
51 }
52 
DBG_PRINT_ENTRY(const char * classname,const char * methodname)53 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname) {
54     OSL_TRACE(">>> %s::%s", classname, methodname);
55 }
56 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const char * value1)57 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const char* value1) {
58     OSL_TRACE(">>> %s::%s%s%s = %s", classname, methodname, PARAMFILLER, param1, value1);
59 }
60 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const rtl::OUString & value1)61 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const rtl::OUString& value1) {
62     OSL_TRACE(">>> %s::%s%s%s = %s", classname, methodname, PARAMFILLER, param1, OUStringToOString(value1, RTL_TEXTENCODING_UTF8).getStr());
63 }
64 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const CFStringRef value1)65 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const CFStringRef value1) {
66     OSL_TRACE(">>> %s::%s%s%s =", classname, methodname, PARAMFILLER, param1);
67 #if OSL_DEBUG_LEVEL > 1
68     CFShow(value1);
69 #endif
70 }
71 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const NSString * value1)72 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const NSString* value1) {
73     OSL_TRACE(">>> %s::%s%s%s =", classname, methodname, PARAMFILLER, param1);
74 #if OSL_DEBUG_LEVEL > 1
75     NSLog( const_cast<NSString*>(value1));
76 #endif
77 }
78 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const int value1)79 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const int value1) {
80     OSL_TRACE(">>> %s::%s%s%s = %d", classname, methodname, PARAMFILLER, param1, value1);
81 }
82 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const char * value1,const char * param2,const int value2)83 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const char* value1, const char* param2, const int value2) {
84     OSL_TRACE(">>> %s::%s%s%s = %s%s%s = %d", classname, methodname, PARAMFILLER, param1, value1, PARAMFILLER, param2, value2);
85 }
86 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const char * value1,const char * param2,const char * value2)87 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const char* value1, const char* param2, const char* value2) {
88     OSL_TRACE(">>> %s::%s%s%s = %s%s%s = %s", classname, methodname, PARAMFILLER, param1, value1, PARAMFILLER, param2, value2);
89 }
90 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const int value1,const char * param2,const int value2)91 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const int value1, const char* param2, const int value2) {
92     OSL_TRACE(">>> %s::%s%s%s = %d%s%s = %d", classname, methodname, PARAMFILLER, param1, value1, PARAMFILLER, param2, value2);
93 }
94 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const int value1,const char * param2,const char * value2)95 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const int value1, const char* param2, const char* value2) {
96     OSL_TRACE(">>> %s::%s%s%s = %d%s%s = %s", classname, methodname, PARAMFILLER, param1, value1, PARAMFILLER, param2, value2);
97 }
98 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const int value1,const char * param2,const CFStringRef value2)99 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const int value1, const char* param2, const CFStringRef value2) {
100     OSL_TRACE(">>> %s::%s%s%s = %d%s%s =", classname, methodname, PARAMFILLER, param1, value1, PARAMFILLER, param2, value2);
101 #if OSL_DEBUG_LEVEL > 1
102     CFShow(value2);
103 #endif
104 }
105 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const int value1,const char * param2,const NSString * value2)106 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const int value1, const char* param2, const NSString* value2) {
107     OSL_TRACE(">>> %s::%s%s%s = %d%s%s =", classname, methodname, PARAMFILLER, param1, value1, PARAMFILLER, param2, value2);
108 #if OSL_DEBUG_LEVEL > 1
109     NSLog( const_cast<NSString*>(value2));
110 #endif
111 }
112 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const rtl::OUString & value1,const char * param2,const rtl::OUString & value2)113 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const rtl::OUString& value1, const char* param2, const rtl::OUString& value2) {
114     OSL_TRACE(">>> %s::%s%s%s = %s%s%s = %s", classname, methodname, PARAMFILLER, param1, OUStringToOString(value1, RTL_TEXTENCODING_UTF8).getStr(), PARAMFILLER, param2, OUStringToOString(value2, RTL_TEXTENCODING_UTF8).getStr());
115 }
116 
DBG_PRINT_ENTRY(const char * classname,const char * methodname,const char * param1,const rtl::OUString & value1,const char * param2,const int value2)117 inline void DBG_PRINT_ENTRY(const char * classname, const char * methodname, const char* param1, const rtl::OUString& value1, const char* param2, const int value2) {
118     OSL_TRACE(">>> %s::%s%s%s = %s%s%s = %d", classname, methodname, PARAMFILLER, param1, OUStringToOString(value1, RTL_TEXTENCODING_UTF8).getStr(), PARAMFILLER, param2, value2);
119 }
120 
121 //exit method debugs
122 
DBG_PRINT_EXIT()123 inline void DBG_PRINT_EXIT() {
124     OSL_TRACE("<<< %s", __func__);
125 }
126 
DBG_PRINT_EXIT(const char * classname,const char * methodname)127 inline void DBG_PRINT_EXIT(const char * classname, const char * methodname) {
128     OSL_TRACE("<<< %s::%s", classname, methodname);
129 }
130 
DBG_PRINT_EXIT(const char * classname,const char * methodname,const char * retVal)131 inline void DBG_PRINT_EXIT(const char * classname, const char * methodname, const char* retVal) {
132     OSL_TRACE("<<< %s::%s%sreturnValue = %s", classname, methodname, PARAMFILLER, retVal);
133 }
134 
DBG_PRINT_EXIT(const char * classname,const char * methodname,int retVal)135 inline void DBG_PRINT_EXIT(const char * classname, const char * methodname, int retVal) {
136     OSL_TRACE("<<< %s::%s%sreturnValue = %d", classname, methodname, PARAMFILLER, retVal);
137 }
138 
DBG_PRINT_EXIT(const char * classname,const char * methodname,const CFStringRef retVal)139 inline void DBG_PRINT_EXIT(const char * classname, const char * methodname, const CFStringRef retVal) {
140     OSL_TRACE("<<< %s::%s%sreturnValue = ", classname, methodname, PARAMFILLER);
141 #if OSL_DEBUG_LEVEL > 1
142     CFShow(retVal);
143 #endif
144 }
145 
DBG_PRINT_EXIT(const char * classname,const char * methodname,const NSString * retVal)146 inline void DBG_PRINT_EXIT(const char * classname, const char * methodname, const NSString* retVal) {
147     OSL_TRACE("<<< %s::%s%sreturnValue = ", classname, methodname, PARAMFILLER);
148 #if OSL_DEBUG_LEVEL > 1
149     NSLog( const_cast<NSString*>(retVal));
150 #endif
151 }
152 
DBG_PRINT_EXIT(const char * classname,const char * methodname,const rtl::OUString & retVal)153 inline void DBG_PRINT_EXIT(const char * classname, const char * methodname, const rtl::OUString& retVal) {
154     OSL_TRACE("<<< %s::%s%sreturnValue = %s", classname, methodname, PARAMFILLER, OUStringToOString(retVal, RTL_TEXTENCODING_UTF8).getStr());
155 }
156 
157 #endif //_CFSTRINGUTILITIES_HXX_
158