/* * ==================================================================== * 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.sqljet.core.SqlJetException; import org.tmatesoft.sqljet.core.table.ISqlJetCursor; import org.tmatesoft.svn.core.SVNException; import org.tmatesoft.svn.core.internal.db.SVNSqlJetDb; import org.tmatesoft.svn.core.internal.db.SVNSqlJetSelectStatement; /** * SELECT local_dir_relpath, locked_levels FROM wc_lock * WHERE wc_id = ?1 * AND ((local_dir_relpath <= ?2 AND local_dir_relpath >= ?3) * OR local_dir_relpath = '') * ORDER BY local_dir_relpath DESC */ public class SVNWCDbSelectAncestorWCLocks extends SVNSqlJetSelectStatement { public SVNWCDbSelectAncestorWCLocks(SVNSqlJetDb sDb) throws SVNException { super(sDb, SVNWCDbSchema.WC_LOCK); } @Override protected Object[] getWhere() throws SVNException { return new Object[] {getBind(1), getBind(2)}; } @Override protected ISqlJetCursor openCursor() throws SVNException { try { return getTable().scope(getIndexName(), null, getWhere()).reverse(); } catch (SqlJetException e) { SVNSqlJetDb.createSqlJetError(e); return null; } } }