/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ package util; import com.sun.star.uno.XInterface; import com.sun.star.uno.UnoRuntime; import com.sun.star.uno.Type; import com.sun.star.beans.XPropertySet; import com.sun.star.beans.XPropertySetInfo; import com.sun.star.beans.Property; import com.sun.star.beans.PropertyAttribute; import com.sun.star.beans.PropertyValue; import com.sun.star.lang.XTypeProvider; import com.sun.star.lang.XServiceInfo; import java.io.PrintWriter; import java.lang.reflect.Method; /** * This class accumulates all kinds of methods for accessing debug information * from UNO implementations. */ public class dbg { /** * Prints information about the supported interfaces of an implementation * to standard out. * @param xTarget The implementation which should be analysed. * @see com.sun.star.uno.XInterface */ public static void printInterfaces(XInterface xTarget) { printInterfaces(xTarget, false); } /** * Prints information about the supported interfaces of an implementation * to standard out. Extended information can be printed. * @param xTarget The implementation which should be analysed. * @param extendedInfo Should extended information be printed? * @see com.sun.star.uno.XInterface */ public static void printInterfaces(XInterface xTarget, boolean extendedInfo){ Type[] types = getInterfaceTypes(xTarget); if( null != types ) { int nLen = types.length; for( int i = 0; i < nLen ; i++ ) { System.out.println(types[i].getTypeName()); if (extendedInfo) { printInterfaceInfo(types[i]); System.out.println(); } } } } /** * Returns all interface types of an implementation as a type array. * @param xTarget The implementation which should be analyzed. * @return An array with all interface types; null if there are none. * @see com.sun.star.uno.XInterface */ public static Type[] getInterfaceTypes(XInterface xTarget) { Type[] types = null; XTypeProvider xTypeProvider = (XTypeProvider) UnoRuntime.queryInterface( XTypeProvider.class, xTarget); if( xTypeProvider != null ) types = xTypeProvider.getTypes(); return types; } /** * Returns true if a specified target implements the interface with the * given name. Note that the comparison is not case sensitive. * @param xTarget The implementation which should be analysed. * @param ifcName The name of the interface that is tested. The name can * be full qualified, such as 'com.sun.star.io.XInputStream', or only * consist of the interface name, such as 'XText'. * @return True, if xTarget implements the interface named ifcType * @see com.sun.star.uno.XInterface */ public static boolean implementsInterface( XInterface xTarget, String ifcName) { Type[] types = getInterfaceTypes(xTarget); if( null != types ) { int nLen = types.length; for( int i = 0; i < nLen ; i++ ) { if(types[i].getTypeName().toLowerCase().endsWith( ifcName.toLowerCase())) return true; } } return false; } /** * Prints information about an interface type. * * @param aType The type of the given interface. * @see com.sun.star.uno.Type */ public static void printInterfaceInfo(Type aType) { try { Class zClass = aType.getZClass(); Method[] methods = zClass.getDeclaredMethods(); for (int i=0; iname from * the property set PS to standard out. * @param PS The property set which should contain a property called * name. * @param name The name of the property. * @see com.sun.star.beans.XPropertySet */ public static void printPropertyInfo(XPropertySet PS, String name) { printPropertyInfo(PS, name, new PrintWriter(System.out)) ; } /** * Print all information about the property name from * the property set PS to a print writer. * @param PS The property set which should contain a property called * name. * @param name The name of the property. * @param out The print writer which is used as output. * @see com.sun.star.beans.XPropertySet */ public static void printPropertyInfo(XPropertySet PS, String name, PrintWriter out) { try { XPropertySetInfo PSI = PS.getPropertySetInfo(); Property[] props = PSI.getProperties(); Property prop = PSI.getPropertyByName(name); out.println("Property name is " + prop.Name); out.println("Property handle is " + prop.Handle); out.println("Property type is " + prop.Type.getTypeName()); out.println("Property current value is " + PS.getPropertyValue(name)); out.println("Attributes :"); short attr = prop.Attributes; if ((attr & PropertyAttribute.BOUND) != 0) out.println("\t-BOUND"); if ((attr & PropertyAttribute.CONSTRAINED) != 0) out.println("\t-CONSTRAINED"); if ((attr & PropertyAttribute.MAYBEAMBIGUOUS) != 0) out.println("\t-MAYBEAMBIGUOUS"); if ((attr & PropertyAttribute.MAYBEDEFAULT) != 0) out.println("\t-MAYBEDEFAULT"); if ((attr & PropertyAttribute.MAYBEVOID) != 0) out.println("\t-MAYBEVOID"); if ((attr & PropertyAttribute.READONLY) != 0) out.println("\t-READONLY"); if ((attr & PropertyAttribute.REMOVEABLE) != 0) out.println("\t-REMOVEABLE"); if ((attr & PropertyAttribute.TRANSIENT) != 0) out.println("\t-TRANSIENT"); } catch(com.sun.star.uno.Exception e) { out.println("Exception!!!!"); e.printStackTrace(out); } } /** * Print the names and the values of a sequnze of PropertyValue * to to standard out. * @param ps The property which should displayed * @see com.sun.star.beans.PropertyValue */ public static void printProperyValueSequenzePairs(PropertyValue[] ps){ for( int i = 0; i < ps.length; i++){ printProperyValuePairs(ps[i], new PrintWriter(System.out)); } } /** * Print the names and the values of a sequenze of PropertyValue * to a print writer. * @param ps The property which should displayed * @param out The print writer which is used as output. * @see com.sun.star.beans.PropertyValue */ public static void printProperyValueSequenzePairs(PropertyValue[] ps, PrintWriter out){ for( int i = 0; i < ps.length; i++){ printProperyValuePairs(ps[i], out); } } /** * Print the name and the value of a PropertyValue to to standard out. * @param ps The property which should displayed * @see com.sun.star.beans.PropertyValue */ public static void printProperyValuePairs(PropertyValue ps){ printProperyValuePairs(ps, new PrintWriter(System.out)); } /** * Print the name and the value of a PropertyValue to a print writer. * @param ps The property which should displayed * @param out The print writer which is used as output. * @see com.sun.star.beans.PropertyValue */ public static void printProperyValuePairs(PropertyValue ps, PrintWriter out){ if (ps.Value instanceof String[] ){ String[] values = (String[]) ps.Value; String oneValue = "value is an empty String[]"; if (values.length > 0){ oneValue = "['"; for( int i=0; i < values.length; i++){ oneValue += values[i]; if (i+1 < values.length) oneValue += "';'"; } oneValue += "']"; } out.println("--------"); out.println(" Name: '" + ps.Name + "' contains String[]:"); out.println(oneValue); out.println("--------"); } else if (ps.Value instanceof PropertyValue){ out.println("--------"); out.println(" Name: '" + ps.Name + "' contains PropertyValue:"); printProperyValuePairs((PropertyValue)ps.Value, out); out.println("--------"); } else if (ps.Value instanceof PropertyValue[]){ out.println("--------"); out.println(" Name: '" + ps.Name + "' contains PropertyValue[]:"); printProperyValueSequenzePairs((PropertyValue[])ps.Value, out); out.println("--------"); } else { out.println("Name: '" + ps.Name + "' Value: '" + ps.Value.toString() + "'"); } } /** * Print the names of all properties inside this property set * @param ps The property set which is printed. * @see com.sun.star.beans.XPropertySet */ public static void printPropertiesNames(XPropertySet ps) { XPropertySetInfo psi = ps.getPropertySetInfo(); Property[] props = psi.getProperties(); for (int i = 0; i < props.length; i++) System.out.println(i + ". " + props[i].Name); } /** * Print the supported services of a UNO object. * @param aObject A UNO object. */ public static void getSuppServices (Object aObject) { XServiceInfo xSI = (XServiceInfo) UnoRuntime.queryInterface(XServiceInfo.class,aObject); printArray(xSI.getSupportedServiceNames()); String str="Therein not Supported Service"; boolean notSupportedServices = false; for (int i=0;i