/*
* ====================================================================
* Copyright (c) 2004-2010 TMate Software Ltd. All rights reserved.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
* are also available at http://svnkit.com/license.html.
* If newer versions of this license are posted there, you may use a
* newer version instead, at your option.
* ====================================================================
*/
package org.tmatesoft.svn.core.internal.wc17.db.statement;
import org.tmatesoft.svn.core.SVNException;
import org.tmatesoft.svn.core.internal.db.SVNSqlJetDb;
import org.tmatesoft.svn.core.internal.db.SVNSqlJetSelectFieldsStatement;
import org.tmatesoft.svn.core.internal.wc17.db.statement.SVNWCDbSchema.EXTERNALS__Fields;
/**
* SELECT local_relpath, def_local_relpath
* FROM externals
* WHERE wc_id = ?1
* AND (?2 = ''
* OR def_local_relpath = ?2
* OR (def_local_relpath > ?2 || '/' AND def_local_relpath < ?2 || '0'))
*
* @author TMate Software Ltd.
*/
public class SVNWCDBSelectExternalsDefined extends SVNSqlJetSelectFieldsStatement<SVNWCDbSchema.EXTERNALS__Fields> {
public SVNWCDBSelectExternalsDefined(SVNSqlJetDb sDb) throws SVNException {
super(sDb, SVNWCDbSchema.EXTERNALS);
}
protected void defineFields() {
fields.add(EXTERNALS__Fields.local_relpath);
fields.add(EXTERNALS__Fields.def_local_relpath);
}
@Override
protected boolean isFilterPassed() throws SVNException {
String selectPath = (String) getBind(2);
if ("".equals(selectPath)) {
return true;
}
String rowPath = getColumnString(EXTERNALS__Fields.def_local_relpath);
return (selectPath.equals(rowPath) || rowPath.startsWith(selectPath + "/"));
}
protected Object[] getWhere() throws SVNException {
return new Object[] {getBind(1)};
}
}