diff options
3 files changed, 511 insertions, 43 deletions
diff --git a/ridljar/com/sun/star/lib/uno/typedesc/TypeDescription.java b/ridljar/com/sun/star/lib/uno/typedesc/TypeDescription.java index 9d9b68a3b28e..6e5645178ac2 100644 --- a/ridljar/com/sun/star/lib/uno/typedesc/TypeDescription.java +++ b/ridljar/com/sun/star/lib/uno/typedesc/TypeDescription.java @@ -2,9 +2,9 @@ * * $RCSfile: TypeDescription.java,v $ * - * $Revision: 1.11 $ + * $Revision: 1.12 $ * - * last change: $Author: kr $ $Date: 2001-06-25 13:35:43 $ + * last change: $Author: kr $ $Date: 2001-09-11 15:57:18 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -97,7 +97,7 @@ import com.sun.star.lib.uno.typeinfo.TypeInfo; * methods, which may be changed or moved in the furture, so please * do not use these methods. * <p> - * @version $Revision: 1.11 $ $ $Date: 2001-06-25 13:35:43 $ + * @version $Revision: 1.12 $ $ $Date: 2001-09-11 15:57:18 $ * @author Kay Ramme * @since UDK2.0 */ @@ -207,10 +207,10 @@ public class TypeDescription implements ITypeDescription { } } catch(NoSuchFieldException noSuchFieldException) { - if(DEBUG) System.err.println("__getTypeInfos:" + zInterface + " - exception:" + noSuchFieldException); + if(DEBUG) System.err.println("__getTypeInfos:" + zInterface + " - exception:" + noSuchFieldException); } catch(ClassNotFoundException classNotFoundException) { - if(DEBUG) System.err.println("__getTypeInfos:" + zInterface + " - exception:" + classNotFoundException); + if(DEBUG) System.err.println("__getTypeInfos:" + zInterface + " - exception:" + classNotFoundException); } catch(IllegalAccessException illegalAccessException) { System.err.println("__getTypeInfos:" + zInterface + " - exception:" + illegalAccessException); @@ -569,11 +569,11 @@ public class TypeDescription implements ITypeDescription { protected TypeDescription _superType; // if this is a struct or an interface - protected int _offset; - protected MethodDescription _methodDescriptionsByIndex[]; - protected Hashtable _methodDescriptionsByName; - protected Hashtable _iFieldDescriptionsByName; + protected int _offset; + protected MethodDescription _methodDescriptions[]; + protected Hashtable _methodDescriptionsByName; + protected Hashtable _iFieldDescriptionsByName; protected IFieldDescription _iFieldDescriptions[]; protected ITypeDescription _componentType; @@ -621,8 +621,6 @@ public class TypeDescription implements ITypeDescription { Class interfaces[] = _class.getInterfaces(); if(interfaces.length > 0) _superType = getTypeDescription(interfaces[0]); // uno only supports single inheritance - - _initMethodTypeInfos(); } else if(zClass.isArray()) { _typeClass = TypeClass.SEQUENCE; @@ -641,8 +639,6 @@ public class TypeDescription implements ITypeDescription { Class superClass = _class.getSuperclass(); if(superClass != null && superClass != Object.class) _superType = getTypeDescription(superClass); - - _initMemberTypeInfos(); } else { _typeClass = TypeClass.STRUCT; @@ -653,8 +649,6 @@ public class TypeDescription implements ITypeDescription { Class superClass = _class.getSuperclass(); if(superClass != null && superClass != Object.class) _superType = getTypeDescription(superClass); - - _initMemberTypeInfos(); } __cyclicTypes.remove(zClass.getName()); @@ -692,10 +686,9 @@ public class TypeDescription implements ITypeDescription { } private void _initMethodTypeInfos() { - if(_methodDescriptionsByName != null) - return; + if(DEBUG) System.err.println("TypeDescription._initMethodTypeInfos"); - _methodDescriptionsByName = new Hashtable(); + Hashtable methodDescriptionsByName = new Hashtable(); int superOffset = 0; @@ -710,9 +703,9 @@ public class TypeDescription implements ITypeDescription { MethodDescription release = new MethodDescription("release", 2, TypeInfo.ONEWAY); release.init(new Class[0], null, Void.class); - _methodDescriptionsByName.put("queryInterface", queryInterface); - _methodDescriptionsByName.put("acquire", acquire); - _methodDescriptionsByName.put("release", release); + methodDescriptionsByName.put("queryInterface", queryInterface); + methodDescriptionsByName.put("acquire", acquire); + methodDescriptionsByName.put("release", release); _offset = 3; } @@ -753,30 +746,36 @@ public class TypeDescription implements ITypeDescription { if(methodDescription != null) { methodDescription.init(methods[i], parameterTypeInfos, superOffset); - _methodDescriptionsByName.put(methodDescription.getName(), methodDescription); + methodDescriptionsByName.put(methodDescription.getName(), methodDescription); } } } - _methodDescriptionsByIndex = new MethodDescription[_methodDescriptionsByName.size()]; - Enumeration element = _methodDescriptionsByName.elements(); + MethodDescription methodDescriptions[] = new MethodDescription[methodDescriptionsByName.size()]; + Enumeration element = methodDescriptionsByName.elements(); while(element.hasMoreElements()) { MethodDescription methodDescription = (MethodDescription)element.nextElement(); - _methodDescriptionsByIndex[methodDescription.getIndex() - superOffset] = methodDescription; + methodDescriptions[methodDescription.getIndex() - superOffset] = methodDescription; } - _offset = superOffset + _methodDescriptionsByIndex.length; + _offset = superOffset + methodDescriptions.length; + + // transactional assignment + _methodDescriptions = methodDescriptions; + _methodDescriptionsByName = methodDescriptionsByName; } private void _initMemberTypeInfos() { + if(DEBUG) System.err.println("TypeDescription._initMemberTypeInfos"); + TypeInfo typeInfos[] = __getTypeInfos(_class); Field fields[] = _class.getFields(); int index = 0; - IFieldDescription iFieldDescriptions[] = new IFieldDescription[fields.length]; + IFieldDescription tmp_iFieldDescriptions[] = new IFieldDescription[fields.length]; - _iFieldDescriptionsByName = new Hashtable(); + Hashtable iFieldDescriptionsByName = new Hashtable(); for(int i = 0; i < fields.length; ++ i) { @@ -797,13 +796,17 @@ public class TypeDescription implements ITypeDescription { iFieldDescription = new FieldDescription(memberTypeInfo, fields[i]); } - _iFieldDescriptionsByName.put(iFieldDescription.getName(), iFieldDescription); - iFieldDescriptions[index ++] = iFieldDescription; + iFieldDescriptionsByName.put(iFieldDescription.getName(), iFieldDescription); + tmp_iFieldDescriptions[index ++] = iFieldDescription; } } - _iFieldDescriptions = new IFieldDescription[index]; - System.arraycopy(iFieldDescriptions, 0, _iFieldDescriptions, 0, index); + IFieldDescription iFieldDescriptions[] = new IFieldDescription[index]; + System.arraycopy(tmp_iFieldDescriptions, 0, iFieldDescriptions, 0, index); + + // transactional assignment + _iFieldDescriptions = iFieldDescriptions; + _iFieldDescriptionsByName = iFieldDescriptionsByName; } public ITypeDescription getSuperType() { @@ -811,24 +814,22 @@ public class TypeDescription implements ITypeDescription { } public IMethodDescription []getMethodDescriptions() { - IMethodDescription iMethodDescriptions[] = null; - - if(_methodDescriptionsByIndex != null) { - iMethodDescriptions = new IMethodDescription[_methodDescriptionsByIndex.length]; - - System.arraycopy(_methodDescriptionsByIndex, 0, iMethodDescriptions, 0, _methodDescriptionsByIndex.length); - } + if(_methodDescriptions == null) + _initMethodTypeInfos(); - return iMethodDescriptions; + return _methodDescriptions; } public IMethodDescription getMethodDescription(int methodId) { + if(_methodDescriptionsByName == null) + _initMethodTypeInfos(); + IMethodDescription iMethodDescription = null; - int relMethodId = methodId - (_offset - _methodDescriptionsByIndex.length); + int relMethodId = methodId - (_offset - _methodDescriptions.length); - if(relMethodId >= 0 && relMethodId < _methodDescriptionsByIndex.length) - iMethodDescription = _methodDescriptionsByIndex[relMethodId]; + if(relMethodId >= 0 && relMethodId < _methodDescriptions.length) + iMethodDescription = _methodDescriptions[relMethodId]; else if(_superType != null) iMethodDescription = _superType.getMethodDescription(methodId); @@ -837,6 +838,9 @@ public class TypeDescription implements ITypeDescription { } public IMethodDescription getMethodDescription(String name) { + if(_methodDescriptionsByName == null) + _initMethodTypeInfos(); + IMethodDescription iMethodDescription = (MethodDescription)_methodDescriptionsByName.get(name); if(iMethodDescription == null && _superType != null) iMethodDescription = _superType.getMethodDescription(name); @@ -845,10 +849,16 @@ public class TypeDescription implements ITypeDescription { } public IFieldDescription []getFieldDescriptions() { + if(_iFieldDescriptions == null) + _initMemberTypeInfos(); + return _iFieldDescriptions; } public IFieldDescription getFieldDescription(String name) { + if(_iFieldDescriptions == null) + _initMemberTypeInfos(); + IFieldDescription iFieldDescription = (IFieldDescription)_iFieldDescriptionsByName.get(name); if(iFieldDescription == null && _superType != null) iFieldDescription = _superType.getFieldDescription(name); diff --git a/ridljar/test/com/sun/star/lib/uno/typedesc/TypeDescription_Test.java b/ridljar/test/com/sun/star/lib/uno/typedesc/TypeDescription_Test.java new file mode 100644 index 000000000000..354bc4b8b57a --- /dev/null +++ b/ridljar/test/com/sun/star/lib/uno/typedesc/TypeDescription_Test.java @@ -0,0 +1,371 @@ +/************************************************************************* + * + * $RCSfile: TypeDescription_Test.java,v $ + * + * $Revision: 1.1 $ + * + * last change: $Author: kr $ $Date: 2001-09-11 15:57:18 $ + * + * The Contents of this file are made available subject to the terms of + * either of the following licenses + * + * - GNU Lesser General Public License Version 2.1 + * - Sun Industry Standards Source License Version 1.1 + * + * Sun Microsystems Inc., October, 2000 + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2000 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + * + * Sun Industry Standards Source License Version 1.1 + * ================================================= + * The contents of this file are subject to the Sun Industry Standards + * Source License Version 1.1 (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.openoffice.org/license.html. + * + * Software provided under this License is provided on an "AS IS" basis, + * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, + * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, + * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. + * See the License for the specific provisions governing your rights and + * obligations concerning the Software. + * + * The Initial Developer of the Original Code is: Sun Microsystems, Inc. + * + * Copyright: 2000 by Sun Microsystems, Inc. + * + * All Rights Reserved. + * + * Contributor(s): _______________________________________ + * + * + ************************************************************************/ +package com.sun.star.lib.uno.typedesc; + + +import java.lang.reflect.Method; +import java.util.Vector; + + +import com.sun.star.uno.Any; +import com.sun.star.uno.IFieldDescription; +import com.sun.star.uno.IMethodDescription; +import com.sun.star.uno.ITypeDescription; +import com.sun.star.uno.Type; +import com.sun.star.uno.TypeClass; +import com.sun.star.uno.XInterface; + + +public class TypeDescription_Test { +// static public TypeDescription getTypeDescription(String typeName) throws ClassNotFoundException { +// static public ITypeDescription getTypeDescription(Type type) throws ClassNotFoundException { +// static public TypeDescription getTypeDescription(TypeClass typeClass) { +// static public TypeDescription getTypeDescription(TypeInfo typeInfo, Class zClass) { +// TypeDescription.isTypeClassSimple(TypeClass typeClass) { + + static class MethodSignature { + boolean _oneway; + boolean _buildIn; + ITypeDescription _inSig[]; + ITypeDescription _outSig[]; + ITypeDescription _retSig; + + MethodSignature(boolean oneway, boolean buildin, ITypeDescription inSig[], ITypeDescription outSig[], ITypeDescription retSig) { + _oneway = oneway; + _buildIn = buildin; + _inSig = inSig; + _outSig = outSig; + _retSig = retSig; + } + + boolean test(Vector notpassed, int index, IMethodDescription iMethodDescription) { + boolean passed = true; + + boolean tmp_passed = iMethodDescription.isOneway() == _oneway; + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement("isOneway"); + + int mindex = iMethodDescription.getIndex(); + tmp_passed = mindex == index; + passed = passed && tmp_passed; + if(!tmp_passed) { + notpassed.addElement("getIndex - " + mindex); +// throw new RuntimeException("blabla"); + } + + ITypeDescription inSig[] = iMethodDescription.getInSignature(); + tmp_passed = inSig.length == _inSig.length; + if(tmp_passed) + for(int i = 0; i < inSig.length; ++ i) + tmp_passed = tmp_passed && inSig[i].equals(_inSig[i]); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement("getInSignature - "); + + ITypeDescription outSig[] = iMethodDescription.getOutSignature(); + tmp_passed = outSig.length == _outSig.length; + if(tmp_passed) + for(int i = 0; i < outSig.length; ++ i) + tmp_passed = tmp_passed && (outSig[i] == _outSig[i] || outSig[i].equals(_outSig[i])); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement("getOutSignature - "); + + ITypeDescription retSig = iMethodDescription.getReturnSignature(); + tmp_passed = retSig.equals(_retSig); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement("getReturnSignature - "); + + Method method = iMethodDescription.getMethod(); + tmp_passed = (method != null) ^ _buildIn; + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement("getMethod - " + method); + + return passed; + } + } + + + static class TypeSignature { + TypeSignature _superType; + MethodSignature _methodSignatures[]; + String _method_names[]; + int _method_offset; + + TypeSignature _fieldSignatures[]; + String _field_names[]; + int _field_offset; + + TypeSignature(TypeSignature superType, String names[], MethodSignature methodSignatures[], String field_names[], TypeSignature fieldSignatures[]) { + _superType = superType; + _method_names = names; + _methodSignatures = methodSignatures; + + _fieldSignatures = fieldSignatures; + _field_names = field_names; + + if(_superType != null) { + _method_offset = _superType._method_offset + _superType._method_names.length; + _field_offset = _superType._field_offset + _superType._field_names.length; + } + } + + public boolean test(Vector notpassed, Object names[], ITypeDescription iTypeDescription) throws Exception { + boolean passed = true; + + String comment = "TypeSignature.test(" + iTypeDescription + ") "; + System.err.println("TypeDescription_Test.test_TypeSignature - doing tests..."); + + ITypeDescription superType = iTypeDescription.getSuperType(); + boolean tmp_passed = superType == null || (names.length == 6 && _superType.test(notpassed, (Object [])names[5], superType)); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getSuperType - " + superType); + + IMethodDescription iMethodDescriptions[] = iTypeDescription.getMethodDescriptions(); + tmp_passed = iMethodDescriptions != null; + tmp_passed = tmp_passed && _methodSignatures.length == iMethodDescriptions.length; + if(tmp_passed) + for(int i = 0; i < _methodSignatures.length; ++ i) { + boolean tmp_tmp_passed = _methodSignatures[i].test(notpassed, i + _method_offset, iMethodDescriptions[i]); + + tmp_passed = tmp_passed && tmp_tmp_passed; + if(!tmp_tmp_passed) + notpassed.addElement(comment + "- getMethodDescriptions - index:" + i); + } + else + notpassed.addElement(comment + "- getMethodDescriptions - size:" + iMethodDescriptions.length); + passed = passed && tmp_passed; + + + for(int i = 0; i < _method_names.length; ++ i) { + IMethodDescription iMethodDescription = iTypeDescription.getMethodDescription(i + _method_offset); + tmp_passed = iMethodDescription != null && _methodSignatures[i].test(notpassed, i + _method_offset, iMethodDescription); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getMethodDescription(int " + (i + _method_offset) + ") - " + iMethodDescription); + } + + for(int i = 0; i < _method_names.length; ++ i) { + IMethodDescription iMethodDescription = iTypeDescription.getMethodDescription(_method_names[i]); + tmp_passed = iMethodDescription != null && _methodSignatures[i].test(notpassed, i + _method_offset, iMethodDescription); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getMethodDescription(String " + _method_names[i] + ")"); + } + + IFieldDescription iFieldDescriptions[] = iTypeDescription.getFieldDescriptions(); + tmp_passed = iFieldDescriptions != null && iFieldDescriptions.length == _fieldSignatures.length; + if(tmp_passed) + for(int i = 0; i < _fieldSignatures.length; ++ i) { + boolean tmp_tmp_passed = _fieldSignatures[i].test(notpassed, ((Object [][])names[4])[i], iFieldDescriptions[i].getTypeDescription()); + + tmp_passed = tmp_passed && tmp_tmp_passed; + if(!tmp_tmp_passed) + notpassed.addElement(comment + "- getFieldDescriptions - index:" + i); + } + else + notpassed.addElement(comment + "- getFieldDescriptions - size:" + iFieldDescriptions.length); + passed = passed && tmp_passed; + + + TypeClass typeClass = iTypeDescription.getTypeClass(); + tmp_passed = typeClass == names[3]; + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getTypeClass"); + + ITypeDescription componentType = iTypeDescription.getComponentType(); + tmp_passed = componentType == null; + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getComponentType"); + + String typeName = iTypeDescription.getTypeName(); + tmp_passed = typeName.equals(names[0]); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getTypeName"); + + String arrayTypeName = iTypeDescription.getArrayTypeName(); + tmp_passed = arrayTypeName.equals(names[1]); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getArrayTypeName - " + names[1]); + + Class xzClass = iTypeDescription.getZClass(); + tmp_passed = xzClass == names[2]; + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- getZClass"); + + tmp_passed = iTypeDescription.equals(TypeDescription.getTypeDescription((String)names[0])); + passed = passed && tmp_passed; + if(!tmp_passed) + notpassed.addElement(comment + "- equals"); + + + return passed; + } + } + + static ITypeDescription __stringTD = TypeDescription.getTypeDescription(String.class); + static ITypeDescription __xinterfaceTD = TypeDescription.getTypeDescription(XInterface.class); + static ITypeDescription __voidTD = TypeDescription.getTypeDescription(Void.class); + static ITypeDescription __typeTD = TypeDescription.getTypeDescription(Type.class); + static ITypeDescription __anyTD = TypeDescription.getTypeDescription(Any.class); + + + static MethodSignature __sig_sync_buildin_itype__any = new MethodSignature(false, true, new ITypeDescription[]{__typeTD}, new ITypeDescription[1], __anyTD); + static MethodSignature __sig_async_buildin__void = new MethodSignature(true, true, new ITypeDescription[]{}, new ITypeDescription[0], __voidTD); + + static TypeSignature __itf_xinterface = new TypeSignature(null, + new String[]{"queryInterface", "acquire", "release"}, + new MethodSignature[]{__sig_sync_buildin_itype__any, __sig_async_buildin__void, __sig_async_buildin__void}, + new String[0], + new TypeSignature[0]); + + + static MethodSignature __sig_sync_addon_istr__xifc = new MethodSignature(false, false, new ITypeDescription[]{__stringTD}, new ITypeDescription[1], __xinterfaceTD); + static MethodSignature __sig_sync_addon_istr_ixifc__void = new MethodSignature(false, false, new ITypeDescription[]{__stringTD, __xinterfaceTD}, new ITypeDescription[2], __voidTD); + static MethodSignature __sig_sync_addon_istr__void = new MethodSignature(false, false, new ITypeDescription[]{__stringTD}, new ITypeDescription[1], __voidTD); + + static TypeSignature __itf_xnaming_service = new TypeSignature(__itf_xinterface, + new String[]{"getRegisteredObject", "registerObject", "revokeObject"}, + new MethodSignature[]{__sig_sync_addon_istr__xifc, __sig_sync_addon_istr_ixifc__void, __sig_sync_addon_istr__void}, + new String[0], + new TypeSignature[0]); + + + + static TypeSignature __emptySig = new TypeSignature(null, + new String[0], + new MethodSignature[0], + new String[0], + new TypeSignature[0]); + + + static TypeSignature __exception = new TypeSignature(null, + new String[0], + new MethodSignature[0], + new String[]{"Message", "Context"}, + new TypeSignature[] {__emptySig, __itf_xinterface}); + + + + public static boolean test(Vector notpassed) throws Exception { + boolean passed = true; + + boolean tmp_passed = true; + + Object string_cc[] = new Object[]{"string", "[Ljava.lang.String;", java.lang.String.class, TypeClass.STRING}; + Object byte_cc[] = new Object[]{"byte", "[B", byte.class, TypeClass.BYTE}; + + Object xinterface_cc[] = new Object[]{"com.sun.star.uno.XInterface", "[Lcom.sun.star.uno.XInterface;", com.sun.star.uno.XInterface.class, TypeClass.INTERFACE}; + + tmp_passed = __emptySig.test(notpassed, byte_cc, TypeDescription.getTypeDescription("byte")); + passed = passed && tmp_passed; + + tmp_passed = __emptySig.test(notpassed, string_cc, TypeDescription.getTypeDescription("string")); + passed = passed && tmp_passed; + + + tmp_passed = __exception.test(notpassed, new Object[]{"com.sun.star.uno.Exception", + "[Lcom.sun.star.uno.Exception;", + com.sun.star.uno.Exception.class, + TypeClass.EXCEPTION, + new Object[]{string_cc, xinterface_cc}}, TypeDescription.getTypeDescription("com.sun.star.uno.Exception")); + passed = passed && tmp_passed; + + tmp_passed = __emptySig.test(notpassed, new Object[]{"com.sun.star.uno.TypeClass", + "[Lcom.sun.star.uno.TypeClass;", + com.sun.star.uno.TypeClass.class, + TypeClass.ENUM}, TypeDescription.getTypeDescription("com.sun.star.uno.TypeClass")); + passed = passed && tmp_passed; + + tmp_passed = __itf_xinterface.test(notpassed, xinterface_cc, TypeDescription.getTypeDescription(XInterface.class)); + passed = passed && tmp_passed; + + tmp_passed = __itf_xnaming_service.test(notpassed, new Object[]{"com.sun.star.uno.XNamingService", + "[Lcom.sun.star.uno.XNamingService;", + com.sun.star.uno.XNamingService.class, + TypeClass.INTERFACE, + null, + xinterface_cc}, TypeDescription.getTypeDescription(com.sun.star.uno.XNamingService.class)); + passed = passed && tmp_passed; + + return passed; + } + + static public void main(String args[]) throws Exception { + Vector notpassed = new Vector(); + + boolean passed = test(notpassed); + + System.err.println("tests passed? " + passed); + + for(int i = 0; i < notpassed.size(); ++ i) + System.err.println("not passed:" + notpassed.elementAt(i)); + } +} diff --git a/ridljar/test/com/sun/star/lib/uno/typedesc/makefile.mk b/ridljar/test/com/sun/star/lib/uno/typedesc/makefile.mk new file mode 100644 index 000000000000..fe1bfefc1d15 --- /dev/null +++ b/ridljar/test/com/sun/star/lib/uno/typedesc/makefile.mk @@ -0,0 +1,87 @@ +#************************************************************************* +# +# $RCSfile: makefile.mk,v $ +# +# $Revision: 1.1 $ +# +# last change: $Author: kr $ $Date: 2001-09-11 15:57:18 $ +# +# The Contents of this file are made available subject to the terms of +# either of the following licenses +# +# - GNU Lesser General Public License Version 2.1 +# - Sun Industry Standards Source License Version 1.1 +# +# Sun Microsystems Inc., October, 2000 +# +# GNU Lesser General Public License Version 2.1 +# ============================================= +# Copyright 2000 by Sun Microsystems, Inc. +# 901 San Antonio Road, Palo Alto, CA 94303, USA +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License version 2.1, as published by the Free Software Foundation. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, +# MA 02111-1307 USA +# +# +# Sun Industry Standards Source License Version 1.1 +# ================================================= +# The contents of this file are subject to the Sun Industry Standards +# Source License Version 1.1 (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.openoffice.org/license.html. +# +# Software provided under this License is provided on an "AS IS" basis, +# WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, +# WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, +# MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. +# See the License for the specific provisions governing your rights and +# obligations concerning the Software. +# +# The Initial Developer of the Original Code is: Sun Microsystems, Inc. +# +# Copyright: 2000 by Sun Microsystems, Inc. +# +# All Rights Reserved. +# +# Contributor(s): _______________________________________ +# +# +# +#************************************************************************* + +PRJ=..$/..$/..$/..$/..$/..$/.. + +PRJNAME := ridljar +PACKAGE := com$/sun$/star$/lib$/uno$/typedesc +TARGET := test_com_sun_star_lib_uno_typedesc + + +# --- Settings ----------------------------------------------------- +.INCLUDE : settings.mk + +JARFILES = sandbox.jar +JAVAFILES = $(subst,$(CLASSDIR)$/$(PACKAGE)$/, $(subst,.class,.java $(JAVACLASSFILES))) + + +# Files -------------------------------------------------------- + + +JAVACLASSFILES= \ + $(CLASSDIR)$/$(PACKAGE)$/TypeDescription_Test.class + + +# --- Targets ------------------------------------------------------ + +.INCLUDE : target.mk + |