src.com.ziclix.python.sql.connect.Connect Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jython Show documentation
Show all versions of jython Show documentation
Jython is an implementation of the high-level, dynamic, object-oriented
language Python written in 100% Pure Java, and seamlessly integrated with
the Java platform. It thus allows you to run Python on any Java platform.
/*
* Jython Database Specification API 2.0
*
*
* Copyright (c) 2001 brian zimmer
*
*/
package com.ziclix.python.sql.connect;
import java.sql.*;
import java.util.*;
import org.python.core.*;
import com.ziclix.python.sql.*;
import com.ziclix.python.sql.util.*;
/**
* Connect using DriverManager.
*
* @author brian zimmer
*/
public class Connect extends PyObject {
private static final PyString _doc = new PyString("establish a connection through java.sql.DriverManager");
/**
* Default empty constructor.
*/
public Connect() {
}
public PyObject __findattr_ex__(String name) {
if ("__doc__".equals(name)) {
return _doc;
}
return super.__findattr_ex__(name);
}
/**
* Establish a connection through DriverManager.
*/
public PyObject __call__(PyObject[] args, String[] keywords) {
Connection c = null;
PyArgParser parser = new PyArgParser(args, keywords);
Object arg = parser.arg(0).__tojava__(Connection.class);
if (arg == Py.NoConversion) {
Properties props = new Properties();
String url = (String) parser.arg(0).__tojava__(String.class);
String user = (String) parser.arg(1).__tojava__(String.class);
String password = (String) parser.arg(2).__tojava__(String.class);
String driver = (String) parser.arg(3).__tojava__(String.class);
if (url == null) {
throw zxJDBC.makeException(zxJDBC.DatabaseError, "no url specified");
}
if (driver == null) {
throw zxJDBC.makeException(zxJDBC.DatabaseError, "no driver specified");
}
// the value can't be null
props.put("user", (user == null) ? "" : user);
props.put("password", (password == null) ? "" : password);
String[] kws = parser.kws();
for (int i = 0; i < kws.length; i++) {
Object value = parser.kw(kws[i]).__tojava__(Object.class);
props.put(kws[i], value);
}
try {
Class.forName(driver);
} catch (Throwable e) {
throw zxJDBC.makeException(zxJDBC.DatabaseError, "driver [" + driver + "] not found");
}
try {
c = DriverManager.getConnection(url, props);
} catch (SQLException e) {
throw zxJDBC.makeException(zxJDBC.DatabaseError, e);
}
} else {
c = (Connection) arg;
}
try {
if ((c == null) || c.isClosed()) {
throw zxJDBC.makeException(zxJDBC.DatabaseError, "unable to establish connection");
}
return new PyConnection(c);
} catch (SQLException e) {
throw zxJDBC.makeException(zxJDBC.DatabaseError, e);
}
}
/**
* Method toString
*
* @return String
*/
public String toString() {
return "";
}
}