Applied a bunch of patches from Tom Morris (Issue 25, 26 and 27)
- make java6 dependency explicit in eclipse project files - avoid using NotImplementException especially the sun.* one - avoid using internal sun signal handling and rely on standard java.* APIs (I tested this one and it seems to be working fine) git-svn-id: http://google-refine.googlecode.com/svn/trunk@756 7d457c2a-affb-35e4-300a-418c747d4874
This commit is contained in:
parent
a096fae7a0
commit
ea459aed07
@ -3,7 +3,7 @@
|
|||||||
<classpathentry kind="src" path="src/main/java"/>
|
<classpathentry kind="src" path="src/main/java"/>
|
||||||
<classpathentry kind="src" path="src/server/java"/>
|
<classpathentry kind="src" path="src/server/java"/>
|
||||||
<classpathentry kind="src" path="tests/java/src"/>
|
<classpathentry kind="src" path="tests/java/src"/>
|
||||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
|
||||||
<classpathentry kind="lib" path="lib/servlet-api-2.5.jar" sourcepath="lib-src/servlet-api-2.5-sources.jar"/>
|
<classpathentry kind="lib" path="lib/servlet-api-2.5.jar" sourcepath="lib-src/servlet-api-2.5-sources.jar"/>
|
||||||
<classpathentry kind="lib" path="lib/jetty-6.1.22.jar" sourcepath="lib-src/jetty-6.1.22-sources.jar"/>
|
<classpathentry kind="lib" path="lib/jetty-6.1.22.jar" sourcepath="lib-src/jetty-6.1.22-sources.jar"/>
|
||||||
<classpathentry kind="lib" path="lib/jetty-util-6.1.22.jar" sourcepath="lib-src/jetty-util-6.1.22-sources.jar"/>
|
<classpathentry kind="lib" path="lib/jetty-util-6.1.22.jar" sourcepath="lib-src/jetty-util-6.1.22-sources.jar"/>
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
#Sat Feb 06 22:08:10 PST 2010
|
#Thu May 13 14:23:04 EDT 2010
|
||||||
eclipse.preferences.version=1
|
eclipse.preferences.version=1
|
||||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.5
|
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.6
|
||||||
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
|
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
|
||||||
org.eclipse.jdt.core.compiler.compliance=1.5
|
org.eclipse.jdt.core.compiler.compliance=1.6
|
||||||
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
|
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
|
||||||
org.eclipse.jdt.core.compiler.debug.localVariable=generate
|
org.eclipse.jdt.core.compiler.debug.localVariable=generate
|
||||||
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
|
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
|
||||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||||
org.eclipse.jdt.core.compiler.source=1.5
|
org.eclipse.jdt.core.compiler.source=1.6
|
||||||
|
@ -10,7 +10,6 @@ import javax.servlet.ServletException;
|
|||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import org.apache.commons.lang.NotImplementedException;
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
@ -36,13 +35,13 @@ public abstract class Command {
|
|||||||
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
||||||
throws ServletException, IOException {
|
throws ServletException, IOException {
|
||||||
|
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
};
|
};
|
||||||
|
|
||||||
public void doGet(HttpServletRequest request, HttpServletResponse response)
|
public void doGet(HttpServletRequest request, HttpServletResponse response)
|
||||||
throws ServletException, IOException {
|
throws ServletException, IOException {
|
||||||
|
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -10,7 +10,6 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang.NotImplementedException;
|
|
||||||
import org.apache.poi.common.usermodel.Hyperlink;
|
import org.apache.poi.common.usermodel.Hyperlink;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
|
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
||||||
@ -39,7 +38,7 @@ public class ExcelImporter implements Importer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void read(Reader reader, Project project, Properties options) throws Exception {
|
public void read(Reader reader, Project project, Properties options) throws Exception {
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void read(InputStream inputStream, Project project, Properties options) throws Exception {
|
public void read(InputStream inputStream, Project project, Properties options) throws Exception {
|
||||||
@ -53,7 +52,7 @@ public class ExcelImporter implements Importer {
|
|||||||
new XSSFWorkbook(inputStream) :
|
new XSSFWorkbook(inputStream) :
|
||||||
new HSSFWorkbook(new POIFSFileSystem(inputStream));
|
new HSSFWorkbook(new POIFSFileSystem(inputStream));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new IOException(
|
throw new Exception(
|
||||||
"Attempted to parse file as Excel file but failed. " +
|
"Attempted to parse file as Excel file but failed. " +
|
||||||
"Try to use Excel to re-save the file as a different Excel version or as TSV and upload again.",
|
"Try to use Excel to re-save the file as a different Excel version or as TSV and upload again.",
|
||||||
e
|
e
|
||||||
|
@ -8,7 +8,6 @@ import java.io.OutputStream;
|
|||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang.NotImplementedException;
|
|
||||||
import org.marc4j.MarcPermissiveStreamReader;
|
import org.marc4j.MarcPermissiveStreamReader;
|
||||||
import org.marc4j.MarcWriter;
|
import org.marc4j.MarcWriter;
|
||||||
import org.marc4j.MarcXmlWriter;
|
import org.marc4j.MarcXmlWriter;
|
||||||
@ -25,7 +24,7 @@ public class MarcImporter implements Importer {
|
|||||||
public void read(Reader reader, Project project, Properties options)
|
public void read(Reader reader, Project project, Properties options)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
|
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void read(
|
public void read(
|
||||||
|
@ -7,7 +7,6 @@ import java.util.ArrayList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang.NotImplementedException;
|
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
|
|
||||||
import com.metaweb.gridworks.importers.parsers.CSVRowParser;
|
import com.metaweb.gridworks.importers.parsers.CSVRowParser;
|
||||||
@ -94,7 +93,7 @@ public class TsvCsvImporter implements Importer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void read(InputStream inputStream, Project project, Properties options) throws Exception {
|
public void read(InputStream inputStream, Project project, Properties options) throws Exception {
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean takesReader() {
|
public boolean takesReader() {
|
||||||
|
@ -6,8 +6,6 @@ import java.io.PushbackInputStream;
|
|||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang.NotImplementedException;
|
|
||||||
|
|
||||||
import com.metaweb.gridworks.importers.XmlImportUtilities.ImportColumnGroup;
|
import com.metaweb.gridworks.importers.XmlImportUtilities.ImportColumnGroup;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
|
|
||||||
@ -22,7 +20,7 @@ public class XmlImporter implements Importer {
|
|||||||
public void read(Reader reader, Project project, Properties options)
|
public void read(Reader reader, Project project, Properties options)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
|
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void read(
|
public void read(
|
||||||
|
@ -2,8 +2,6 @@ package com.metaweb.gridworks.model;
|
|||||||
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang.NotImplementedException;
|
|
||||||
|
|
||||||
import com.metaweb.gridworks.Jsonizable;
|
import com.metaweb.gridworks.Jsonizable;
|
||||||
import com.metaweb.gridworks.history.HistoryEntry;
|
import com.metaweb.gridworks.history.HistoryEntry;
|
||||||
import com.metaweb.gridworks.process.Process;
|
import com.metaweb.gridworks.process.Process;
|
||||||
@ -24,10 +22,10 @@ abstract public class AbstractOperation implements Jsonizable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected HistoryEntry createHistoryEntry(Project project, long historyEntryID) throws Exception {
|
protected HistoryEntry createHistoryEntry(Project project, long historyEntryID) throws Exception {
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String getBriefDescription(Project project) {
|
protected String getBriefDescription(Project project) {
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11,8 +11,6 @@ import org.json.JSONException;
|
|||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import sun.reflect.generics.reflectiveObjects.NotImplementedException;
|
|
||||||
|
|
||||||
import com.metaweb.gridworks.browsing.Engine;
|
import com.metaweb.gridworks.browsing.Engine;
|
||||||
import com.metaweb.gridworks.browsing.FilteredRows;
|
import com.metaweb.gridworks.browsing.FilteredRows;
|
||||||
import com.metaweb.gridworks.browsing.RowVisitor;
|
import com.metaweb.gridworks.browsing.RowVisitor;
|
||||||
@ -260,7 +258,7 @@ public class ColumnSplitOperation extends EngineDependentOperation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected List<Serializable> split(String s) {
|
protected List<Serializable> split(String s) {
|
||||||
throw new NotImplementedException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Serializable stringToValue(String s) {
|
protected Serializable stringToValue(String s) {
|
||||||
|
@ -29,9 +29,12 @@ import org.mortbay.util.Scanner;
|
|||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import com.metaweb.util.signal.AbstractSignalHandler;
|
|
||||||
import com.metaweb.util.threads.ThreadPoolExecutorAdapter;
|
import com.metaweb.util.threads.ThreadPoolExecutorAdapter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Main class for Gridworks server application. Starts an instance of the
|
||||||
|
* Jetty HTTP server / servlet container (inner class Gridworks Server).
|
||||||
|
*/
|
||||||
public class Gridworks {
|
public class Gridworks {
|
||||||
|
|
||||||
static private final String VERSION = "1.0";
|
static private final String VERSION = "1.0";
|
||||||
@ -113,7 +116,8 @@ public class Gridworks {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// hook up the signal handlers
|
// hook up the signal handlers
|
||||||
new ShutdownSignalHandler("TERM", server);
|
Runtime.getRuntime().addShutdownHook(
|
||||||
|
new Thread(new ShutdownSignalHandler(server)));
|
||||||
|
|
||||||
server.join();
|
server.join();
|
||||||
}
|
}
|
||||||
@ -300,18 +304,16 @@ class GridworksClient extends JFrame implements ActionListener {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class ShutdownSignalHandler extends AbstractSignalHandler {
|
class ShutdownSignalHandler implements Runnable {
|
||||||
|
|
||||||
private Server _server;
|
private Server _server;
|
||||||
|
|
||||||
public ShutdownSignalHandler(String sigName, Server server) {
|
public ShutdownSignalHandler(Server server) {
|
||||||
super(sigName);
|
|
||||||
this._server = server;
|
this._server = server;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean handle(String signame) {
|
@Override
|
||||||
|
public void run() {
|
||||||
//System.err.println("Received Signal: " + signame);
|
|
||||||
|
|
||||||
// Tell the server we want to try and shutdown gracefully
|
// Tell the server we want to try and shutdown gracefully
|
||||||
// this means that the server will stop accepting new connections
|
// this means that the server will stop accepting new connections
|
||||||
@ -327,8 +329,7 @@ class ShutdownSignalHandler extends AbstractSignalHandler {
|
|||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
System.exit(1);
|
System.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -1,20 +0,0 @@
|
|||||||
package com.metaweb.util.signal;
|
|
||||||
|
|
||||||
public abstract class AbstractSignalHandler {
|
|
||||||
|
|
||||||
public AbstractSignalHandler(final String signalName) {
|
|
||||||
try {
|
|
||||||
new SignalHandlerWrapper(signalName, this);
|
|
||||||
} catch (Throwable e) {
|
|
||||||
throw new java.lang.RuntimeException("Signal handling facilities are not available in this JVM.", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The method that handles the signal this handler has been registered for.
|
|
||||||
* If the method returns false or throws, the chain of invocation is stopped;
|
|
||||||
* this includes the handlers the JVM already registered for those signals.
|
|
||||||
*/
|
|
||||||
public abstract boolean handle(String signame);
|
|
||||||
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
package com.metaweb.util.signal;
|
|
||||||
|
|
||||||
import sun.misc.Signal;
|
|
||||||
import sun.misc.SignalHandler;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This class allows our own SignalHandler class to fail more gracefully
|
|
||||||
* in case the "sun.misc.Signal*" classes are not found in the current jvm.
|
|
||||||
*/
|
|
||||||
final class SignalHandlerWrapper implements SignalHandler {
|
|
||||||
|
|
||||||
private transient final SignalHandler existingHandler;
|
|
||||||
|
|
||||||
private transient final AbstractSignalHandler handler;
|
|
||||||
|
|
||||||
SignalHandlerWrapper(final String signalName, final AbstractSignalHandler handler) {
|
|
||||||
this.handler = handler;
|
|
||||||
final Signal signal = new Signal(signalName);
|
|
||||||
existingHandler = Signal.handle(signal, this);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void handle(final Signal sig) {
|
|
||||||
if (handler.handle(sig.getName()) && (existingHandler != null)) {
|
|
||||||
existingHandler.handle(sig);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user