1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-25 13:17:41 +03:00

Added an alternative constructor to PGSQLException so that debugging

some more osteric bugs is easier. If only 1 arg is supplied and it's
          of type Exception, then that Exception's stacktrace is now included.

This was done as there's been a report of an unusual bug during connection.
This will make this sort of bug hunting easier from now on.
This commit is contained in:
Peter Mount
2001-01-25 09:16:36 +00:00
parent 97f447b2cd
commit f118c36a78
3 changed files with 71 additions and 37 deletions

View File

@@ -1,3 +1,8 @@
Thu Jan 25 09:11:00 GMT 2001 peter@retep.org.uk
- Added an alternative constructor to PGSQLException so that debugging
some more osteric bugs is easier. If only 1 arg is supplied and it's
of type Exception, then that Exception's stacktrace is now included.
Wed Jan 24 09:18:00 GMT 2001 peter@retep.org.uk Wed Jan 24 09:18:00 GMT 2001 peter@retep.org.uk
- Removed the 8k limit by setting it to 64k - Removed the 8k limit by setting it to 64k

View File

@@ -24,10 +24,10 @@ import org.postgresql.util.PSQLException;
* @see org.postgresql.Connection * @see org.postgresql.Connection
* @see java.sql.Driver * @see java.sql.Driver
*/ */
public class Driver implements java.sql.Driver public class Driver implements java.sql.Driver
{ {
static static
{ {
try { try {
// moved the registerDriver from the constructor to here // moved the registerDriver from the constructor to here
@@ -39,7 +39,7 @@ public class Driver implements java.sql.Driver
e.printStackTrace(); e.printStackTrace();
} }
} }
/** /**
* Construct a new driver and register it with DriverManager * Construct a new driver and register it with DriverManager
* *
@@ -54,7 +54,7 @@ public class Driver implements java.sql.Driver
//} else { //} else {
//connectClass = "postgresql.jdbc2.Connection"; //connectClass = "postgresql.jdbc2.Connection";
//} //}
// Ok, when the above code was introduced in 6.5 it's intention was to allow // Ok, when the above code was introduced in 6.5 it's intention was to allow
// the driver to automatically detect which version of JDBC was being used // the driver to automatically detect which version of JDBC was being used
// and to detect the version of the JVM accordingly. // and to detect the version of the JVM accordingly.
@@ -71,7 +71,7 @@ public class Driver implements java.sql.Driver
// For this to work, the Makefile creates a pseudo class which contains the class // For this to work, the Makefile creates a pseudo class which contains the class
// name that will actually make the connection. // name that will actually make the connection.
} }
/** /**
* Try to make a database connection to the given URL. The driver * Try to make a database connection to the given URL. The driver
* should return "null" if it realizes it is the wrong kind of * should return "null" if it realizes it is the wrong kind of
@@ -85,12 +85,12 @@ public class Driver implements java.sql.Driver
* *
* <p>The java.util.Properties argument can be used to pass arbitrary * <p>The java.util.Properties argument can be used to pass arbitrary
* string tag/value pairs as connection arguments. Normally, at least * string tag/value pairs as connection arguments. Normally, at least
* "user" and "password" properties should be included in the * "user" and "password" properties should be included in the
* properties. In addition, the "charSet" property can be used to * properties. In addition, the "charSet" property can be used to
* set a character set encoding (e.g. "utf-8") other than the platform * set a character set encoding (e.g. "utf-8") other than the platform
* default (typically Latin1). This is necessary in particular if storing * default (typically Latin1). This is necessary in particular if storing
* multibyte characters in the database. For a list of supported * multibyte characters in the database. For a list of supported
* character encoding , see * character encoding , see
* http://java.sun.com/products/jdk/1.2/docs/guide/internat/encoding.doc.html * http://java.sun.com/products/jdk/1.2/docs/guide/internat/encoding.doc.html
* Note that you will probably want to have set up the Postgres database * Note that you will probably want to have set up the Postgres database
* itself to use the same encoding, with the "-E <encoding>" argument * itself to use the same encoding, with the "-E <encoding>" argument
@@ -112,7 +112,7 @@ public class Driver implements java.sql.Driver
{ {
if((props = parseURL(url,info))==null) if((props = parseURL(url,info))==null)
return null; return null;
try { try {
org.postgresql.Connection con = (org.postgresql.Connection)(Class.forName("@JDBCCONNECTCLASS@").newInstance()); org.postgresql.Connection con = (org.postgresql.Connection)(Class.forName("@JDBCCONNECTCLASS@").newInstance());
con.openConnection (host(), port(), props, database(), url, this); con.openConnection (host(), port(), props, database(), url, this);
@@ -127,7 +127,7 @@ public class Driver implements java.sql.Driver
throw new PSQLException("postgresql.unusual",ex2); throw new PSQLException("postgresql.unusual",ex2);
} }
} }
/** /**
* Returns true if the driver thinks it can open a connection to the * Returns true if the driver thinks it can open a connection to the
* given URL. Typically, drivers will return true if they understand * given URL. Typically, drivers will return true if they understand
@@ -146,7 +146,7 @@ public class Driver implements java.sql.Driver
return false; return false;
return true; return true;
} }
/** /**
* The getPropertyInfo method is intended to allow a generic GUI * The getPropertyInfo method is intended to allow a generic GUI
* tool to discover what properties it should prompt a human for * tool to discover what properties it should prompt a human for
@@ -168,12 +168,12 @@ public class Driver implements java.sql.Driver
public DriverPropertyInfo[] getPropertyInfo(String url, Properties info) throws SQLException public DriverPropertyInfo[] getPropertyInfo(String url, Properties info) throws SQLException
{ {
Properties p = parseURL(url,info); Properties p = parseURL(url,info);
// naughty, but its best for speed. If anyone adds a property here, then // naughty, but its best for speed. If anyone adds a property here, then
// this _MUST_ be increased to accomodate them. // this _MUST_ be increased to accomodate them.
DriverPropertyInfo d,dpi[] = new DriverPropertyInfo[0]; DriverPropertyInfo d,dpi[] = new DriverPropertyInfo[0];
//int i=0; //int i=0;
//dpi[i++] = d = new DriverPropertyInfo("auth",p.getProperty("auth","default")); //dpi[i++] = d = new DriverPropertyInfo("auth",p.getProperty("auth","default"));
//d.description = "determines if password authentication is used"; //d.description = "determines if password authentication is used";
//d.choices = new String[4]; //d.choices = new String[4];
@@ -181,10 +181,10 @@ public class Driver implements java.sql.Driver
//d.choices[1]="trust"; // No password authentication //d.choices[1]="trust"; // No password authentication
//d.choices[2]="password"; // Password authentication //d.choices[2]="password"; // Password authentication
//d.choices[3]="ident"; // Ident (RFC 1413) protocol //d.choices[3]="ident"; // Ident (RFC 1413) protocol
return dpi; return dpi;
} }
/** /**
* Gets the drivers major version number * Gets the drivers major version number
* *
@@ -194,7 +194,7 @@ public class Driver implements java.sql.Driver
{ {
return @MAJORVERSION@; return @MAJORVERSION@;
} }
/** /**
* Get the drivers minor version number * Get the drivers minor version number
* *
@@ -204,7 +204,7 @@ public class Driver implements java.sql.Driver
{ {
return @MINORVERSION@; return @MINORVERSION@;
} }
/** /**
* Returns the VERSION variable from Makefile.global * Returns the VERSION variable from Makefile.global
*/ */
@@ -212,13 +212,13 @@ public class Driver implements java.sql.Driver
{ {
return "@VERSION@"; return "@VERSION@";
} }
/** /**
* Report whether the driver is a genuine JDBC compliant driver. A * Report whether the driver is a genuine JDBC compliant driver. A
* driver may only report "true" here if it passes the JDBC compliance * driver may only report "true" here if it passes the JDBC compliance
* tests, otherwise it is required to return false. JDBC compliance * tests, otherwise it is required to return false. JDBC compliance
* requires full support for the JDBC API and full support for SQL 92 * requires full support for the JDBC API and full support for SQL 92
* Entry Level. * Entry Level.
* *
* <p>For PostgreSQL, this is not yet possible, as we are not SQL92 * <p>For PostgreSQL, this is not yet possible, as we are not SQL92
* compliant (yet). * compliant (yet).
@@ -227,11 +227,11 @@ public class Driver implements java.sql.Driver
{ {
return false; return false;
} }
private Properties props; private Properties props;
static private String[] protocols = { "jdbc","postgresql" }; static private String[] protocols = { "jdbc","postgresql" };
/** /**
* Constructs a new DriverURL, splitting the specified URL into its * Constructs a new DriverURL, splitting the specified URL into its
* component parts * component parts
@@ -246,17 +246,17 @@ public class Driver implements java.sql.Driver
Properties urlProps = new Properties(defaults); Properties urlProps = new Properties(defaults);
String key = ""; String key = "";
String value = ""; String value = "";
StringTokenizer st = new StringTokenizer(url, ":/;=&?", true); StringTokenizer st = new StringTokenizer(url, ":/;=&?", true);
for (int count = 0; (st.hasMoreTokens()); count++) { for (int count = 0; (st.hasMoreTokens()); count++) {
String token = st.nextToken(); String token = st.nextToken();
// PM June 29 1997 // PM June 29 1997
// Added this, to help me understand how this works. // Added this, to help me understand how this works.
// Unless you want each token to be processed, leave this commented out // Unless you want each token to be processed, leave this commented out
// but don't delete it. // but don't delete it.
//DriverManager.println("wellFormedURL: state="+state+" count="+count+" token='"+token+"'"); //DriverManager.println("wellFormedURL: state="+state+" count="+count+" token='"+token+"'");
// PM Aug 2 1997 - Modified to allow multiple backends // PM Aug 2 1997 - Modified to allow multiple backends
if (count <= 3) { if (count <= 3) {
if ((count % 2) == 1 && token.equals(":")) if ((count % 2) == 1 && token.equals(":"))
@@ -273,7 +273,7 @@ public class Driver implements java.sql.Driver
} }
} }
} }
if(found == false) if(found == false)
return null; return null;
} else return null; } else return null;
@@ -322,18 +322,18 @@ public class Driver implements java.sql.Driver
} }
} }
} }
// PM June 29 1997 // PM June 29 1997
// This now outputs the properties only if we are logging // This now outputs the properties only if we are logging
// PM Sep 13 1999 Commented out, as it throws a Deprecation warning // PM Sep 13 1999 Commented out, as it throws a Deprecation warning
// when compiled under JDK1.2. // when compiled under JDK1.2.
//if(DriverManager.getLogStream() != null) //if(DriverManager.getLogStream() != null)
// urlProps.list(DriverManager.getLogStream()); // urlProps.list(DriverManager.getLogStream());
return urlProps; return urlProps;
} }
/** /**
* @return the hostname portion of the URL * @return the hostname portion of the URL
*/ */
@@ -341,7 +341,7 @@ public class Driver implements java.sql.Driver
{ {
return props.getProperty("PGHOST","localhost"); return props.getProperty("PGHOST","localhost");
} }
/** /**
* @return the port number portion of the URL or -1 if no port was specified * @return the port number portion of the URL or -1 if no port was specified
*/ */
@@ -349,7 +349,7 @@ public class Driver implements java.sql.Driver
{ {
return Integer.parseInt(props.getProperty("PGPORT","5432")); return Integer.parseInt(props.getProperty("PGPORT","5432"));
} }
/** /**
* @return the database name of the URL * @return the database name of the URL
*/ */
@@ -357,7 +357,7 @@ public class Driver implements java.sql.Driver
{ {
return props.getProperty("PGDBNAME"); return props.getProperty("PGDBNAME");
} }
/** /**
* @return the value of any property specified in the URL or properties * @return the value of any property specified in the URL or properties
* passed to connect(), or null if not found. * passed to connect(), or null if not found.
@@ -366,7 +366,7 @@ public class Driver implements java.sql.Driver
{ {
return props.getProperty(name); return props.getProperty(name);
} }
/** /**
* This method was added in v6.5, and simply throws an SQLException * This method was added in v6.5, and simply throws an SQLException
* for an unimplemented method. I decided to do it this way while * for an unimplemented method. I decided to do it this way while

View File

@@ -1,5 +1,6 @@
package org.postgresql.util; package org.postgresql.util;
import java.io.*;
import java.sql.*; import java.sql.*;
import java.text.*; import java.text.*;
import java.util.*; import java.util.*;
@@ -45,6 +46,34 @@ public class PSQLException extends SQLException
translate(error,argv); translate(error,argv);
} }
/**
* Helper version for 1 arg. This is used for debug purposes only with
* some unusual Exception's. It allows the originiating Exceptions stack
* trace to be returned.
*/
public PSQLException(String error,Exception ex)
{
super();
Object[] argv = new Object[1];
try {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
PrintWriter pw = new PrintWriter(baos);
pw.println("Exception: "+ex.toString()+"\nStack Trace:\n");
ex.printStackTrace(pw);
pw.println("End of Stack Trace");
pw.flush();
argv[0] = baos.toString();
pw.close();
baos.close();
} catch(Exception ioe) {
argv[0] = ex.toString()+"\nIO Error on stack trace generation! "+ioe.toString();
}
translate(error,argv);
}
/** /**
* Helper version for 2 args * Helper version for 2 args
*/ */