diff options
Diffstat (limited to 'org/omg/IOP')
-rw-r--r-- | org/omg/IOP/CodecFactoryPackage/UnknownEncoding.java | 78 | ||||
-rw-r--r-- | org/omg/IOP/CodecFactoryPackage/UnknownEncodingHelper.java | 150 | ||||
-rw-r--r-- | org/omg/IOP/CodecPackage/FormatMismatch.java | 81 | ||||
-rw-r--r-- | org/omg/IOP/CodecPackage/FormatMismatchHelper.java | 146 | ||||
-rw-r--r-- | org/omg/IOP/CodecPackage/InvalidTypeForEncoding.java | 81 | ||||
-rw-r--r-- | org/omg/IOP/CodecPackage/InvalidTypeForEncodingHelper.java | 149 | ||||
-rw-r--r-- | org/omg/IOP/CodecPackage/TypeMismatch.java | 79 | ||||
-rw-r--r-- | org/omg/IOP/CodecPackage/TypeMismatchHelper.java | 146 |
8 files changed, 910 insertions, 0 deletions
diff --git a/org/omg/IOP/CodecFactoryPackage/UnknownEncoding.java b/org/omg/IOP/CodecFactoryPackage/UnknownEncoding.java new file mode 100644 index 000000000..207f3bac5 --- /dev/null +++ b/org/omg/IOP/CodecFactoryPackage/UnknownEncoding.java @@ -0,0 +1,78 @@ +/* UnknownEncoding.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecFactoryPackage; + +import org.omg.CORBA.UserException; +import org.omg.CORBA.portable.IDLEntity; + +import java.io.Serializable; + +/** +* The {@link org.omg.IOP.CodecFactoryOperations#create_codec} raises +* UnknownEncoding if that factory cannot create a +* {@link org.omg.IOP.Codec} of the given encoding. +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public class UnknownEncoding + extends UserException + implements IDLEntity, Serializable +{ + /** + * Use serialVersionUID (v1.4) for interoperability. + */ + private static final long serialVersionUID = 1613955753212049966L; + + /** + * Create UnknownEncoding with no explaining message. + */ + public UnknownEncoding() + { + } + + /** + * Create the UnknownEncoding with explaining message. + * + * @param why a string, explaining, why this exception has been thrown. + */ + public UnknownEncoding(String why) + { + super(why); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecFactoryPackage/UnknownEncodingHelper.java b/org/omg/IOP/CodecFactoryPackage/UnknownEncodingHelper.java new file mode 100644 index 000000000..7f4d37b6a --- /dev/null +++ b/org/omg/IOP/CodecFactoryPackage/UnknownEncodingHelper.java @@ -0,0 +1,150 @@ +/* UnknownEncodingHelper.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecFactoryPackage; + +import gnu.CORBA.EmptyExceptionHolder; + +import org.omg.CORBA.ORB; +import org.omg.CORBA.Any; +import org.omg.CORBA.TypeCode; +import org.omg.CORBA.TCKind; +import org.omg.CORBA.StructMember; + +import org.omg.CORBA.portable.InputStream; +import org.omg.CORBA.portable.OutputStream; +import org.omg.CORBA.BAD_OPERATION; + + /** + * The helper operations for the exception {@link UnknownEncoding}. + * + * @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) + */ +public abstract class UnknownEncodingHelper +{ + /** + * The cached typecode value, computed only once. + */ + private static TypeCode typeCode; + + /** + * Create the UnknownEncoding typecode (structure, + * named "UnknownEncoding"). + */ + public static TypeCode type() + { + if (typeCode == null) + { + ORB orb = ORB.init(); + StructMember[] members = new StructMember[0]; + typeCode = + orb.create_exception_tc (id(), "UnknownEncoding", members); + + } + return typeCode; + } + + /* Every user exception with no user defined fields can use EmptyExceptionHolder */ + + /** + * Insert the UnknownEncoding into the given Any. + * + * @param any the Any to insert into. + * @param that the UnknownEncoding to insert. + */ + public static void insert(Any any, UnknownEncoding that) + { + any.insert_Streamable(new EmptyExceptionHolder(that, type())); + } + + /** + * Extract the UnknownEncoding from given Any. + * + * @throws BAD_OPERATION if the passed Any does not contain UnknownEncoding. + */ + public static UnknownEncoding extract(Any any) + { + try + { + EmptyExceptionHolder h = (EmptyExceptionHolder) any.extract_Streamable(); + return (UnknownEncoding) h.value; + } + catch (ClassCastException cex) + { + BAD_OPERATION bad = new BAD_OPERATION("UnknownEncoding expected"); + bad.initCause(cex); + throw bad; + } + } + + /** + * Get the UnknownEncoding repository id. + * + * @return "IDL:omg.org/IOP/CodecFactory/UnknownEncoding:1.0", always. + */ + public static String id() + { + return "IDL:omg.org/IOP/CodecFactory/UnknownEncoding:1.0"; + } + + /** + * Read the exception from the CDR intput stream. + * + * @param input a org.omg.CORBA.portable stream to read from. + */ + public static UnknownEncoding read(InputStream input) + { + // Read the exception repository id. + String id = input.read_string(); + UnknownEncoding value = new UnknownEncoding(id); + + return value; + } + + /** + * Write the exception to the CDR output stream. + * + * @param output a org.omg.CORBA.portable stream stream to write into. + * @param value a value to write. + */ + public static void write(OutputStream output, UnknownEncoding value) + { + // Write the exception repository id. + output.write_string(id()); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecPackage/FormatMismatch.java b/org/omg/IOP/CodecPackage/FormatMismatch.java new file mode 100644 index 000000000..9bcd2b720 --- /dev/null +++ b/org/omg/IOP/CodecPackage/FormatMismatch.java @@ -0,0 +1,81 @@ +/* FormatMismatch.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecPackage; + +import org.omg.CORBA.UserException; +import org.omg.CORBA.portable.IDLEntity; + +import java.io.Serializable; + +/** +* This exception is raised by {@link org.omg.IOP.CodecOperations#decode} +* or {@link org.omg.IOP.CodecOperations#decode_value} when the data in the +* octet sequence cannot be decoded into {@link org.omg.CORBA.Any}. +* +* @see org.omg.IOP.CodecOperations +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public class FormatMismatch + extends UserException + implements IDLEntity, Serializable +{ + /** + * Use serialVersionUID (v1.4) for interoperability. + */ + private static final long serialVersionUID = 5818121867618342320L; + + /** + * Create FormatMismatch with no explaining message. + */ + public FormatMismatch() + { + } + + /** + * Create the FormatMismatch with explaining message and all fields + * initialised to the given values. + * + * @param why a string, explaining, why this exception has been thrown. + */ + public FormatMismatch(String why) + { + super(why); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecPackage/FormatMismatchHelper.java b/org/omg/IOP/CodecPackage/FormatMismatchHelper.java new file mode 100644 index 000000000..447286ab8 --- /dev/null +++ b/org/omg/IOP/CodecPackage/FormatMismatchHelper.java @@ -0,0 +1,146 @@ +/* FormatMismatchHelper.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecPackage; + +import gnu.CORBA.EmptyExceptionHolder; + +import org.omg.CORBA.Any; +import org.omg.CORBA.BAD_OPERATION; +import org.omg.CORBA.ORB; +import org.omg.CORBA.StructMember; +import org.omg.CORBA.TCKind; +import org.omg.CORBA.TypeCode; +import org.omg.CORBA.portable.InputStream; +import org.omg.CORBA.portable.OutputStream; + +/** +* The helper operations for the exception {@link FormatMismatch}. +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public abstract class FormatMismatchHelper +{ + /** + * The cached typecode value, computed only once. + */ + private static TypeCode typeCode; + + /** + * Create the FormatMismatch typecode (structure, + * named "FormatMismatch"). + */ + public static TypeCode type() + { + if (typeCode == null) + { + ORB orb = ORB.init(); + StructMember[] members = new StructMember[ 0 ]; + typeCode = orb.create_exception_tc(id(), "FormatMismatch", members); + } + return typeCode; + } + + /** + * Insert the FormatMismatch into the given Any. + * + * @param any the Any to insert into. + * @param that the FormatMismatch to insert. + */ + public static void insert(Any any, FormatMismatch that) + { + any.insert_Streamable(new EmptyExceptionHolder(that, type())); + } + + /** + * Extract the FormatMismatch from given Any. + * + * @throws BAD_OPERATION if the passed Any does not contain FormatMismatch. + */ + public static FormatMismatch extract(Any any) + { + try + { + EmptyExceptionHolder h = + (EmptyExceptionHolder) any.extract_Streamable(); + return (FormatMismatch) h.value; + } + catch (ClassCastException cex) + { + BAD_OPERATION bad = new BAD_OPERATION("FormatMismatch expected"); + bad.initCause(cex); + throw bad; + } + } + + /** + * Get the FormatMismatch repository id. + * + * @return "IDL:omg.org/IOP/Codec/FormatMismatch:1.0", always. + */ + public static String id() + { + return "IDL:omg.org/IOP/Codec/FormatMismatch:1.0"; + } + + /** + * Read the exception from the CDR intput stream. + * + * @param input a org.omg.CORBA.portable stream to read from. + */ + public static FormatMismatch read(InputStream input) + { + // Read the exception repository id. + String id = input.read_string(); + FormatMismatch value = new FormatMismatch(id); + + return value; + } + + /** + * Write the exception to the CDR output stream. + * + * @param output a org.omg.CORBA.portable stream stream to write into. + * @param value a value to write. + */ + public static void write(OutputStream output, FormatMismatch value) + { + // Write the exception repository id. + output.write_string(id()); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecPackage/InvalidTypeForEncoding.java b/org/omg/IOP/CodecPackage/InvalidTypeForEncoding.java new file mode 100644 index 000000000..ebf620843 --- /dev/null +++ b/org/omg/IOP/CodecPackage/InvalidTypeForEncoding.java @@ -0,0 +1,81 @@ +/* InvalidTypeForEncoding.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecPackage; + +import org.omg.CORBA.UserException; +import org.omg.CORBA.portable.IDLEntity; + +import java.io.Serializable; + +/** +* This exception is raised by {@link org.omg.IOP.CodecOperations#encode} or +* {@link org.omg.IOP.CodecOperations#encode_value} when the type is not +* valid for the encoding. For instance, the "wide" character string is +* not a valid type for GIOP version 1.0. +* +* @see org.omg.IOP.CodecOperations +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public class InvalidTypeForEncoding + extends UserException + implements IDLEntity, Serializable +{ + /** + * Use serialVersionUID (v1.4) for interoperability. + */ + private static final long serialVersionUID = 7951932210684443970L; + + /** + * Create InvalidTypeForEncoding with no explaining message. + */ + public InvalidTypeForEncoding() + { + } + + /** + * Create the InvalidTypeForEncoding with explaining message. + * + * @param why a string, explaining, why this exception has been thrown. + */ + public InvalidTypeForEncoding(String why) + { + super(why); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecPackage/InvalidTypeForEncodingHelper.java b/org/omg/IOP/CodecPackage/InvalidTypeForEncodingHelper.java new file mode 100644 index 000000000..820e87a5c --- /dev/null +++ b/org/omg/IOP/CodecPackage/InvalidTypeForEncodingHelper.java @@ -0,0 +1,149 @@ +/* InvalidTypeForEncodingHelper.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecPackage; + +import gnu.CORBA.EmptyExceptionHolder; + +import org.omg.CORBA.Any; +import org.omg.CORBA.BAD_OPERATION; +import org.omg.CORBA.ORB; +import org.omg.CORBA.StructMember; +import org.omg.CORBA.TCKind; +import org.omg.CORBA.TypeCode; +import org.omg.CORBA.portable.InputStream; +import org.omg.CORBA.portable.OutputStream; + +/** +* The helper operations for the exception {@link InvalidTypeForEncoding}. +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public abstract class InvalidTypeForEncodingHelper +{ + /** + * The cached typecode value, computed only once. + */ + private static TypeCode typeCode; + + /** + * Create the InvalidTypeForEncoding typecode (structure, + * named "InvalidTypeForEncoding"). + */ + public static TypeCode type() + { + if (typeCode == null) + { + ORB orb = ORB.init(); + StructMember[] members = new StructMember[ 0 ]; + typeCode = + orb.create_exception_tc(id(), "InvalidTypeForEncoding", members); + } + return typeCode; + } + + /** + * Insert the InvalidTypeForEncoding into the given Any. + * + * @param any the Any to insert into. + * @param that the InvalidTypeForEncoding to insert. + */ + public static void insert(Any any, InvalidTypeForEncoding that) + { + any.insert_Streamable(new EmptyExceptionHolder(that, type())); + } + + /** + * Extract the InvalidTypeForEncoding from given Any. + * + * @throws BAD_OPERATION if the passed Any does not contain + * InvalidTypeForEncoding. + */ + public static InvalidTypeForEncoding extract(Any any) + { + try + { + EmptyExceptionHolder h = + (EmptyExceptionHolder) any.extract_Streamable(); + return (InvalidTypeForEncoding) h.value; + } + catch (ClassCastException cex) + { + BAD_OPERATION bad = + new BAD_OPERATION("InvalidTypeForEncoding expected"); + bad.initCause(cex); + throw bad; + } + } + + /** + * Get the InvalidTypeForEncoding repository id. + * + * @return "IDL:omg.org/IOP/Codec/InvalidTypeForEncoding:1.0", always. + */ + public static String id() + { + return "IDL:omg.org/IOP/Codec/InvalidTypeForEncoding:1.0"; + } + + /** + * Read the exception from the CDR intput stream. + * + * @param input a org.omg.CORBA.portable stream to read from. + */ + public static InvalidTypeForEncoding read(InputStream input) + { + // Read the exception repository id. + String id = input.read_string(); + InvalidTypeForEncoding value = new InvalidTypeForEncoding(id); + + return value; + } + + /** + * Write the exception to the CDR output stream. + * + * @param output a org.omg.CORBA.portable stream stream to write into. + * @param value a value to write. + */ + public static void write(OutputStream output, InvalidTypeForEncoding value) + { + // Write the exception repository id. + output.write_string(id()); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecPackage/TypeMismatch.java b/org/omg/IOP/CodecPackage/TypeMismatch.java new file mode 100644 index 000000000..508b17144 --- /dev/null +++ b/org/omg/IOP/CodecPackage/TypeMismatch.java @@ -0,0 +1,79 @@ +/* TypeMismatch.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecPackage; + +import org.omg.CORBA.UserException; +import org.omg.CORBA.portable.IDLEntity; + +import java.io.Serializable; + +/** +* The TypeMismatch may be thrown by various methods in org.omg.DynamicAny +* package when the operation is not applicable due unexpected +* {@link org.omg.CORBA.TypeCode}. +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public class TypeMismatch + extends UserException + implements IDLEntity, Serializable +{ + + /** + * Use serialVersionUID (v1.4) for interoperability. + */ + private static final long serialVersionUID = -3544092104480759035L; + + /** + * Create TypeMismatch with no explaining message. + */ + public TypeMismatch() + { + } + + /** + * Create the TypeMismatch with explaining message. + * + * @param why a string, explaining, why this exception has been thrown. + */ + public TypeMismatch(String why) + { + super(why); + } +}
\ No newline at end of file diff --git a/org/omg/IOP/CodecPackage/TypeMismatchHelper.java b/org/omg/IOP/CodecPackage/TypeMismatchHelper.java new file mode 100644 index 000000000..b10f13f13 --- /dev/null +++ b/org/omg/IOP/CodecPackage/TypeMismatchHelper.java @@ -0,0 +1,146 @@ +/* TypeMismatchHelper.java -- + Copyright (C) 2005 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 +General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package org.omg.IOP.CodecPackage; + +import gnu.CORBA.EmptyExceptionHolder; + +import org.omg.CORBA.Any; +import org.omg.CORBA.BAD_OPERATION; +import org.omg.CORBA.ORB; +import org.omg.CORBA.StructMember; +import org.omg.CORBA.TCKind; +import org.omg.CORBA.TypeCode; +import org.omg.CORBA.portable.InputStream; +import org.omg.CORBA.portable.OutputStream; + +/** +* The helper operations for the exception {@link TypeMismatch}. +* +* @author Audrius Meskauskas, Lithiania (AudriusA@Bioinformatics.org) +*/ +public abstract class TypeMismatchHelper +{ + /** + * The cached typecode value, computed only once. + */ + private static TypeCode typeCode; + + /** + * Create the TypeMismatch typecode (structure, + * named "TypeMismatch"). + */ + public static TypeCode type() + { + if (typeCode == null) + { + ORB orb = ORB.init(); + StructMember[] members = new StructMember[ 0 ]; + typeCode = orb.create_exception_tc(id(), "TypeMismatch", members); + } + return typeCode; + } + + /** + * Insert the TypeMismatch into the given Any. + * + * @param any the Any to insert into. + * @param that the TypeMismatch to insert. + */ + public static void insert(Any any, TypeMismatch that) + { + any.insert_Streamable(new EmptyExceptionHolder(that, type())); + } + + /** + * Extract the TypeMismatch from given Any. + * + * @throws BAD_OPERATION if the passed Any does not contain TypeMismatch. + */ + public static TypeMismatch extract(Any any) + { + try + { + EmptyExceptionHolder h = + (EmptyExceptionHolder) any.extract_Streamable(); + return (TypeMismatch) h.value; + } + catch (ClassCastException cex) + { + BAD_OPERATION bad = new BAD_OPERATION("TypeMismatch expected"); + bad.initCause(cex); + throw bad; + } + } + + /** + * Get the TypeMismatch repository id. + * + * @return "IDL:omg.org/IOP/Codec/TypeMismatch:1.0", always. + */ + public static String id() + { + return "IDL:omg.org/IOP/Codec/TypeMismatch:1.0"; + } + + /** + * Read the exception from the CDR intput stream. + * + * @param input a org.omg.CORBA.portable stream to read from. + */ + public static TypeMismatch read(InputStream input) + { + // Read the exception repository id. + String id = input.read_string(); + TypeMismatch value = new TypeMismatch(id); + + return value; + } + + /** + * Write the exception to the CDR output stream. + * + * @param output a org.omg.CORBA.portable stream stream to write into. + * @param value a value to write. + */ + public static void write(OutputStream output, TypeMismatch value) + { + // Write the exception repository id. + output.write_string(id()); + } +}
\ No newline at end of file |