/*******************************************************************************
* SAT4J: a SATisfiability library for Java Copyright (C) 2004-2008 Daniel Le Berre
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU Lesser General Public License Version 2.1 or later (the
* "LGPL"), in which case the provisions of the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of the LGPL, and not to allow others to use your version of
* this file under the terms of the EPL, indicate your decision by deleting
* the provisions above and replace them with the notice and other provisions
* required by the LGPL. If you do not delete the provisions above, a recipient
* may use your version of this file under the terms of the EPL or the LGPL.
*
* Based on the original MiniSat specification from:
*
* An extensible SAT solver. Niklas Een and Niklas Sorensson. Proceedings of the
* Sixth International Conference on Theory and Applications of Satisfiability
* Testing, LNCS 2919, pp 502-518, 2003.
*
* See www.minisat.se for the original solver in C++.
*
*******************************************************************************/
package org.sat4j.reader;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.URL;
import java.util.zip.GZIPInputStream;
import org.sat4j.specs.ContradictionException;
import org.sat4j.specs.IProblem;
/**
* A reader is responsible to feed an ISolver from a text file and to convert
* the model found by the solver to a textual representation.
*
* @author leberre
*/
public abstract class Reader {
public IProblem parseInstance(final String filename)
throws FileNotFoundException, ParseFormatException, IOException,
ContradictionException {
InputStream in = null;
try {
if (filename.startsWith("http://")) {
in = (new URL(filename)).openStream();
} else {
in = new FileInputStream(filename);
}
if (filename.endsWith(".gz")) {
in = new GZIPInputStream(in);
}
IProblem problem;
problem = parseInstance(in);
return problem;
} catch (FileNotFoundException e) {
throw e;
} catch (ParseFormatException e) {
throw e;
} catch (IOException e) {
throw e;
} catch (ContradictionException e) {
throw e;
} finally {
if (in != null) {
in.close();
}
}
}
public IProblem parseInstance(final InputStream in)
throws ParseFormatException, ContradictionException, IOException {
return parseInstance(new InputStreamReader(in));
}
public abstract IProblem parseInstance(final java.io.Reader in)
throws ParseFormatException, ContradictionException, IOException;
/**
* Produce a model using the reader format.
*
* @param model
* a model using the Dimacs format.
* @return a human readable view of the model.
*/
@Deprecated
public abstract String decode(int[] model);
/**
* Produce a model using the reader format on a provided printwriter.
*
* @param model
* a model using the Dimacs format.
* @param out
* the place where to display the model
*/
public abstract void decode(int[] model, PrintWriter out);
public boolean isVerbose() {
return verbose;
}
public void setVerbosity(boolean b) {
verbose = b;
}
private boolean verbose = false;
}