/* * ==================================================================== * Copyright (c) 2004-2011 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 java.util.HashMap; import java.util.Map; import org.tmatesoft.sqljet.core.schema.SqlJetConflictAction; import org.tmatesoft.svn.core.SVNException; import org.tmatesoft.svn.core.internal.db.SVNSqlJetDb; import org.tmatesoft.svn.core.internal.db.SVNSqlJetInsertStatement; import org.tmatesoft.svn.core.internal.db.SVNSqlJetStatement; import org.tmatesoft.svn.core.internal.wc17.db.statement.SVNWCDbSchema.NODES__Fields; /** * INSERT OR REPLACE INTO nodes ( wc_id, local_relpath, op_depth, * parent_relpath, repos_id, repos_path, revision, presence, depth, kind, * changed_revision, changed_date, changed_author, checksum, properties, * dav_cache, symlink_target, file_external ) VALUES (?1, ?2, 0, ?3, ?4, ?5, ?6, ?7, ?8, ?9, * ?10, ?11, ?12, ?13, ?14, ?15, ?16, ?17); * * @version 1.4 * @author TMate Software Ltd. */ public class SVNWCDbApplyChangesToBaseNode extends SVNSqlJetInsertStatement { public SVNWCDbApplyChangesToBaseNode(SVNSqlJetDb sDb) throws SVNException { super(sDb, SVNWCDbSchema.NODES, SqlJetConflictAction.REPLACE); } protected Map<String, Object> getInsertValues() throws SVNException { Map<String, Object> values = new HashMap<String, Object>(); values.put(SVNWCDbSchema.NODES__Fields.wc_id.toString(), getBind(1)); values.put(SVNWCDbSchema.NODES__Fields.local_relpath.toString(), getBind(2)); values.put(SVNWCDbSchema.NODES__Fields.op_depth.toString(), 0); values.put(SVNWCDbSchema.NODES__Fields.parent_relpath.toString(), getBind(3)); values.put(SVNWCDbSchema.NODES__Fields.repos_id.toString(), getBind(4)); values.put(SVNWCDbSchema.NODES__Fields.repos_path.toString(), getBind(5)); values.put(SVNWCDbSchema.NODES__Fields.revision.toString(), getBind(6)); values.put(SVNWCDbSchema.NODES__Fields.presence.toString(), getBind(7)); values.put(SVNWCDbSchema.NODES__Fields.depth.toString(), getBind(8)); values.put(SVNWCDbSchema.NODES__Fields.kind.toString(), getBind(9)); values.put(SVNWCDbSchema.NODES__Fields.changed_revision.toString(), getBind(10)); values.put(SVNWCDbSchema.NODES__Fields.changed_date.toString(), getBind(11)); values.put(SVNWCDbSchema.NODES__Fields.changed_author.toString(), getBind(12)); values.put(SVNWCDbSchema.NODES__Fields.checksum.toString(), getBind(13)); values.put(SVNWCDbSchema.NODES__Fields.properties.toString(), getBind(14)); values.put(SVNWCDbSchema.NODES__Fields.dav_cache.toString(), getBind(15)); values.put(SVNWCDbSchema.NODES__Fields.symlink_target.toString(), getBind(16)); SVNSqlJetStatement stmt = sDb.getStatement(SVNWCDbStatements.SELECT_BASE_NODE); try { stmt.bindf("is", getBind(1), getBind(2)); if (stmt.next() && !stmt.isColumnNull(NODES__Fields.file_external)) { values.put(SVNWCDbSchema.NODES__Fields.file_external.toString(), stmt.getColumn(NODES__Fields.file_external)); } } finally { if (stmt != null) { stmt.reset(); } } return values; } }