1*5b190011SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*5b190011SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*5b190011SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*5b190011SAndrew Rist * distributed with this work for additional information 6*5b190011SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*5b190011SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*5b190011SAndrew Rist * "License"); you may not use this file except in compliance 9*5b190011SAndrew Rist * with the License. You may obtain a copy of the License at 10*5b190011SAndrew Rist * 11*5b190011SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*5b190011SAndrew Rist * 13*5b190011SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*5b190011SAndrew Rist * software distributed under the License is distributed on an 15*5b190011SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*5b190011SAndrew Rist * KIND, either express or implied. See the License for the 17*5b190011SAndrew Rist * specific language governing permissions and limitations 18*5b190011SAndrew Rist * under the License. 19*5b190011SAndrew Rist * 20*5b190011SAndrew Rist *************************************************************/ 21*5b190011SAndrew Rist 22*5b190011SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir #include "precompiled_sd.hxx" 25cdf0e10cSrcweir 26cdf0e10cSrcweir #include "ConfigurationTracer.hxx" 27cdf0e10cSrcweir 28cdf0e10cSrcweir #include <cstdio> 29cdf0e10cSrcweir 30cdf0e10cSrcweir using namespace ::com::sun::star::uno; 31cdf0e10cSrcweir using namespace ::com::sun::star::drawing::framework; 32cdf0e10cSrcweir 33cdf0e10cSrcweir namespace sd { namespace framework { 34cdf0e10cSrcweir 35cdf0e10cSrcweir void ConfigurationTracer::TraceConfiguration ( 36cdf0e10cSrcweir const Reference<XConfiguration>& rxConfiguration, 37cdf0e10cSrcweir const char* pMessage) 38cdf0e10cSrcweir { 39cdf0e10cSrcweir #ifdef DEBUG 40cdf0e10cSrcweir OSL_TRACE("%s at %p {", pMessage, rxConfiguration.get()); 41cdf0e10cSrcweir if (rxConfiguration.is()) 42cdf0e10cSrcweir { 43cdf0e10cSrcweir TraceBoundResources(rxConfiguration, NULL, 0); 44cdf0e10cSrcweir } 45cdf0e10cSrcweir else 46cdf0e10cSrcweir { 47cdf0e10cSrcweir OSL_TRACE(" empty"); 48cdf0e10cSrcweir } 49cdf0e10cSrcweir OSL_TRACE("}"); 50cdf0e10cSrcweir #else 51cdf0e10cSrcweir (void)rxConfiguration; 52cdf0e10cSrcweir (void)pMessage; 53cdf0e10cSrcweir #endif 54cdf0e10cSrcweir } 55cdf0e10cSrcweir 56cdf0e10cSrcweir 57cdf0e10cSrcweir 58cdf0e10cSrcweir 59cdf0e10cSrcweir #ifdef DEBUG 60cdf0e10cSrcweir void ConfigurationTracer::TraceBoundResources ( 61cdf0e10cSrcweir const Reference<XConfiguration>& rxConfiguration, 62cdf0e10cSrcweir const Reference<XResourceId>& rxResourceId, 63cdf0e10cSrcweir const int nIndentation) 64cdf0e10cSrcweir { 65cdf0e10cSrcweir Sequence<Reference<XResourceId> > aResourceList ( 66cdf0e10cSrcweir rxConfiguration->getResources(rxResourceId, ::rtl::OUString(), AnchorBindingMode_DIRECT)); 67cdf0e10cSrcweir const ::rtl::OUString sIndentation (::rtl::OUString::createFromAscii(" ")); 68cdf0e10cSrcweir for (sal_Int32 nIndex=0; nIndex<aResourceList.getLength(); ++nIndex) 69cdf0e10cSrcweir { 70cdf0e10cSrcweir ::rtl::OUString sLine (aResourceList[nIndex]->getResourceURL()); 71cdf0e10cSrcweir for (int i=0; i<nIndentation; ++i) 72cdf0e10cSrcweir sLine = sIndentation + sLine; 73cdf0e10cSrcweir OSL_TRACE("%s", OUStringToOString(sLine, RTL_TEXTENCODING_UTF8).getStr()); 74cdf0e10cSrcweir TraceBoundResources(rxConfiguration, aResourceList[nIndex], nIndentation+1); 75cdf0e10cSrcweir } 76cdf0e10cSrcweir } 77cdf0e10cSrcweir #endif 78cdf0e10cSrcweir 79cdf0e10cSrcweir } } // end of namespace sd::framework 80