--- /dev/null
+/*\r
+ \r
+ Derby - Class org.apache.derby.impl.jdbc.SQLExceptionFactory\r
+ \r
+ Licensed to the Apache Software Foundation (ASF) under one or more\r
+ contributor license agreements. See the NOTICE file distributed with\r
+ this work for additional information regarding copyright ownership.\r
+ The ASF licenses this file to you under the Apache License, Version 2.0\r
+ (the "License"); you may not use this file except in compliance with\r
+ the License. You may obtain a copy of the License at\r
+ \r
+ http://www.apache.org/licenses/LICENSE-2.0\r
+ \r
+ Unless required by applicable law or agreed to in writing, software\r
+ distributed under the License is distributed on an "AS IS" BASIS,\r
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
+ See the License for the specific language governing permissions and\r
+ limitations under the License.\r
+ \r
+ */\r
+\r
+package org.apache.derby.impl.jdbc;\r
+\r
+import java.io.IOException;\r
+import org.apache.derby.iapi.error.ExceptionSeverity;\r
+import org.apache.derby.iapi.reference.SQLState;\r
+import org.apache.derby.iapi.error.StandardException;\r
+import org.apache.derby.iapi.services.i18n.MessageService;\r
+import org.apache.derby.iapi.reference.MessageId;\r
+\r
+import java.sql.SQLException;\r
+\r
+/**\r
+ *Class to create SQLException\r
+ *\r
+ */\r
+public class SQLExceptionFactory {\r
+ /**\r
+ * method to construct SQLException\r
+ * version specific drivers can overload this method to create\r
+ * version specific exceptions\r
+ */\r
+ public SQLException getSQLException(String message, String messageId,\r
+ SQLException next, int severity, Throwable t, Object[] args) {\r
+ return new EmbedSQLException(message, messageId, next, severity,\r
+ t, args);\r
+ }\r
+\r
+ /**\r
+ * Unpack a SQL exception, looking for an EmbedSQLException which carries\r
+ * the Derby messageID and args which we will serialize across DRDA so\r
+ * that the client can reconstitute a SQLException with appropriate text.\r
+ * If we are running JDBC3 or JDBC2, then we hope that the passed-in\r
+ * exception is already an EmbedSQLException, which carries all the\r
+ * information we need.\r
+ */\r
+ public SQLException getArgumentFerry(SQLException se)\r
+ {\r
+ return se;\r
+ }\r
+\r
+}\r