package adql.db.exception; /* * This file is part of ADQLLibrary. * * ADQLLibrary is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * ADQLLibrary is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with ADQLLibrary. If not, see <http://www.gnu.org/licenses/>. * * Copyright 2012,2015 - UDS/Centre de DonnĂ©es astronomiques de Strasbourg (CDS), * Astronomisches Rechen Institut (ARI) */ import java.util.ArrayList; import java.util.Iterator; import adql.db.DBChecker; import adql.parser.ParseException; /** * <p> * This exception is thrown by {@link DBChecker} when several columns or tables do not exist. * It lists several {@link ParseException} (either {@link UnresolvedColumnException} or {@link UnresolvedTableException}). * </p> * <p> * Its message only tells the number of unresolved identifiers. * If you want to have more details about the position and the exact message of each exception, you just have to iterate * on this {@link UnresolvedIdentifiersException} (method {@link #iterator()}). * </p> * * @author Grégory Mantelet (CDS;ARI) * @version 1.4 (06/2015) * * @see DBChecker */ public class UnresolvedIdentifiersException extends ParseException implements Iterable<ParseException> { private static final long serialVersionUID = 1L; /** List of exceptions (one per unresolved identifier). */ protected ArrayList<ParseException> exceptions; private String unresolvedIdentifiers = null; /** * Build an empty {@link UnresolvedIdentifiersException} (that's to say: there is no unresolved identifier). */ public UnresolvedIdentifiersException(){ exceptions = new ArrayList<ParseException>(); } /** * Adds a {@link ParseException} (supposed to be either an {@link UnresolvedColumnException} or an {@link UnresolvedTableException}). * * @param pe An exception. */ public final void addException(final ParseException pe){ if (pe != null){ exceptions.add(pe); if (pe instanceof UnresolvedColumnException){ String colName = ((UnresolvedColumnException)pe).getColumnName(); if (colName != null && colName.trim().length() > 0) addIdentifierName(colName + " " + pe.getPosition()); }else if (pe instanceof UnresolvedTableException){ String tableName = ((UnresolvedTableException)pe).getTableName(); if (tableName != null && tableName.trim().length() > 0) addIdentifierName(tableName + " " + pe.getPosition()); }else if (pe instanceof UnresolvedFunctionException){ String fctName = (((UnresolvedFunctionException)pe).getFunction() == null) ? null : ((UnresolvedFunctionException)pe).getFunction().getName() + "(...)"; if (fctName != null && fctName.trim().length() > 0) addIdentifierName(fctName + " " + pe.getPosition()); }else if (pe instanceof UnresolvedIdentifiersException) addIdentifierName(((UnresolvedIdentifiersException)pe).unresolvedIdentifiers); } } /** * Adds the name (or the description) into the string list of all the unresolved identifiers. * * @param name Name (or description) of the identifier to add. */ private final void addIdentifierName(final String name){ if (name != null && name.trim().length() > 0){ if (unresolvedIdentifiers == null) unresolvedIdentifiers = ""; else unresolvedIdentifiers += ", "; unresolvedIdentifiers += name; } } /** * Gets the number of unresolved identifiers. * * @return The number of unresolved identifiers. */ public final int getNbErrors(){ return exceptions.size(); } /** * Gets the list of all errors. * * @return Errors list. */ public final Iterator<ParseException> getErrors(){ return exceptions.iterator(); } @Override public final Iterator<ParseException> iterator(){ return getErrors(); } /** * Only tells how many identifiers have not been resolved. * * @see java.lang.Throwable#getMessage() */ @Override public String getMessage(){ StringBuffer buf = new StringBuffer(); buf.append(exceptions.size()).append(" unresolved identifiers").append(((unresolvedIdentifiers != null) ? (": " + unresolvedIdentifiers) : "")).append('!'); for(ParseException pe : exceptions) buf.append("\n - ").append(pe.getMessage()); return buf.toString(); } }