summaryrefslogtreecommitdiff
path: root/subversion/libsvn_wc/wc-queries.h
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2017-08-05 16:22:51 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2017-08-05 16:22:51 +0000
commitcf46733632c7279a9fd0fe6ce26f9185a4ae82a9 (patch)
treeda27775a2161723ef342e91af41a8b51fedef405 /subversion/libsvn_wc/wc-queries.h
parentbb0ef45f7c46b0ae221b26265ef98a768c33f820 (diff)
downloadsubversion-tarball-master.tar.gz
Diffstat (limited to 'subversion/libsvn_wc/wc-queries.h')
-rw-r--r--subversion/libsvn_wc/wc-queries.h1983
1 files changed, 1111 insertions, 872 deletions
diff --git a/subversion/libsvn_wc/wc-queries.h b/subversion/libsvn_wc/wc-queries.h
index e33af98..2a75940 100644
--- a/subversion/libsvn_wc/wc-queries.h
+++ b/subversion/libsvn_wc/wc-queries.h
@@ -1,4 +1,4 @@
-/* This file is automatically generated from wc-queries.sql and .dist_sandbox/subversion-1.8.13/subversion/libsvn_wc/token-map.h.
+/* This file is automatically generated from wc-queries.sql and .dist_sandbox/subversion-1.9.7/subversion/libsvn_wc/token-map.h.
* Do not edit this file -- edit the source and rerun gen-make.py */
#define STMT_SELECT_NODE_INFO 0
@@ -55,6 +55,15 @@
#define STMT_4_INFO {"STMT_SELECT_BASE_CHILDREN_INFO", NULL}
#define STMT_4 \
"SELECT local_relpath, nodes.repos_id, nodes.repos_path, presence, kind, " \
+ " revision, depth, file_external " \
+ "FROM nodes " \
+ "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \
+ ""
+
+#define STMT_SELECT_BASE_CHILDREN_INFO_LOCK 5
+#define STMT_5_INFO {"STMT_SELECT_BASE_CHILDREN_INFO_LOCK", NULL}
+#define STMT_5 \
+ "SELECT local_relpath, nodes.repos_id, nodes.repos_path, presence, kind, " \
" revision, depth, file_external, " \
" lock_token, lock_owner, lock_comment, lock_date " \
"FROM nodes " \
@@ -63,9 +72,9 @@
"WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_SELECT_WORKING_NODE 5
-#define STMT_5_INFO {"STMT_SELECT_WORKING_NODE", NULL}
-#define STMT_5 \
+#define STMT_SELECT_WORKING_NODE 6
+#define STMT_6_INFO {"STMT_SELECT_WORKING_NODE", NULL}
+#define STMT_6 \
"SELECT op_depth, presence, kind, checksum, translated_size, " \
" changed_revision, changed_date, changed_author, depth, symlink_target, " \
" repos_id, repos_path, revision, " \
@@ -76,19 +85,19 @@
"LIMIT 1 " \
""
-#define STMT_SELECT_DEPTH_NODE 6
-#define STMT_6_INFO {"STMT_SELECT_DEPTH_NODE", NULL}
-#define STMT_6 \
+#define STMT_SELECT_DEPTH_NODE 7
+#define STMT_7_INFO {"STMT_SELECT_DEPTH_NODE", NULL}
+#define STMT_7 \
"SELECT repos_id, repos_path, presence, kind, revision, checksum, " \
" translated_size, changed_revision, changed_date, changed_author, depth, " \
- " symlink_target, last_mod_time, properties " \
+ " symlink_target, properties, moved_to, moved_here " \
"FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
""
-#define STMT_SELECT_LOWEST_WORKING_NODE 7
-#define STMT_7_INFO {"STMT_SELECT_LOWEST_WORKING_NODE", NULL}
-#define STMT_7 \
+#define STMT_SELECT_LOWEST_WORKING_NODE 8
+#define STMT_8_INFO {"STMT_SELECT_LOWEST_WORKING_NODE", NULL}
+#define STMT_8 \
"SELECT op_depth, presence, kind, moved_to " \
"FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 " \
@@ -96,9 +105,9 @@
"LIMIT 1 " \
""
-#define STMT_SELECT_HIGHEST_WORKING_NODE 8
-#define STMT_8_INFO {"STMT_SELECT_HIGHEST_WORKING_NODE", NULL}
-#define STMT_8 \
+#define STMT_SELECT_HIGHEST_WORKING_NODE 9
+#define STMT_9_INFO {"STMT_SELECT_HIGHEST_WORKING_NODE", NULL}
+#define STMT_9 \
"SELECT op_depth " \
"FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth < ?3 " \
@@ -106,17 +115,17 @@
"LIMIT 1 " \
""
-#define STMT_SELECT_ACTUAL_NODE 9
-#define STMT_9_INFO {"STMT_SELECT_ACTUAL_NODE", NULL}
-#define STMT_9 \
+#define STMT_SELECT_ACTUAL_NODE 10
+#define STMT_10_INFO {"STMT_SELECT_ACTUAL_NODE", NULL}
+#define STMT_10 \
"SELECT changelist, properties, conflict_data " \
"FROM actual_node " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_SELECT_NODE_CHILDREN_INFO 10
-#define STMT_10_INFO {"STMT_SELECT_NODE_CHILDREN_INFO", NULL}
-#define STMT_10 \
+#define STMT_SELECT_NODE_CHILDREN_INFO 11
+#define STMT_11_INFO {"STMT_SELECT_NODE_CHILDREN_INFO", NULL}
+#define STMT_11 \
"SELECT op_depth, nodes.repos_id, nodes.repos_path, presence, kind, revision, " \
" checksum, translated_size, changed_revision, changed_date, changed_author, " \
" depth, symlink_target, last_mod_time, properties, lock_token, lock_owner, " \
@@ -125,51 +134,67 @@
"LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \
" AND nodes.repos_path = lock.repos_relpath AND op_depth = 0 " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
+ "ORDER BY local_relpath DESC, op_depth DESC " \
""
-#define STMT_SELECT_NODE_CHILDREN_WALKER_INFO 11
-#define STMT_11_INFO {"STMT_SELECT_NODE_CHILDREN_WALKER_INFO", NULL}
-#define STMT_11 \
+#define STMT_SELECT_BASE_NODE_CHILDREN_INFO 12
+#define STMT_12_INFO {"STMT_SELECT_BASE_NODE_CHILDREN_INFO", NULL}
+#define STMT_12 \
+ "SELECT op_depth, nodes.repos_id, nodes.repos_path, presence, kind, revision, " \
+ " checksum, translated_size, changed_revision, changed_date, changed_author, " \
+ " depth, symlink_target, last_mod_time, properties, lock_token, lock_owner, " \
+ " lock_comment, lock_date, local_relpath, moved_here, moved_to, file_external " \
+ "FROM nodes " \
+ "LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \
+ " AND nodes.repos_path = lock.repos_relpath AND op_depth = 0 " \
+ "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \
+ "ORDER BY local_relpath DESC " \
+ ""
+
+#define STMT_SELECT_NODE_CHILDREN_WALKER_INFO 13
+#define STMT_13_INFO {"STMT_SELECT_NODE_CHILDREN_WALKER_INFO", NULL}
+#define STMT_13 \
"SELECT local_relpath, op_depth, presence, kind " \
"FROM nodes_current " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
+ "ORDER BY local_relpath " \
""
-#define STMT_SELECT_ACTUAL_CHILDREN_INFO 12
-#define STMT_12_INFO {"STMT_SELECT_ACTUAL_CHILDREN_INFO", NULL}
-#define STMT_12 \
+#define STMT_SELECT_ACTUAL_CHILDREN_INFO 14
+#define STMT_14_INFO {"STMT_SELECT_ACTUAL_CHILDREN_INFO", NULL}
+#define STMT_14 \
"SELECT local_relpath, changelist, properties, conflict_data " \
"FROM actual_node " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
""
-#define STMT_SELECT_REPOSITORY_BY_ID 13
-#define STMT_13_INFO {"STMT_SELECT_REPOSITORY_BY_ID", NULL}
-#define STMT_13 \
+#define STMT_SELECT_REPOSITORY_BY_ID 15
+#define STMT_15_INFO {"STMT_SELECT_REPOSITORY_BY_ID", NULL}
+#define STMT_15 \
"SELECT root, uuid FROM repository WHERE id = ?1 " \
""
-#define STMT_SELECT_WCROOT_NULL 14
-#define STMT_14_INFO {"STMT_SELECT_WCROOT_NULL", NULL}
-#define STMT_14 \
+#define STMT_SELECT_WCROOT_NULL 16
+#define STMT_16_INFO {"STMT_SELECT_WCROOT_NULL", NULL}
+#define STMT_16 \
"SELECT id FROM wcroot WHERE local_abspath IS NULL " \
""
-#define STMT_SELECT_REPOSITORY 15
-#define STMT_15_INFO {"STMT_SELECT_REPOSITORY", NULL}
-#define STMT_15 \
+#define STMT_SELECT_REPOSITORY 17
+#define STMT_17_INFO {"STMT_SELECT_REPOSITORY", NULL}
+#define STMT_17 \
"SELECT id FROM repository WHERE root = ?1 " \
""
-#define STMT_INSERT_REPOSITORY 16
-#define STMT_16_INFO {"STMT_INSERT_REPOSITORY", NULL}
-#define STMT_16 \
+#define STMT_INSERT_REPOSITORY 18
+#define STMT_18_INFO {"STMT_INSERT_REPOSITORY", NULL}
+#define STMT_18 \
"INSERT INTO repository (root, uuid) VALUES (?1, ?2) " \
""
-#define STMT_INSERT_NODE 17
-#define STMT_17_INFO {"STMT_INSERT_NODE", NULL}
-#define STMT_17 \
+#define STMT_INSERT_NODE 19
+#define STMT_19_INFO {"STMT_INSERT_NODE", NULL}
+#define STMT_19 \
"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, " \
@@ -180,22 +205,9 @@
" ?15, ?16, ?17, ?18, ?19, ?20, ?21, ?22, ?23) " \
""
-#define STMT_SELECT_BASE_PRESENT 18
-#define STMT_18_INFO {"STMT_SELECT_BASE_PRESENT", NULL}
-#define STMT_18 \
- "SELECT local_relpath, kind FROM nodes n " \
- "WHERE wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND op_depth = 0 " \
- " AND presence in ('normal', 'incomplete') " \
- " AND NOT EXISTS(SELECT 1 FROM NODES w " \
- " WHERE w.wc_id = ?1 AND w.local_relpath = n.local_relpath " \
- " AND op_depth > 0) " \
- "ORDER BY local_relpath DESC " \
- ""
-
-#define STMT_SELECT_WORKING_PRESENT 19
-#define STMT_19_INFO {"STMT_SELECT_WORKING_PRESENT", NULL}
-#define STMT_19 \
+#define STMT_SELECT_WORKING_PRESENT 20
+#define STMT_20_INFO {"STMT_SELECT_WORKING_PRESENT", NULL}
+#define STMT_20 \
"SELECT local_relpath, kind, checksum, translated_size, last_mod_time " \
"FROM nodes n " \
"WHERE wc_id = ?1 " \
@@ -208,25 +220,25 @@
"ORDER BY local_relpath DESC " \
""
-#define STMT_DELETE_NODE_RECURSIVE 20
-#define STMT_20_INFO {"STMT_DELETE_NODE_RECURSIVE", NULL}
-#define STMT_20 \
+#define STMT_DELETE_NODE_RECURSIVE 21
+#define STMT_21_INFO {"STMT_DELETE_NODE_RECURSIVE", NULL}
+#define STMT_21 \
"DELETE FROM NODES " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_DELETE_NODE 21
-#define STMT_21_INFO {"STMT_DELETE_NODE", NULL}
-#define STMT_21 \
+#define STMT_DELETE_NODE 22
+#define STMT_22_INFO {"STMT_DELETE_NODE", NULL}
+#define STMT_22 \
"DELETE " \
"FROM NODES " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
""
-#define STMT_DELETE_ACTUAL_FOR_BASE_RECURSIVE 22
-#define STMT_22_INFO {"STMT_DELETE_ACTUAL_FOR_BASE_RECURSIVE", NULL}
-#define STMT_22 \
+#define STMT_DELETE_ACTUAL_FOR_BASE_RECURSIVE 23
+#define STMT_23_INFO {"STMT_DELETE_ACTUAL_FOR_BASE_RECURSIVE", NULL}
+#define STMT_23 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND EXISTS(SELECT 1 FROM NODES b " \
@@ -240,113 +252,161 @@
" AND presence in ('normal', 'incomplete', 'not-present')) " \
""
-#define STMT_DELETE_WORKING_BASE_DELETE 23
-#define STMT_23_INFO {"STMT_DELETE_WORKING_BASE_DELETE", NULL}
-#define STMT_23 \
+#define STMT_DELETE_WORKING_BASE_DELETE 24
+#define STMT_24_INFO {"STMT_DELETE_WORKING_BASE_DELETE", NULL}
+#define STMT_24 \
"DELETE FROM nodes " \
- "WHERE wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ "WHERE wc_id = ?1 AND local_relpath = ?2 " \
" AND presence = 'base-deleted' " \
- " AND op_depth > 0 " \
+ " AND op_depth > ?3 " \
" AND op_depth = (SELECT MIN(op_depth) FROM nodes n " \
" WHERE n.wc_id = ?1 " \
" AND n.local_relpath = nodes.local_relpath " \
- " AND op_depth > 0) " \
+ " AND op_depth > ?3) " \
""
-#define STMT_DELETE_WORKING_RECURSIVE 24
-#define STMT_24_INFO {"STMT_DELETE_WORKING_RECURSIVE", NULL}
-#define STMT_24 \
- "DELETE FROM nodes " \
- "WHERE wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND op_depth > 0 " \
- ""
-
-#define STMT_DELETE_BASE_RECURSIVE 25
-#define STMT_25_INFO {"STMT_DELETE_BASE_RECURSIVE", NULL}
+#define STMT_DELETE_WORKING_BASE_DELETE_RECURSIVE 25
+#define STMT_25_INFO {"STMT_DELETE_WORKING_BASE_DELETE_RECURSIVE", NULL}
#define STMT_25 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND op_depth = 0 " \
+ " AND presence = 'base-deleted' " \
+ " AND op_depth > ?3 " \
+ " AND op_depth = (SELECT MIN(op_depth) FROM nodes n " \
+ " WHERE n.wc_id = ?1 " \
+ " AND n.local_relpath = nodes.local_relpath " \
+ " AND op_depth > ?3) " \
""
-#define STMT_DELETE_WORKING_OP_DEPTH 26
-#define STMT_26_INFO {"STMT_DELETE_WORKING_OP_DEPTH", NULL}
+#define STMT_DELETE_WORKING_RECURSIVE 26
+#define STMT_26_INFO {"STMT_DELETE_WORKING_RECURSIVE", NULL}
#define STMT_26 \
"DELETE FROM nodes " \
- "WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND op_depth = ?3 " \
+ "WHERE wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ " AND op_depth > 0 " \
""
-#define STMT_DELETE_WORKING_OP_DEPTH_ABOVE 27
-#define STMT_27_INFO {"STMT_DELETE_WORKING_OP_DEPTH_ABOVE", NULL}
+#define STMT_DELETE_BASE_RECURSIVE 27
+#define STMT_27_INFO {"STMT_DELETE_BASE_RECURSIVE", NULL}
#define STMT_27 \
"DELETE FROM nodes " \
- "WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND op_depth > ?3 " \
+ "WHERE wc_id = ?1 AND (local_relpath = ?2 " \
+ " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
+ " AND op_depth = 0 " \
""
-#define STMT_SELECT_LOCAL_RELPATH_OP_DEPTH 28
-#define STMT_28_INFO {"STMT_SELECT_LOCAL_RELPATH_OP_DEPTH", NULL}
+#define STMT_DELETE_WORKING_OP_DEPTH 28
+#define STMT_28_INFO {"STMT_DELETE_WORKING_OP_DEPTH", NULL}
#define STMT_28 \
- "SELECT local_relpath " \
- "FROM nodes " \
+ "DELETE FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
" AND op_depth = ?3 " \
""
-#define STMT_SELECT_CHILDREN_OP_DEPTH 29
-#define STMT_29_INFO {"STMT_SELECT_CHILDREN_OP_DEPTH", NULL}
+#define STMT_SELECT_LAYER_FOR_REPLACE 29
+#define STMT_29_INFO {"STMT_SELECT_LAYER_FOR_REPLACE", NULL}
#define STMT_29 \
+ "SELECT s.local_relpath, s.kind, " \
+ " (CASE WHEN (?2) = '' THEN (CASE WHEN (?4) = '' THEN (s.local_relpath) WHEN (s.local_relpath) = '' THEN (?4) ELSE (?4) || '/' || (s.local_relpath) END) WHEN (?4) = '' THEN (CASE WHEN (?2) = '' THEN (s.local_relpath) WHEN SUBSTR((s.local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(s.local_relpath) THEN '' WHEN SUBSTR((s.local_relpath), LENGTH(?2)+1, 1) = '/' THEN SUBSTR((s.local_relpath), LENGTH(?2)+2) END END) WHEN SUBSTR((s.local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(s.local_relpath) THEN (?4) WHEN SUBSTR((s.local_relpath), LENGTH(?2)+1, 1) = '/' THEN (?4) || SUBSTR((s.local_relpath), LENGTH(?2)+1) END END) drp, 'normal' " \
+ "FROM nodes s " \
+ "WHERE s.wc_id = ?1 AND s.local_relpath = ?2 AND s.op_depth = ?3 " \
+ "UNION ALL " \
+ "SELECT s.local_relpath, s.kind, " \
+ " (CASE WHEN (?2) = '' THEN (CASE WHEN (?4) = '' THEN (s.local_relpath) WHEN (s.local_relpath) = '' THEN (?4) ELSE (?4) || '/' || (s.local_relpath) END) WHEN (?4) = '' THEN (CASE WHEN (?2) = '' THEN (s.local_relpath) WHEN SUBSTR((s.local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(s.local_relpath) THEN '' WHEN SUBSTR((s.local_relpath), LENGTH(?2)+1, 1) = '/' THEN SUBSTR((s.local_relpath), LENGTH(?2)+2) END END) WHEN SUBSTR((s.local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(s.local_relpath) THEN (?4) WHEN SUBSTR((s.local_relpath), LENGTH(?2)+1, 1) = '/' THEN (?4) || SUBSTR((s.local_relpath), LENGTH(?2)+1) END END) drp, d.presence " \
+ "FROM nodes s " \
+ "LEFT OUTER JOIN nodes d ON d.wc_id= ?1 AND d.op_depth = ?5 " \
+ " AND d.local_relpath = drp " \
+ "WHERE s.wc_id = ?1 " \
+ " AND (((s.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((s.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ " AND s.op_depth = ?3 " \
+ "ORDER BY s.local_relpath " \
+ ""
+
+#define STMT_SELECT_DESCENDANTS_OP_DEPTH_RV 30
+#define STMT_30_INFO {"STMT_SELECT_DESCENDANTS_OP_DEPTH_RV", NULL}
+#define STMT_30 \
"SELECT local_relpath, kind " \
"FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND op_depth = ?3 " \
+ " AND presence in ('normal', 'incomplete') " \
"ORDER BY local_relpath DESC " \
""
-#define STMT_COPY_NODE_MOVE 30
-#define STMT_30_INFO {"STMT_COPY_NODE_MOVE", NULL}
-#define STMT_30 \
+#define STMT_COPY_NODE_MOVE 31
+#define STMT_31_INFO {"STMT_COPY_NODE_MOVE", NULL}
+#define STMT_31 \
"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, translated_size, last_mod_time, " \
" symlink_target, moved_here, moved_to ) " \
"SELECT " \
- " wc_id, ?4 , ?5 , ?6 , " \
- " repos_id, " \
- " repos_path, revision, presence, depth, kind, changed_revision, " \
- " changed_date, changed_author, checksum, properties, translated_size, " \
- " last_mod_time, symlink_target, 1, " \
- " (SELECT dst.moved_to FROM nodes AS dst " \
- " WHERE dst.wc_id = ?1 " \
- " AND dst.local_relpath = ?4 " \
- " AND dst.op_depth = ?5) " \
- "FROM nodes " \
- "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
- ""
-
-#define STMT_SELECT_OP_DEPTH_CHILDREN 31
-#define STMT_31_INFO {"STMT_SELECT_OP_DEPTH_CHILDREN", NULL}
-#define STMT_31 \
+ " s.wc_id, ?4 , ?5 , ?6 , " \
+ " s.repos_id, " \
+ " s.repos_path, s.revision, s.presence, s.depth, s.kind, s.changed_revision, " \
+ " s.changed_date, s.changed_author, s.checksum, s.properties, " \
+ " CASE WHEN d.checksum=s.checksum THEN d.translated_size END, " \
+ " CASE WHEN d.checksum=s.checksum THEN d.last_mod_time END, " \
+ " s.symlink_target, 1, d.moved_to " \
+ "FROM nodes s " \
+ "LEFT JOIN nodes d ON d.wc_id=?1 AND d.local_relpath=?4 AND d.op_depth=?5 " \
+ "WHERE s.wc_id = ?1 AND s.local_relpath = ?2 AND s.op_depth = ?3 " \
+ ""
+
+#define STMT_SELECT_NO_LONGER_MOVED_RV 32
+#define STMT_32_INFO {"STMT_SELECT_NO_LONGER_MOVED_RV", NULL}
+#define STMT_32 \
+ "SELECT d.local_relpath, (CASE WHEN (?2) = '' THEN (CASE WHEN (?4) = '' THEN (d.local_relpath) WHEN (d.local_relpath) = '' THEN (?4) ELSE (?4) || '/' || (d.local_relpath) END) WHEN (?4) = '' THEN (CASE WHEN (?2) = '' THEN (d.local_relpath) WHEN SUBSTR((d.local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(d.local_relpath) THEN '' WHEN SUBSTR((d.local_relpath), LENGTH(?2)+1, 1) = '/' THEN SUBSTR((d.local_relpath), LENGTH(?2)+2) END END) WHEN SUBSTR((d.local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(d.local_relpath) THEN (?4) WHEN SUBSTR((d.local_relpath), LENGTH(?2)+1, 1) = '/' THEN (?4) || SUBSTR((d.local_relpath), LENGTH(?2)+1) END END) srp, " \
+ " b.presence, b.op_depth " \
+ "FROM nodes d " \
+ "LEFT OUTER JOIN nodes b ON b.wc_id = ?1 AND b.local_relpath = d.local_relpath " \
+ " AND b.op_depth = (SELECT MAX(x.op_depth) FROM nodes x " \
+ " WHERE x.wc_id = ?1 " \
+ " AND x.local_relpath = b.local_relpath " \
+ " AND x.op_depth < ?3) " \
+ "WHERE d.wc_id = ?1 " \
+ " AND (((d.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((d.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ " AND d.op_depth = ?3 " \
+ " AND NOT EXISTS(SELECT * FROM nodes s " \
+ " WHERE s.wc_id = ?1 " \
+ " AND s.local_relpath = srp " \
+ " AND s.op_depth = ?5) " \
+ "ORDER BY d.local_relpath DESC " \
+ ""
+
+#define STMT_SELECT_OP_DEPTH_CHILDREN 33
+#define STMT_33_INFO {"STMT_SELECT_OP_DEPTH_CHILDREN", NULL}
+#define STMT_33 \
"SELECT local_relpath, kind FROM nodes " \
"WHERE wc_id = ?1 " \
" AND parent_relpath = ?2 " \
" AND op_depth = ?3 " \
" AND presence != 'base-deleted' " \
" AND file_external is NULL " \
+ "ORDER BY local_relpath " \
""
-#define STMT_SELECT_GE_OP_DEPTH_CHILDREN 32
-#define STMT_32_INFO {"STMT_SELECT_GE_OP_DEPTH_CHILDREN", NULL}
-#define STMT_32 \
+#define STMT_SELECT_OP_DEPTH_CHILDREN_EXISTS 34
+#define STMT_34_INFO {"STMT_SELECT_OP_DEPTH_CHILDREN_EXISTS", NULL}
+#define STMT_34 \
+ "SELECT local_relpath, kind FROM nodes " \
+ "WHERE wc_id = ?1 " \
+ " AND parent_relpath = ?2 " \
+ " AND op_depth = ?3 " \
+ " AND presence IN ('normal', 'incomplete') " \
+ "ORDER BY local_relpath " \
+ ""
+
+#define STMT_SELECT_GE_OP_DEPTH_CHILDREN 35
+#define STMT_35_INFO {"STMT_SELECT_GE_OP_DEPTH_CHILDREN", NULL}
+#define STMT_35 \
"SELECT 1 FROM nodes " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
- " AND (op_depth > ?3 OR (op_depth = ?3 AND presence != 'base-deleted')) " \
+ " AND (op_depth > ?3 OR (op_depth = ?3 " \
+ " AND presence IN ('normal', 'incomplete'))) " \
"UNION ALL " \
"SELECT 1 FROM ACTUAL_NODE a " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
@@ -354,9 +414,9 @@
" WHERE wc_id = ?1 AND n.local_relpath = a.local_relpath) " \
""
-#define STMT_DELETE_SHADOWED_RECURSIVE 33
-#define STMT_33_INFO {"STMT_DELETE_SHADOWED_RECURSIVE", NULL}
-#define STMT_33 \
+#define STMT_DELETE_SHADOWED_RECURSIVE 36
+#define STMT_36_INFO {"STMT_DELETE_SHADOWED_RECURSIVE", NULL}
+#define STMT_36 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
@@ -364,32 +424,33 @@
" OR (op_depth = ?3 AND presence = 'base-deleted')) " \
""
-#define STMT_CLEAR_MOVED_TO_FROM_DEST 34
-#define STMT_34_INFO {"STMT_CLEAR_MOVED_TO_FROM_DEST", NULL}
-#define STMT_34 \
+#define STMT_CLEAR_MOVED_TO_FROM_DEST 37
+#define STMT_37_INFO {"STMT_CLEAR_MOVED_TO_FROM_DEST", NULL}
+#define STMT_37 \
"UPDATE NODES SET moved_to = NULL " \
"WHERE wc_id = ?1 " \
" AND moved_to = ?2 " \
""
-#define STMT_SELECT_NOT_PRESENT_DESCENDANTS 35
-#define STMT_35_INFO {"STMT_SELECT_NOT_PRESENT_DESCENDANTS", NULL}
-#define STMT_35 \
+#define STMT_SELECT_NOT_PRESENT_DESCENDANTS 38
+#define STMT_38_INFO {"STMT_SELECT_NOT_PRESENT_DESCENDANTS", NULL}
+#define STMT_38 \
"SELECT local_relpath FROM nodes " \
"WHERE wc_id = ?1 AND op_depth = ?3 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND presence = 'not-present' " \
""
-#define STMT_COMMIT_DESCENDANTS_TO_BASE 36
-#define STMT_36_INFO {"STMT_COMMIT_DESCENDANTS_TO_BASE", NULL}
-#define STMT_36 \
+#define STMT_COMMIT_DESCENDANTS_TO_BASE 39
+#define STMT_39_INFO {"STMT_COMMIT_DESCENDANTS_TO_BASE", NULL}
+#define STMT_39 \
"UPDATE NODES SET op_depth = 0, " \
" repos_id = ?4, " \
- " repos_path = ?5 || SUBSTR(local_relpath, LENGTH(?2)+1), " \
+ " repos_path = (CASE WHEN (?2) = '' THEN (CASE WHEN (?5) = '' THEN (local_relpath) WHEN (local_relpath) = '' THEN (?5) ELSE (?5) || '/' || (local_relpath) END) WHEN (?5) = '' THEN (CASE WHEN (?2) = '' THEN (local_relpath) WHEN SUBSTR((local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(local_relpath) THEN '' WHEN SUBSTR((local_relpath), LENGTH(?2)+1, 1) = '/' THEN SUBSTR((local_relpath), LENGTH(?2)+2) END END) WHEN SUBSTR((local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(local_relpath) THEN (?5) WHEN SUBSTR((local_relpath), LENGTH(?2)+1, 1) = '/' THEN (?5) || SUBSTR((local_relpath), LENGTH(?2)+1) END END), " \
" revision = ?6, " \
" dav_cache = NULL, " \
" moved_here = NULL, " \
+ " moved_to = NULL, " \
" presence = CASE presence " \
" WHEN 'normal' THEN 'normal' " \
" WHEN 'excluded' THEN 'excluded' " \
@@ -400,67 +461,78 @@
" AND op_depth = ?3 " \
""
-#define STMT_SELECT_NODE_CHILDREN 37
-#define STMT_37_INFO {"STMT_SELECT_NODE_CHILDREN", NULL}
-#define STMT_37 \
- "SELECT local_relpath FROM nodes " \
+#define STMT_SELECT_NODE_CHILDREN 40
+#define STMT_40_INFO {"STMT_SELECT_NODE_CHILDREN", NULL}
+#define STMT_40 \
+ "SELECT DISTINCT local_relpath FROM nodes " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
+ "ORDER BY local_relpath " \
""
-#define STMT_SELECT_WORKING_CHILDREN 38
-#define STMT_38_INFO {"STMT_SELECT_WORKING_CHILDREN", NULL}
-#define STMT_38 \
- "SELECT local_relpath FROM nodes " \
+#define STMT_SELECT_WORKING_CHILDREN 41
+#define STMT_41_INFO {"STMT_SELECT_WORKING_CHILDREN", NULL}
+#define STMT_41 \
+ "SELECT DISTINCT local_relpath FROM nodes " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
" AND (op_depth > (SELECT MAX(op_depth) FROM nodes " \
" WHERE wc_id = ?1 AND local_relpath = ?2) " \
" OR " \
" (op_depth = (SELECT MAX(op_depth) FROM nodes " \
" WHERE wc_id = ?1 AND local_relpath = ?2) " \
- " AND presence != 'base-deleted')) " \
+ " AND presence IN ('normal', 'incomplete'))) " \
+ "ORDER BY local_relpath " \
""
-#define STMT_SELECT_NODE_PROPS 39
-#define STMT_39_INFO {"STMT_SELECT_NODE_PROPS", NULL}
-#define STMT_39 \
+#define STMT_SELECT_BASE_NOT_PRESENT_CHILDREN 42
+#define STMT_42_INFO {"STMT_SELECT_BASE_NOT_PRESENT_CHILDREN", NULL}
+#define STMT_42 \
+ "SELECT local_relpath FROM nodes " \
+ "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \
+ " AND presence = 'not-present' " \
+ "ORDER BY local_relpath " \
+ ""
+
+#define STMT_SELECT_NODE_PROPS 43
+#define STMT_43_INFO {"STMT_SELECT_NODE_PROPS", NULL}
+#define STMT_43 \
"SELECT properties, presence FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
"ORDER BY op_depth DESC " \
""
-#define STMT_SELECT_ACTUAL_PROPS 40
-#define STMT_40_INFO {"STMT_SELECT_ACTUAL_PROPS", NULL}
-#define STMT_40 \
+#define STMT_SELECT_ACTUAL_PROPS 44
+#define STMT_44_INFO {"STMT_SELECT_ACTUAL_PROPS", NULL}
+#define STMT_44 \
"SELECT properties FROM actual_node " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_UPDATE_ACTUAL_PROPS 41
-#define STMT_41_INFO {"STMT_UPDATE_ACTUAL_PROPS", NULL}
-#define STMT_41 \
+#define STMT_UPDATE_ACTUAL_PROPS 45
+#define STMT_45_INFO {"STMT_UPDATE_ACTUAL_PROPS", NULL}
+#define STMT_45 \
"UPDATE actual_node SET properties = ?3 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_INSERT_ACTUAL_PROPS 42
-#define STMT_42_INFO {"STMT_INSERT_ACTUAL_PROPS", NULL}
-#define STMT_42 \
+#define STMT_INSERT_ACTUAL_PROPS 46
+#define STMT_46_INFO {"STMT_INSERT_ACTUAL_PROPS", NULL}
+#define STMT_46 \
"INSERT INTO actual_node (wc_id, local_relpath, parent_relpath, properties) " \
"VALUES (?1, ?2, ?3, ?4) " \
""
-#define STMT_INSERT_LOCK 43
-#define STMT_43_INFO {"STMT_INSERT_LOCK", NULL}
-#define STMT_43 \
+#define STMT_INSERT_LOCK 47
+#define STMT_47_INFO {"STMT_INSERT_LOCK", NULL}
+#define STMT_47 \
"INSERT OR REPLACE INTO lock " \
"(repos_id, repos_relpath, lock_token, lock_owner, lock_comment, " \
" lock_date) " \
"VALUES (?1, ?2, ?3, ?4, ?5, ?6) " \
""
-#define STMT_SELECT_BASE_NODE_LOCK_TOKENS_RECURSIVE 44
-#define STMT_44_INFO {"STMT_SELECT_BASE_NODE_LOCK_TOKENS_RECURSIVE", NULL}
-#define STMT_44 \
+#define STMT_SELECT_BASE_NODE_LOCK_TOKENS_RECURSIVE 48
+#define STMT_48_INFO {"STMT_SELECT_BASE_NODE_LOCK_TOKENS_RECURSIVE", NULL}
+#define STMT_48 \
"SELECT nodes.repos_id, nodes.repos_path, lock_token " \
"FROM nodes " \
"LEFT JOIN lock ON nodes.repos_id = lock.repos_id " \
@@ -469,93 +541,73 @@
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_INSERT_WCROOT 45
-#define STMT_45_INFO {"STMT_INSERT_WCROOT", NULL}
-#define STMT_45 \
+#define STMT_INSERT_WCROOT 49
+#define STMT_49_INFO {"STMT_INSERT_WCROOT", NULL}
+#define STMT_49 \
"INSERT INTO wcroot (local_abspath) " \
"VALUES (?1) " \
""
-#define STMT_UPDATE_BASE_NODE_DAV_CACHE 46
-#define STMT_46_INFO {"STMT_UPDATE_BASE_NODE_DAV_CACHE", NULL}
-#define STMT_46 \
+#define STMT_UPDATE_BASE_NODE_DAV_CACHE 50
+#define STMT_50_INFO {"STMT_UPDATE_BASE_NODE_DAV_CACHE", NULL}
+#define STMT_50 \
"UPDATE nodes SET dav_cache = ?3 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_SELECT_BASE_DAV_CACHE 47
-#define STMT_47_INFO {"STMT_SELECT_BASE_DAV_CACHE", NULL}
-#define STMT_47 \
+#define STMT_SELECT_BASE_DAV_CACHE 51
+#define STMT_51_INFO {"STMT_SELECT_BASE_DAV_CACHE", NULL}
+#define STMT_51 \
"SELECT dav_cache FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_SELECT_DELETION_INFO 48
-#define STMT_48_INFO {"STMT_SELECT_DELETION_INFO", NULL}
-#define STMT_48 \
- "SELECT (SELECT b.presence FROM nodes AS b " \
- " WHERE b.wc_id = ?1 AND b.local_relpath = ?2 AND b.op_depth = 0), " \
- " work.presence, work.op_depth " \
- "FROM nodes_current AS work " \
- "WHERE work.wc_id = ?1 AND work.local_relpath = ?2 AND work.op_depth > 0 " \
- "LIMIT 1 " \
- ""
-
-#define STMT_SELECT_DELETION_INFO_SCAN 49
-#define STMT_49_INFO {"STMT_SELECT_DELETION_INFO_SCAN", NULL}
-#define STMT_49 \
- "SELECT (SELECT b.presence FROM nodes AS b " \
- " WHERE b.wc_id = ?1 AND b.local_relpath = ?2 AND b.op_depth = 0), " \
- " work.presence, work.op_depth, moved.moved_to " \
- "FROM nodes_current AS work " \
- "LEFT OUTER JOIN nodes AS moved " \
- " ON moved.wc_id = work.wc_id " \
- " AND moved.local_relpath = work.local_relpath " \
- " AND moved.moved_to IS NOT NULL " \
- "WHERE work.wc_id = ?1 AND work.local_relpath = ?2 AND work.op_depth > 0 " \
+#define STMT_SELECT_DELETION_INFO 52
+#define STMT_52_INFO {"STMT_SELECT_DELETION_INFO", NULL}
+#define STMT_52 \
+ "SELECT b.presence, w.presence, w.op_depth, w.moved_to " \
+ "FROM nodes w " \
+ "LEFT JOIN nodes b ON b.wc_id = ?1 AND b.local_relpath = ?2 AND b.op_depth = 0 " \
+ "WHERE w.wc_id = ?1 AND w.local_relpath = ?2 " \
+ " AND w.op_depth = (SELECT MAX(op_depth) FROM nodes d " \
+ " WHERE d.wc_id = ?1 AND d.local_relpath = ?2 " \
+ " AND d.op_depth > 0) " \
"LIMIT 1 " \
""
-#define STMT_SELECT_MOVED_TO_NODE 50
-#define STMT_50_INFO {"STMT_SELECT_MOVED_TO_NODE", NULL}
-#define STMT_50 \
+#define STMT_SELECT_MOVED_TO_NODE 53
+#define STMT_53_INFO {"STMT_SELECT_MOVED_TO_NODE", NULL}
+#define STMT_53 \
"SELECT op_depth, moved_to " \
"FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND moved_to IS NOT NULL " \
"ORDER BY op_depth DESC " \
""
-#define STMT_SELECT_OP_DEPTH_MOVED_TO 51
-#define STMT_51_INFO {"STMT_SELECT_OP_DEPTH_MOVED_TO", NULL}
-#define STMT_51 \
- "SELECT op_depth, moved_to, repos_path, revision " \
+#define STMT_SELECT_OP_DEPTH_MOVED_TO 54
+#define STMT_54_INFO {"STMT_SELECT_OP_DEPTH_MOVED_TO", NULL}
+#define STMT_54 \
+ "SELECT op_depth, moved_to " \
"FROM nodes " \
- "WHERE wc_id = ?1 AND local_relpath = ?2 " \
- " AND op_depth <= (SELECT MIN(op_depth) FROM nodes " \
- " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3) " \
- "ORDER BY op_depth DESC " \
+ "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 " \
+ " AND EXISTS(SELECT * from nodes " \
+ " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
+ " AND presence IN ('normal', 'incomplete')) " \
+ "ORDER BY op_depth ASC " \
+ "LIMIT 1 " \
""
-#define STMT_SELECT_MOVED_TO 52
-#define STMT_52_INFO {"STMT_SELECT_MOVED_TO", NULL}
-#define STMT_52 \
+#define STMT_SELECT_MOVED_TO 55
+#define STMT_55_INFO {"STMT_SELECT_MOVED_TO", NULL}
+#define STMT_55 \
"SELECT moved_to " \
"FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
""
-#define STMT_SELECT_MOVED_HERE 53
-#define STMT_53_INFO {"STMT_SELECT_MOVED_HERE", NULL}
-#define STMT_53 \
- "SELECT moved_here, presence, repos_path, revision " \
- "FROM nodes " \
- "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth >= ?3 " \
- "ORDER BY op_depth " \
- ""
-
-#define STMT_SELECT_MOVED_BACK 54
-#define STMT_54_INFO {"STMT_SELECT_MOVED_BACK", NULL}
-#define STMT_54 \
+#define STMT_SELECT_MOVED_BACK 56
+#define STMT_56_INFO {"STMT_SELECT_MOVED_BACK", NULL}
+#define STMT_56 \
"SELECT u.local_relpath, " \
" u.presence, u.repos_id, u.repos_path, u.revision, " \
" l.presence, l.repos_id, l.repos_path, l.revision, " \
@@ -581,81 +633,71 @@
" AND u.op_depth = ?4 " \
""
-#define STMT_DELETE_MOVED_BACK 55
-#define STMT_55_INFO {"STMT_DELETE_MOVED_BACK", NULL}
-#define STMT_55 \
- "DELETE FROM nodes " \
- "WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 " \
- " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND op_depth = ?3 " \
- ""
-
-#define STMT_DELETE_LOCK 56
-#define STMT_56_INFO {"STMT_DELETE_LOCK", NULL}
-#define STMT_56 \
+#define STMT_DELETE_LOCK 57
+#define STMT_57_INFO {"STMT_DELETE_LOCK", NULL}
+#define STMT_57 \
"DELETE FROM lock " \
"WHERE repos_id = ?1 AND repos_relpath = ?2 " \
""
-#define STMT_DELETE_LOCK_RECURSIVELY 57
-#define STMT_57_INFO {"STMT_DELETE_LOCK_RECURSIVELY", NULL}
-#define STMT_57 \
+#define STMT_DELETE_LOCK_RECURSIVELY 58
+#define STMT_58_INFO {"STMT_DELETE_LOCK_RECURSIVELY", NULL}
+#define STMT_58 \
"DELETE FROM lock " \
"WHERE repos_id = ?1 AND (repos_relpath = ?2 OR (((repos_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((repos_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
""
-#define STMT_CLEAR_BASE_NODE_RECURSIVE_DAV_CACHE 58
-#define STMT_58_INFO {"STMT_CLEAR_BASE_NODE_RECURSIVE_DAV_CACHE", NULL}
-#define STMT_58 \
+#define STMT_CLEAR_BASE_NODE_RECURSIVE_DAV_CACHE 59
+#define STMT_59_INFO {"STMT_CLEAR_BASE_NODE_RECURSIVE_DAV_CACHE", NULL}
+#define STMT_59 \
"UPDATE nodes SET dav_cache = NULL " \
"WHERE dav_cache IS NOT NULL AND wc_id = ?1 AND op_depth = 0 " \
" AND (local_relpath = ?2 " \
" OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
""
-#define STMT_RECURSIVE_UPDATE_NODE_REPO 59
-#define STMT_59_INFO {"STMT_RECURSIVE_UPDATE_NODE_REPO", NULL}
-#define STMT_59 \
+#define STMT_RECURSIVE_UPDATE_NODE_REPO 60
+#define STMT_60_INFO {"STMT_RECURSIVE_UPDATE_NODE_REPO", NULL}
+#define STMT_60 \
"UPDATE nodes SET repos_id = ?4, dav_cache = NULL " \
"WHERE (wc_id = ?1 AND local_relpath = ?2 AND repos_id = ?3) " \
" OR (wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND repos_id = ?3) " \
""
-#define STMT_UPDATE_LOCK_REPOS_ID 60
-#define STMT_60_INFO {"STMT_UPDATE_LOCK_REPOS_ID", NULL}
-#define STMT_60 \
+#define STMT_UPDATE_LOCK_REPOS_ID 61
+#define STMT_61_INFO {"STMT_UPDATE_LOCK_REPOS_ID", NULL}
+#define STMT_61 \
"UPDATE lock SET repos_id = ?2 " \
"WHERE repos_id = ?1 " \
""
-#define STMT_UPDATE_NODE_FILEINFO 61
-#define STMT_61_INFO {"STMT_UPDATE_NODE_FILEINFO", NULL}
-#define STMT_61 \
+#define STMT_UPDATE_NODE_FILEINFO 62
+#define STMT_62_INFO {"STMT_UPDATE_NODE_FILEINFO", NULL}
+#define STMT_62 \
"UPDATE nodes SET translated_size = ?3, last_mod_time = ?4 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
" AND op_depth = (SELECT MAX(op_depth) FROM nodes " \
" WHERE wc_id = ?1 AND local_relpath = ?2) " \
""
-#define STMT_INSERT_ACTUAL_CONFLICT 62
-#define STMT_62_INFO {"STMT_INSERT_ACTUAL_CONFLICT", NULL}
-#define STMT_62 \
+#define STMT_INSERT_ACTUAL_CONFLICT 63
+#define STMT_63_INFO {"STMT_INSERT_ACTUAL_CONFLICT", NULL}
+#define STMT_63 \
"INSERT INTO actual_node (wc_id, local_relpath, conflict_data, parent_relpath) " \
"VALUES (?1, ?2, ?3, ?4) " \
""
-#define STMT_UPDATE_ACTUAL_CONFLICT 63
-#define STMT_63_INFO {"STMT_UPDATE_ACTUAL_CONFLICT", NULL}
-#define STMT_63 \
+#define STMT_UPDATE_ACTUAL_CONFLICT 64
+#define STMT_64_INFO {"STMT_UPDATE_ACTUAL_CONFLICT", NULL}
+#define STMT_64 \
"UPDATE actual_node SET conflict_data = ?3 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_UPDATE_ACTUAL_CHANGELISTS 64
-#define STMT_64_INFO {"STMT_UPDATE_ACTUAL_CHANGELISTS", NULL}
-#define STMT_64 \
+#define STMT_UPDATE_ACTUAL_CHANGELISTS 65
+#define STMT_65_INFO {"STMT_UPDATE_ACTUAL_CHANGELISTS", NULL}
+#define STMT_65 \
"UPDATE actual_node SET changelist = ?3 " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
@@ -665,16 +707,16 @@
" AND kind = 'file') " \
""
-#define STMT_UPDATE_ACTUAL_CLEAR_CHANGELIST 65
-#define STMT_65_INFO {"STMT_UPDATE_ACTUAL_CLEAR_CHANGELIST", NULL}
-#define STMT_65 \
+#define STMT_UPDATE_ACTUAL_CLEAR_CHANGELIST 66
+#define STMT_66_INFO {"STMT_UPDATE_ACTUAL_CLEAR_CHANGELIST", NULL}
+#define STMT_66 \
"UPDATE actual_node SET changelist = NULL " \
" WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_MARK_SKIPPED_CHANGELIST_DIRS 66
-#define STMT_66_INFO {"STMT_MARK_SKIPPED_CHANGELIST_DIRS", NULL}
-#define STMT_66 \
+#define STMT_MARK_SKIPPED_CHANGELIST_DIRS 67
+#define STMT_67_INFO {"STMT_MARK_SKIPPED_CHANGELIST_DIRS", NULL}
+#define STMT_67 \
"INSERT INTO changelist_list (wc_id, local_relpath, notify, changelist) " \
"SELECT wc_id, local_relpath, 7, ?3 " \
"FROM targets_list " \
@@ -683,17 +725,17 @@
" AND kind = 'dir' " \
""
-#define STMT_RESET_ACTUAL_WITH_CHANGELIST 67
-#define STMT_67_INFO {"STMT_RESET_ACTUAL_WITH_CHANGELIST", NULL}
-#define STMT_67 \
+#define STMT_RESET_ACTUAL_WITH_CHANGELIST 68
+#define STMT_68_INFO {"STMT_RESET_ACTUAL_WITH_CHANGELIST", NULL}
+#define STMT_68 \
"REPLACE INTO actual_node ( " \
" wc_id, local_relpath, parent_relpath, changelist) " \
"VALUES (?1, ?2, ?3, ?4) " \
""
-#define STMT_CREATE_CHANGELIST_LIST 68
-#define STMT_68_INFO {"STMT_CREATE_CHANGELIST_LIST", NULL}
-#define STMT_68 \
+#define STMT_CREATE_CHANGELIST_LIST 69
+#define STMT_69_INFO {"STMT_CREATE_CHANGELIST_LIST", NULL}
+#define STMT_69 \
"DROP TABLE IF EXISTS changelist_list; " \
"CREATE TEMPORARY TABLE changelist_list ( " \
" wc_id INTEGER NOT NULL, " \
@@ -704,9 +746,9 @@
") " \
""
-#define STMT_CREATE_CHANGELIST_TRIGGER 69
-#define STMT_69_INFO {"STMT_CREATE_CHANGELIST_TRIGGER", NULL}
-#define STMT_69 \
+#define STMT_CREATE_CHANGELIST_TRIGGER 70
+#define STMT_70_INFO {"STMT_CREATE_CHANGELIST_TRIGGER", NULL}
+#define STMT_70 \
"DROP TRIGGER IF EXISTS trigger_changelist_list_change; " \
"CREATE TEMPORARY TRIGGER trigger_changelist_list_change " \
"BEFORE UPDATE ON actual_node " \
@@ -721,25 +763,25 @@
"END " \
""
-#define STMT_FINALIZE_CHANGELIST 70
-#define STMT_70_INFO {"STMT_FINALIZE_CHANGELIST", NULL}
-#define STMT_70 \
+#define STMT_FINALIZE_CHANGELIST 71
+#define STMT_71_INFO {"STMT_FINALIZE_CHANGELIST", NULL}
+#define STMT_71 \
"DROP TRIGGER trigger_changelist_list_change; " \
"DROP TABLE changelist_list; " \
"DROP TABLE targets_list " \
""
-#define STMT_SELECT_CHANGELIST_LIST 71
-#define STMT_71_INFO {"STMT_SELECT_CHANGELIST_LIST", NULL}
-#define STMT_71 \
+#define STMT_SELECT_CHANGELIST_LIST 72
+#define STMT_72_INFO {"STMT_SELECT_CHANGELIST_LIST", NULL}
+#define STMT_72 \
"SELECT wc_id, local_relpath, notify, changelist " \
"FROM changelist_list " \
"ORDER BY wc_id, local_relpath ASC, notify DESC " \
""
-#define STMT_CREATE_TARGETS_LIST 72
-#define STMT_72_INFO {"STMT_CREATE_TARGETS_LIST", NULL}
-#define STMT_72 \
+#define STMT_CREATE_TARGETS_LIST 73
+#define STMT_73_INFO {"STMT_CREATE_TARGETS_LIST", NULL}
+#define STMT_73 \
"DROP TABLE IF EXISTS targets_list; " \
"CREATE TEMPORARY TABLE targets_list ( " \
" wc_id INTEGER NOT NULL, " \
@@ -750,15 +792,15 @@
" ); " \
""
-#define STMT_DROP_TARGETS_LIST 73
-#define STMT_73_INFO {"STMT_DROP_TARGETS_LIST", NULL}
-#define STMT_73 \
+#define STMT_DROP_TARGETS_LIST 74
+#define STMT_74_INFO {"STMT_DROP_TARGETS_LIST", NULL}
+#define STMT_74 \
"DROP TABLE targets_list " \
""
-#define STMT_INSERT_TARGET 74
-#define STMT_74_INFO {"STMT_INSERT_TARGET", NULL}
-#define STMT_74 \
+#define STMT_INSERT_TARGET 75
+#define STMT_75_INFO {"STMT_INSERT_TARGET", NULL}
+#define STMT_75 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT wc_id, local_relpath, parent_relpath, kind " \
"FROM nodes_current " \
@@ -766,9 +808,9 @@
" AND local_relpath = ?2 " \
""
-#define STMT_INSERT_TARGET_DEPTH_FILES 75
-#define STMT_75_INFO {"STMT_INSERT_TARGET_DEPTH_FILES", NULL}
-#define STMT_75 \
+#define STMT_INSERT_TARGET_DEPTH_FILES 76
+#define STMT_76_INFO {"STMT_INSERT_TARGET_DEPTH_FILES", NULL}
+#define STMT_76 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT wc_id, local_relpath, parent_relpath, kind " \
"FROM nodes_current " \
@@ -777,9 +819,9 @@
" AND kind = 'file' " \
""
-#define STMT_INSERT_TARGET_DEPTH_IMMEDIATES 76
-#define STMT_76_INFO {"STMT_INSERT_TARGET_DEPTH_IMMEDIATES", NULL}
-#define STMT_76 \
+#define STMT_INSERT_TARGET_DEPTH_IMMEDIATES 77
+#define STMT_77_INFO {"STMT_INSERT_TARGET_DEPTH_IMMEDIATES", NULL}
+#define STMT_77 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT wc_id, local_relpath, parent_relpath, kind " \
"FROM nodes_current " \
@@ -787,9 +829,9 @@
" AND parent_relpath = ?2 " \
""
-#define STMT_INSERT_TARGET_DEPTH_INFINITY 77
-#define STMT_77_INFO {"STMT_INSERT_TARGET_DEPTH_INFINITY", NULL}
-#define STMT_77 \
+#define STMT_INSERT_TARGET_DEPTH_INFINITY 78
+#define STMT_78_INFO {"STMT_INSERT_TARGET_DEPTH_INFINITY", NULL}
+#define STMT_78 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT wc_id, local_relpath, parent_relpath, kind " \
"FROM nodes_current " \
@@ -797,9 +839,9 @@
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_INSERT_TARGET_WITH_CHANGELIST 78
-#define STMT_78_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST", NULL}
-#define STMT_78 \
+#define STMT_INSERT_TARGET_WITH_CHANGELIST 79
+#define STMT_79_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST", NULL}
+#define STMT_79 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \
" FROM actual_node AS A JOIN nodes_current AS N " \
@@ -809,9 +851,9 @@
" AND A.changelist = ?3 " \
""
-#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_FILES 79
-#define STMT_79_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_FILES", NULL}
-#define STMT_79 \
+#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_FILES 80
+#define STMT_80_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_FILES", NULL}
+#define STMT_80 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \
" FROM actual_node AS A JOIN nodes_current AS N " \
@@ -822,9 +864,9 @@
" AND A.changelist = ?3 " \
""
-#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_IMMEDIATES 80
-#define STMT_80_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_IMMEDIATES", NULL}
-#define STMT_80 \
+#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_IMMEDIATES 81
+#define STMT_81_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_IMMEDIATES", NULL}
+#define STMT_81 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \
" FROM actual_node AS A JOIN nodes_current AS N " \
@@ -834,9 +876,9 @@
" AND A.changelist = ?3 " \
""
-#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_INFINITY 81
-#define STMT_81_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_INFINITY", NULL}
-#define STMT_81 \
+#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_INFINITY 82
+#define STMT_82_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_INFINITY", NULL}
+#define STMT_82 \
"INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \
"SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \
" FROM actual_node AS A JOIN nodes_current AS N " \
@@ -846,18 +888,28 @@
" AND A.changelist = ?3 " \
""
-#define STMT_INSERT_ACTUAL_EMPTIES 82
-#define STMT_82_INFO {"STMT_INSERT_ACTUAL_EMPTIES", NULL}
-#define STMT_82 \
+#define STMT_INSERT_ACTUAL_EMPTIES 83
+#define STMT_83_INFO {"STMT_INSERT_ACTUAL_EMPTIES", NULL}
+#define STMT_83 \
"INSERT OR IGNORE INTO actual_node ( " \
" wc_id, local_relpath, parent_relpath) " \
"SELECT wc_id, local_relpath, parent_relpath " \
"FROM targets_list " \
""
-#define STMT_DELETE_ACTUAL_EMPTY 83
-#define STMT_83_INFO {"STMT_DELETE_ACTUAL_EMPTY", NULL}
-#define STMT_83 \
+#define STMT_INSERT_ACTUAL_EMPTIES_FILES 84
+#define STMT_84_INFO {"STMT_INSERT_ACTUAL_EMPTIES_FILES", NULL}
+#define STMT_84 \
+ "INSERT OR IGNORE INTO actual_node ( " \
+ " wc_id, local_relpath, parent_relpath) " \
+ "SELECT wc_id, local_relpath, parent_relpath " \
+ "FROM targets_list " \
+ "WHERE kind='file' " \
+ ""
+
+#define STMT_DELETE_ACTUAL_EMPTY 85
+#define STMT_85_INFO {"STMT_DELETE_ACTUAL_EMPTY", NULL}
+#define STMT_85 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
" AND properties IS NULL " \
@@ -869,12 +921,12 @@
" AND left_checksum IS NULL " \
""
-#define STMT_DELETE_ACTUAL_EMPTIES 84
-#define STMT_84_INFO {"STMT_DELETE_ACTUAL_EMPTIES", NULL}
-#define STMT_84 \
+#define STMT_DELETE_ACTUAL_EMPTIES 86
+#define STMT_86_INFO {"STMT_DELETE_ACTUAL_EMPTIES", NULL}
+#define STMT_86 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 " \
- " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
" AND properties IS NULL " \
" AND conflict_data IS NULL " \
" AND changelist IS NULL " \
@@ -884,25 +936,25 @@
" AND left_checksum IS NULL " \
""
-#define STMT_DELETE_BASE_NODE 85
-#define STMT_85_INFO {"STMT_DELETE_BASE_NODE", NULL}
-#define STMT_85 \
+#define STMT_DELETE_BASE_NODE 87
+#define STMT_87_INFO {"STMT_DELETE_BASE_NODE", NULL}
+#define STMT_87 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_DELETE_WORKING_NODE 86
-#define STMT_86_INFO {"STMT_DELETE_WORKING_NODE", NULL}
-#define STMT_86 \
+#define STMT_DELETE_WORKING_NODE 88
+#define STMT_88_INFO {"STMT_DELETE_WORKING_NODE", NULL}
+#define STMT_88 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
" AND op_depth = (SELECT MAX(op_depth) FROM nodes " \
" WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > 0) " \
""
-#define STMT_DELETE_LOWEST_WORKING_NODE 87
-#define STMT_87_INFO {"STMT_DELETE_LOWEST_WORKING_NODE", NULL}
-#define STMT_87 \
+#define STMT_DELETE_LOWEST_WORKING_NODE 89
+#define STMT_89_INFO {"STMT_DELETE_LOWEST_WORKING_NODE", NULL}
+#define STMT_89 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
" AND op_depth = (SELECT MIN(op_depth) FROM nodes " \
@@ -910,16 +962,16 @@
" AND presence = 'base-deleted' " \
""
-#define STMT_DELETE_NODE_ALL_LAYERS 88
-#define STMT_88_INFO {"STMT_DELETE_NODE_ALL_LAYERS", NULL}
-#define STMT_88 \
+#define STMT_DELETE_NODE_ALL_LAYERS 90
+#define STMT_90_INFO {"STMT_DELETE_NODE_ALL_LAYERS", NULL}
+#define STMT_90 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_DELETE_NODES_ABOVE_DEPTH_RECURSIVE 89
-#define STMT_89_INFO {"STMT_DELETE_NODES_ABOVE_DEPTH_RECURSIVE", NULL}
-#define STMT_89 \
+#define STMT_DELETE_NODES_ABOVE_DEPTH_RECURSIVE 91
+#define STMT_91_INFO {"STMT_DELETE_NODES_ABOVE_DEPTH_RECURSIVE", NULL}
+#define STMT_91 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
@@ -927,25 +979,25 @@
" AND op_depth >= ?3 " \
""
-#define STMT_DELETE_ACTUAL_NODE 90
-#define STMT_90_INFO {"STMT_DELETE_ACTUAL_NODE", NULL}
-#define STMT_90 \
+#define STMT_DELETE_ACTUAL_NODE 92
+#define STMT_92_INFO {"STMT_DELETE_ACTUAL_NODE", NULL}
+#define STMT_92 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_DELETE_ACTUAL_NODE_RECURSIVE 91
-#define STMT_91_INFO {"STMT_DELETE_ACTUAL_NODE_RECURSIVE", NULL}
-#define STMT_91 \
+#define STMT_DELETE_ACTUAL_NODE_RECURSIVE 93
+#define STMT_93_INFO {"STMT_DELETE_ACTUAL_NODE_RECURSIVE", NULL}
+#define STMT_93 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
" OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
""
-#define STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST 92
-#define STMT_92_INFO {"STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST", NULL}
-#define STMT_92 \
+#define STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST 94
+#define STMT_94_INFO {"STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST", NULL}
+#define STMT_94 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 " \
" AND local_relpath = ?2 " \
@@ -955,9 +1007,9 @@
" AND c.kind = 'file')) " \
""
-#define STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE 93
-#define STMT_93_INFO {"STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE", NULL}
-#define STMT_93 \
+#define STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE 95
+#define STMT_95_INFO {"STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE", NULL}
+#define STMT_95 \
"DELETE FROM actual_node " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
@@ -969,9 +1021,9 @@
" AND c.kind = 'file')) " \
""
-#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST 94
-#define STMT_94_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST", NULL}
-#define STMT_94 \
+#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST 96
+#define STMT_96_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST", NULL}
+#define STMT_96 \
"UPDATE actual_node " \
"SET properties = NULL, " \
" text_mod = NULL, " \
@@ -983,9 +1035,23 @@
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE 95
-#define STMT_95_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE", NULL}
-#define STMT_95 \
+#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CONFLICT 97
+#define STMT_97_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CONFLICT", NULL}
+#define STMT_97 \
+ "UPDATE actual_node " \
+ "SET properties = NULL, " \
+ " text_mod = NULL, " \
+ " tree_conflict_data = NULL, " \
+ " older_checksum = NULL, " \
+ " left_checksum = NULL, " \
+ " right_checksum = NULL, " \
+ " changelist = NULL " \
+ "WHERE wc_id = ?1 AND local_relpath = ?2 " \
+ ""
+
+#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE 98
+#define STMT_98_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE", NULL}
+#define STMT_98 \
"UPDATE actual_node " \
"SET properties = NULL, " \
" text_mod = NULL, " \
@@ -999,108 +1065,109 @@
" OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
""
-#define STMT_UPDATE_NODE_BASE_DEPTH 96
-#define STMT_96_INFO {"STMT_UPDATE_NODE_BASE_DEPTH", NULL}
-#define STMT_96 \
+#define STMT_UPDATE_NODE_BASE_DEPTH 99
+#define STMT_99_INFO {"STMT_UPDATE_NODE_BASE_DEPTH", NULL}
+#define STMT_99 \
"UPDATE nodes SET depth = ?3 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
" AND kind='dir' " \
+ " AND presence IN ('normal', 'incomplete') " \
""
-#define STMT_UPDATE_NODE_BASE_PRESENCE 97
-#define STMT_97_INFO {"STMT_UPDATE_NODE_BASE_PRESENCE", NULL}
-#define STMT_97 \
+#define STMT_UPDATE_NODE_BASE_PRESENCE 100
+#define STMT_100_INFO {"STMT_UPDATE_NODE_BASE_PRESENCE", NULL}
+#define STMT_100 \
"UPDATE nodes SET presence = ?3 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_UPDATE_BASE_NODE_PRESENCE_REVNUM_AND_REPOS_PATH 98
-#define STMT_98_INFO {"STMT_UPDATE_BASE_NODE_PRESENCE_REVNUM_AND_REPOS_PATH", NULL}
-#define STMT_98 \
+#define STMT_UPDATE_BASE_NODE_PRESENCE_REVNUM_AND_REPOS_PATH 101
+#define STMT_101_INFO {"STMT_UPDATE_BASE_NODE_PRESENCE_REVNUM_AND_REPOS_PATH", NULL}
+#define STMT_101 \
"UPDATE nodes SET presence = ?3, revision = ?4, repos_path = ?5 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_LOOK_FOR_WORK 99
-#define STMT_99_INFO {"STMT_LOOK_FOR_WORK", NULL}
-#define STMT_99 \
+#define STMT_LOOK_FOR_WORK 102
+#define STMT_102_INFO {"STMT_LOOK_FOR_WORK", NULL}
+#define STMT_102 \
"SELECT id FROM work_queue LIMIT 1 " \
""
-#define STMT_INSERT_WORK_ITEM 100
-#define STMT_100_INFO {"STMT_INSERT_WORK_ITEM", NULL}
-#define STMT_100 \
+#define STMT_INSERT_WORK_ITEM 103
+#define STMT_103_INFO {"STMT_INSERT_WORK_ITEM", NULL}
+#define STMT_103 \
"INSERT INTO work_queue (work) VALUES (?1) " \
""
-#define STMT_SELECT_WORK_ITEM 101
-#define STMT_101_INFO {"STMT_SELECT_WORK_ITEM", NULL}
-#define STMT_101 \
+#define STMT_SELECT_WORK_ITEM 104
+#define STMT_104_INFO {"STMT_SELECT_WORK_ITEM", NULL}
+#define STMT_104 \
"SELECT id, work FROM work_queue ORDER BY id LIMIT 1 " \
""
-#define STMT_DELETE_WORK_ITEM 102
-#define STMT_102_INFO {"STMT_DELETE_WORK_ITEM", NULL}
-#define STMT_102 \
+#define STMT_DELETE_WORK_ITEM 105
+#define STMT_105_INFO {"STMT_DELETE_WORK_ITEM", NULL}
+#define STMT_105 \
"DELETE FROM work_queue WHERE id = ?1 " \
""
-#define STMT_INSERT_OR_IGNORE_PRISTINE 103
-#define STMT_103_INFO {"STMT_INSERT_OR_IGNORE_PRISTINE", NULL}
-#define STMT_103 \
+#define STMT_INSERT_OR_IGNORE_PRISTINE 106
+#define STMT_106_INFO {"STMT_INSERT_OR_IGNORE_PRISTINE", NULL}
+#define STMT_106 \
"INSERT OR IGNORE INTO pristine (checksum, md5_checksum, size, refcount) " \
"VALUES (?1, ?2, ?3, 0) " \
""
-#define STMT_INSERT_PRISTINE 104
-#define STMT_104_INFO {"STMT_INSERT_PRISTINE", NULL}
-#define STMT_104 \
+#define STMT_INSERT_PRISTINE 107
+#define STMT_107_INFO {"STMT_INSERT_PRISTINE", NULL}
+#define STMT_107 \
"INSERT INTO pristine (checksum, md5_checksum, size, refcount) " \
"VALUES (?1, ?2, ?3, 0) " \
""
-#define STMT_SELECT_PRISTINE 105
-#define STMT_105_INFO {"STMT_SELECT_PRISTINE", NULL}
-#define STMT_105 \
+#define STMT_SELECT_PRISTINE 108
+#define STMT_108_INFO {"STMT_SELECT_PRISTINE", NULL}
+#define STMT_108 \
"SELECT md5_checksum " \
"FROM pristine " \
"WHERE checksum = ?1 " \
""
-#define STMT_SELECT_PRISTINE_SIZE 106
-#define STMT_106_INFO {"STMT_SELECT_PRISTINE_SIZE", NULL}
-#define STMT_106 \
+#define STMT_SELECT_PRISTINE_SIZE 109
+#define STMT_109_INFO {"STMT_SELECT_PRISTINE_SIZE", NULL}
+#define STMT_109 \
"SELECT size " \
"FROM pristine " \
"WHERE checksum = ?1 LIMIT 1 " \
""
-#define STMT_SELECT_PRISTINE_BY_MD5 107
-#define STMT_107_INFO {"STMT_SELECT_PRISTINE_BY_MD5", NULL}
-#define STMT_107 \
+#define STMT_SELECT_PRISTINE_BY_MD5 110
+#define STMT_110_INFO {"STMT_SELECT_PRISTINE_BY_MD5", NULL}
+#define STMT_110 \
"SELECT checksum " \
"FROM pristine " \
"WHERE md5_checksum = ?1 " \
""
-#define STMT_SELECT_UNREFERENCED_PRISTINES 108
-#define STMT_108_INFO {"STMT_SELECT_UNREFERENCED_PRISTINES", NULL}
-#define STMT_108 \
+#define STMT_SELECT_UNREFERENCED_PRISTINES 111
+#define STMT_111_INFO {"STMT_SELECT_UNREFERENCED_PRISTINES", NULL}
+#define STMT_111 \
"SELECT checksum " \
"FROM pristine " \
"WHERE refcount = 0 " \
""
-#define STMT_DELETE_PRISTINE_IF_UNREFERENCED 109
-#define STMT_109_INFO {"STMT_DELETE_PRISTINE_IF_UNREFERENCED", NULL}
-#define STMT_109 \
+#define STMT_DELETE_PRISTINE_IF_UNREFERENCED 112
+#define STMT_112_INFO {"STMT_DELETE_PRISTINE_IF_UNREFERENCED", NULL}
+#define STMT_112 \
"DELETE FROM pristine " \
"WHERE checksum = ?1 AND refcount = 0 " \
""
-#define STMT_SELECT_COPY_PRISTINES 110
-#define STMT_110_INFO {"STMT_SELECT_COPY_PRISTINES", NULL}
-#define STMT_110 \
+#define STMT_SELECT_COPY_PRISTINES 113
+#define STMT_113_INFO {"STMT_SELECT_COPY_PRISTINES", NULL}
+#define STMT_113 \
"SELECT n.checksum, md5_checksum, size " \
"FROM nodes_current n " \
"LEFT JOIN pristine p ON n.checksum = p.checksum " \
@@ -1118,62 +1185,73 @@
" AND n.checksum IS NOT NULL " \
""
-#define STMT_VACUUM 111
-#define STMT_111_INFO {"STMT_VACUUM", NULL}
-#define STMT_111 \
+#define STMT_VACUUM 114
+#define STMT_114_INFO {"STMT_VACUUM", NULL}
+#define STMT_114 \
"VACUUM " \
""
-#define STMT_SELECT_CONFLICT_VICTIMS 112
-#define STMT_112_INFO {"STMT_SELECT_CONFLICT_VICTIMS", NULL}
-#define STMT_112 \
+#define STMT_SELECT_CONFLICT_VICTIMS 115
+#define STMT_115_INFO {"STMT_SELECT_CONFLICT_VICTIMS", NULL}
+#define STMT_115 \
"SELECT local_relpath, conflict_data " \
"FROM actual_node " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 AND " \
" NOT (conflict_data IS NULL) " \
""
-#define STMT_INSERT_WC_LOCK 113
-#define STMT_113_INFO {"STMT_INSERT_WC_LOCK", NULL}
-#define STMT_113 \
+#define STMT_INSERT_WC_LOCK 116
+#define STMT_116_INFO {"STMT_INSERT_WC_LOCK", NULL}
+#define STMT_116 \
"INSERT INTO wc_lock (wc_id, local_dir_relpath, locked_levels) " \
"VALUES (?1, ?2, ?3) " \
""
-#define STMT_SELECT_WC_LOCK 114
-#define STMT_114_INFO {"STMT_SELECT_WC_LOCK", NULL}
-#define STMT_114 \
+#define STMT_SELECT_WC_LOCK 117
+#define STMT_117_INFO {"STMT_SELECT_WC_LOCK", NULL}
+#define STMT_117 \
"SELECT locked_levels FROM wc_lock " \
"WHERE wc_id = ?1 AND local_dir_relpath = ?2 " \
""
-#define STMT_SELECT_ANCESTOR_WCLOCKS 115
-#define STMT_115_INFO {"STMT_SELECT_ANCESTOR_WCLOCKS", NULL}
-#define STMT_115 \
+#define STMT_SELECT_ANCESTOR_WCLOCKS 118
+#define STMT_118_INFO {"STMT_SELECT_ANCESTOR_WCLOCKS", NULL}
+#define STMT_118 \
"SELECT local_dir_relpath, locked_levels FROM wc_lock " \
"WHERE wc_id = ?1 " \
" AND ((local_dir_relpath >= ?3 AND local_dir_relpath <= ?2) " \
" OR local_dir_relpath = '') " \
""
-#define STMT_DELETE_WC_LOCK 116
-#define STMT_116_INFO {"STMT_DELETE_WC_LOCK", NULL}
-#define STMT_116 \
+#define STMT_DELETE_WC_LOCK 119
+#define STMT_119_INFO {"STMT_DELETE_WC_LOCK", NULL}
+#define STMT_119 \
"DELETE FROM wc_lock " \
"WHERE wc_id = ?1 AND local_dir_relpath = ?2 " \
""
-#define STMT_FIND_WC_LOCK 117
-#define STMT_117_INFO {"STMT_FIND_WC_LOCK", NULL}
-#define STMT_117 \
+#define STMT_FIND_WC_LOCK 120
+#define STMT_120_INFO {"STMT_FIND_WC_LOCK", NULL}
+#define STMT_120 \
"SELECT local_dir_relpath FROM wc_lock " \
"WHERE wc_id = ?1 " \
" AND (((local_dir_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_dir_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_DELETE_WC_LOCK_ORPHAN 118
-#define STMT_118_INFO {"STMT_DELETE_WC_LOCK_ORPHAN", NULL}
-#define STMT_118 \
+#define STMT_FIND_CONFLICT_DESCENDANT 121
+#define STMT_121_INFO {"STMT_FIND_CONFLICT_DESCENDANT", NULL}
+#define STMT_121 \
+ "SELECT 1 FROM actual_node " \
+ "WHERE wc_id = ?1 " \
+ " AND local_relpath > (?2 || '/') " \
+ " AND local_relpath < (?2 || '0') " \
+ " AND conflict_data IS NOT NULL " \
+ "LIMIT 1 " \
+ ""
+
+#define STMT_DELETE_WC_LOCK_ORPHAN 122
+#define STMT_122_INFO {"STMT_DELETE_WC_LOCK_ORPHAN", NULL}
+#define STMT_122 \
"DELETE FROM wc_lock " \
"WHERE wc_id = ?1 AND local_dir_relpath = ?2 " \
"AND NOT EXISTS (SELECT 1 FROM nodes " \
@@ -1181,9 +1259,9 @@
" AND nodes.local_relpath = wc_lock.local_dir_relpath) " \
""
-#define STMT_DELETE_WC_LOCK_ORPHAN_RECURSIVE 119
-#define STMT_119_INFO {"STMT_DELETE_WC_LOCK_ORPHAN_RECURSIVE", NULL}
-#define STMT_119 \
+#define STMT_DELETE_WC_LOCK_ORPHAN_RECURSIVE 123
+#define STMT_123_INFO {"STMT_DELETE_WC_LOCK_ORPHAN_RECURSIVE", NULL}
+#define STMT_123 \
"DELETE FROM wc_lock " \
"WHERE wc_id = ?1 " \
" AND (local_dir_relpath = ?2 " \
@@ -1193,9 +1271,9 @@
" AND nodes.local_relpath = wc_lock.local_dir_relpath) " \
""
-#define STMT_APPLY_CHANGES_TO_BASE_NODE 120
-#define STMT_120_INFO {"STMT_APPLY_CHANGES_TO_BASE_NODE", NULL}
-#define STMT_120 \
+#define STMT_APPLY_CHANGES_TO_BASE_NODE 124
+#define STMT_124_INFO {"STMT_APPLY_CHANGES_TO_BASE_NODE", NULL}
+#define STMT_124 \
"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, " \
@@ -1209,77 +1287,70 @@
" AND op_depth = 0)) " \
""
-#define STMT_INSTALL_WORKING_NODE_FOR_DELETE 121
-#define STMT_121_INFO {"STMT_INSTALL_WORKING_NODE_FOR_DELETE", NULL}
-#define STMT_121 \
- "INSERT OR REPLACE INTO nodes ( " \
+#define STMT_INSTALL_WORKING_NODE_FOR_DELETE 125
+#define STMT_125_INFO {"STMT_INSTALL_WORKING_NODE_FOR_DELETE", NULL}
+#define STMT_125 \
+ "INSERT INTO nodes ( " \
" wc_id, local_relpath, op_depth, " \
" parent_relpath, presence, kind) " \
"VALUES(?1, ?2, ?3, ?4, 'base-deleted', ?5) " \
""
-#define STMT_DELETE_NO_LOWER_LAYER 122
-#define STMT_122_INFO {"STMT_DELETE_NO_LOWER_LAYER", NULL}
-#define STMT_122 \
- "DELETE FROM nodes " \
- " WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND op_depth = ?3 " \
- " AND NOT EXISTS (SELECT 1 FROM nodes n " \
- " WHERE n.wc_id = ?1 " \
- " AND n.local_relpath = nodes.local_relpath " \
- " AND n.op_depth = ?4 " \
- " AND n.presence IN ('normal', 'incomplete')) " \
- ""
-
-#define STMT_REPLACE_WITH_BASE_DELETED 123
-#define STMT_123_INFO {"STMT_REPLACE_WITH_BASE_DELETED", NULL}
-#define STMT_123 \
+#define STMT_REPLACE_WITH_BASE_DELETED 126
+#define STMT_126_INFO {"STMT_REPLACE_WITH_BASE_DELETED", NULL}
+#define STMT_126 \
"INSERT OR REPLACE INTO nodes (wc_id, local_relpath, op_depth, parent_relpath, " \
" kind, moved_to, presence) " \
"SELECT wc_id, local_relpath, op_depth, parent_relpath, " \
" kind, moved_to, 'base-deleted' " \
" FROM nodes " \
" WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
+ " AND local_relpath = ?2 " \
" AND op_depth = ?3 " \
""
-#define STMT_INSERT_DELETE_FROM_NODE_RECURSIVE 124
-#define STMT_124_INFO {"STMT_INSERT_DELETE_FROM_NODE_RECURSIVE", NULL}
-#define STMT_124 \
+#define STMT_INSERT_DELETE_FROM_NODE_RECURSIVE 127
+#define STMT_127_INFO {"STMT_INSERT_DELETE_FROM_NODE_RECURSIVE", NULL}
+#define STMT_127 \
"INSERT INTO nodes ( " \
" wc_id, local_relpath, op_depth, parent_relpath, presence, kind) " \
"SELECT wc_id, local_relpath, ?4 , parent_relpath, 'base-deleted', " \
" kind " \
"FROM nodes " \
+ "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
+ "UNION ALL " \
+ "SELECT wc_id, local_relpath, ?4 , parent_relpath, 'base-deleted', " \
+ " kind " \
+ "FROM nodes " \
"WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 " \
- " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
+ " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND op_depth = ?3 " \
" AND presence NOT IN ('base-deleted', 'not-present', 'excluded', 'server-excluded') " \
" AND file_external IS NULL " \
+ "ORDER BY local_relpath " \
""
-#define STMT_INSERT_WORKING_NODE_FROM_BASE_COPY 125
-#define STMT_125_INFO {"STMT_INSERT_WORKING_NODE_FROM_BASE_COPY", NULL}
-#define STMT_125 \
- "INSERT INTO nodes ( " \
+#define STMT_INSERT_WORKING_NODE_FROM_BASE_COPY 128
+#define STMT_128_INFO {"STMT_INSERT_WORKING_NODE_FROM_BASE_COPY", NULL}
+#define STMT_128 \
+ "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, translated_size, last_mod_time, " \
- " symlink_target ) " \
+ " symlink_target, moved_to ) " \
"SELECT wc_id, local_relpath, ?3 , parent_relpath, repos_id, " \
" repos_path, revision, presence, depth, kind, changed_revision, " \
" changed_date, changed_author, checksum, properties, translated_size, " \
- " last_mod_time, symlink_target " \
+ " last_mod_time, symlink_target, " \
+ " (SELECT moved_to FROM nodes " \
+ " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3) moved_to " \
"FROM nodes " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_INSERT_DELETE_FROM_BASE 126
-#define STMT_126_INFO {"STMT_INSERT_DELETE_FROM_BASE", NULL}
-#define STMT_126 \
+#define STMT_INSERT_DELETE_FROM_BASE 129
+#define STMT_129_INFO {"STMT_INSERT_DELETE_FROM_BASE", NULL}
+#define STMT_129 \
"INSERT INTO nodes ( " \
" wc_id, local_relpath, op_depth, parent_relpath, presence, kind) " \
"SELECT wc_id, local_relpath, ?3 , parent_relpath, " \
@@ -1288,34 +1359,52 @@
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_UPDATE_OP_DEPTH_INCREASE_RECURSIVE 127
-#define STMT_127_INFO {"STMT_UPDATE_OP_DEPTH_INCREASE_RECURSIVE", NULL}
-#define STMT_127 \
+#define STMT_UPDATE_OP_DEPTH_INCREASE_RECURSIVE 130
+#define STMT_130_INFO {"STMT_UPDATE_OP_DEPTH_INCREASE_RECURSIVE", NULL}
+#define STMT_130 \
"UPDATE nodes SET op_depth = ?3 + 1 " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND op_depth = ?3 " \
""
-#define STMT_UPDATE_OP_DEPTH_RECURSIVE 128
-#define STMT_128_INFO {"STMT_UPDATE_OP_DEPTH_RECURSIVE", NULL}
-#define STMT_128 \
- "UPDATE nodes SET op_depth = ?4, moved_here = NULL " \
- "WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND op_depth = ?3 " \
+#define STMT_COPY_OP_DEPTH_RECURSIVE 131
+#define STMT_131_INFO {"STMT_COPY_OP_DEPTH_RECURSIVE", NULL}
+#define STMT_131 \
+ "INSERT 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, translated_size, last_mod_time, " \
+ " symlink_target, moved_here, moved_to ) " \
+ "SELECT " \
+ " wc_id, local_relpath, ?4, parent_relpath, repos_id, " \
+ " repos_path, revision, presence, depth, kind, changed_revision, " \
+ " changed_date, changed_author, checksum, properties, translated_size, " \
+ " last_mod_time, symlink_target, NULL, NULL " \
+ "FROM nodes " \
+ "WHERE wc_id = ?1 AND op_depth = ?3 AND local_relpath = ?2 " \
+ "UNION ALL " \
+ "SELECT " \
+ " wc_id, local_relpath, ?4, parent_relpath, repos_id, " \
+ " repos_path, revision, presence, depth, kind, changed_revision, " \
+ " changed_date, changed_author, checksum, properties, translated_size, " \
+ " last_mod_time, symlink_target, NULL, NULL " \
+ "FROM nodes " \
+ "WHERE wc_id = ?1 AND op_depth = ?3 " \
+ " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ "ORDER BY local_relpath " \
""
-#define STMT_DOES_NODE_EXIST 129
-#define STMT_129_INFO {"STMT_DOES_NODE_EXIST", NULL}
-#define STMT_129 \
+#define STMT_DOES_NODE_EXIST 132
+#define STMT_132_INFO {"STMT_DOES_NODE_EXIST", NULL}
+#define STMT_132 \
"SELECT 1 FROM nodes WHERE wc_id = ?1 AND local_relpath = ?2 " \
"LIMIT 1 " \
""
-#define STMT_HAS_SERVER_EXCLUDED_DESCENDANTS 130
-#define STMT_130_INFO {"STMT_HAS_SERVER_EXCLUDED_DESCENDANTS", NULL}
-#define STMT_130 \
+#define STMT_HAS_SERVER_EXCLUDED_DESCENDANTS 133
+#define STMT_133_INFO {"STMT_HAS_SERVER_EXCLUDED_DESCENDANTS", NULL}
+#define STMT_133 \
"SELECT local_relpath FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
@@ -1323,9 +1412,9 @@
"LIMIT 1 " \
""
-#define STMT_SELECT_ALL_EXCLUDED_DESCENDANTS 131
-#define STMT_131_INFO {"STMT_SELECT_ALL_EXCLUDED_DESCENDANTS", NULL}
-#define STMT_131 \
+#define STMT_SELECT_ALL_EXCLUDED_DESCENDANTS 134
+#define STMT_134_INFO {"STMT_SELECT_ALL_EXCLUDED_DESCENDANTS", NULL}
+#define STMT_134 \
"SELECT local_relpath FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
@@ -1333,9 +1422,9 @@
" AND (presence = 'server-excluded' OR presence = 'excluded') " \
""
-#define STMT_INSERT_WORKING_NODE_COPY_FROM 132
-#define STMT_132_INFO {"STMT_INSERT_WORKING_NODE_COPY_FROM", NULL}
-#define STMT_132 \
+#define STMT_INSERT_WORKING_NODE_COPY_FROM 135
+#define STMT_135_INFO {"STMT_INSERT_WORKING_NODE_COPY_FROM", NULL}
+#define STMT_135 \
"INSERT OR REPLACE INTO nodes ( " \
" wc_id, local_relpath, op_depth, parent_relpath, repos_id, " \
" repos_path, revision, presence, depth, moved_here, kind, changed_revision, " \
@@ -1354,9 +1443,9 @@
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_INSERT_WORKING_NODE_COPY_FROM_DEPTH 133
-#define STMT_133_INFO {"STMT_INSERT_WORKING_NODE_COPY_FROM_DEPTH", NULL}
-#define STMT_133 \
+#define STMT_INSERT_WORKING_NODE_COPY_FROM_DEPTH 136
+#define STMT_136_INFO {"STMT_INSERT_WORKING_NODE_COPY_FROM_DEPTH", NULL}
+#define STMT_136 \
"INSERT OR REPLACE INTO nodes ( " \
" wc_id, local_relpath, op_depth, parent_relpath, repos_id, " \
" repos_path, revision, presence, depth, moved_here, kind, changed_revision, " \
@@ -1375,49 +1464,49 @@
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?7 " \
""
-#define STMT_UPDATE_BASE_REVISION 134
-#define STMT_134_INFO {"STMT_UPDATE_BASE_REVISION", NULL}
-#define STMT_134 \
+#define STMT_UPDATE_BASE_REVISION 137
+#define STMT_137_INFO {"STMT_UPDATE_BASE_REVISION", NULL}
+#define STMT_137 \
"UPDATE nodes SET revision = ?3 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_UPDATE_BASE_REPOS 135
-#define STMT_135_INFO {"STMT_UPDATE_BASE_REPOS", NULL}
-#define STMT_135 \
+#define STMT_UPDATE_BASE_REPOS 138
+#define STMT_138_INFO {"STMT_UPDATE_BASE_REPOS", NULL}
+#define STMT_138 \
"UPDATE nodes SET repos_id = ?3, repos_path = ?4 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \
""
-#define STMT_ACTUAL_HAS_CHILDREN 136
-#define STMT_136_INFO {"STMT_ACTUAL_HAS_CHILDREN", NULL}
-#define STMT_136 \
+#define STMT_ACTUAL_HAS_CHILDREN 139
+#define STMT_139_INFO {"STMT_ACTUAL_HAS_CHILDREN", NULL}
+#define STMT_139 \
"SELECT 1 FROM actual_node " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 " \
"LIMIT 1 " \
""
-#define STMT_INSERT_EXTERNAL 137
-#define STMT_137_INFO {"STMT_INSERT_EXTERNAL", NULL}
-#define STMT_137 \
+#define STMT_INSERT_EXTERNAL 140
+#define STMT_140_INFO {"STMT_INSERT_EXTERNAL", NULL}
+#define STMT_140 \
"INSERT OR REPLACE INTO externals ( " \
" wc_id, local_relpath, parent_relpath, presence, kind, def_local_relpath, " \
" repos_id, def_repos_relpath, def_operational_revision, def_revision) " \
"VALUES (?1, ?2, ?3, ?4, ?5, ?6, ?7, ?8, ?9, ?10) " \
""
-#define STMT_SELECT_EXTERNAL_INFO 138
-#define STMT_138_INFO {"STMT_SELECT_EXTERNAL_INFO", NULL}
-#define STMT_138 \
+#define STMT_SELECT_EXTERNAL_INFO 141
+#define STMT_141_INFO {"STMT_SELECT_EXTERNAL_INFO", NULL}
+#define STMT_141 \
"SELECT presence, kind, def_local_relpath, repos_id, " \
" def_repos_relpath, def_operational_revision, def_revision " \
"FROM externals WHERE wc_id = ?1 AND local_relpath = ?2 " \
"LIMIT 1 " \
""
-#define STMT_DELETE_FILE_EXTERNALS 139
-#define STMT_139_INFO {"STMT_DELETE_FILE_EXTERNALS", NULL}
-#define STMT_139 \
+#define STMT_DELETE_FILE_EXTERNALS 142
+#define STMT_142_INFO {"STMT_DELETE_FILE_EXTERNALS", NULL}
+#define STMT_142 \
"DELETE FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
@@ -1425,26 +1514,26 @@
" AND file_external IS NOT NULL " \
""
-#define STMT_DELETE_FILE_EXTERNAL_REGISTATIONS 140
-#define STMT_140_INFO {"STMT_DELETE_FILE_EXTERNAL_REGISTATIONS", NULL}
-#define STMT_140 \
+#define STMT_DELETE_FILE_EXTERNAL_REGISTATIONS 143
+#define STMT_143_INFO {"STMT_DELETE_FILE_EXTERNAL_REGISTATIONS", NULL}
+#define STMT_143 \
"DELETE FROM externals " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND kind != 'dir' " \
""
-#define STMT_DELETE_EXTERNAL_REGISTATIONS 141
-#define STMT_141_INFO {"STMT_DELETE_EXTERNAL_REGISTATIONS", NULL}
-#define STMT_141 \
+#define STMT_DELETE_EXTERNAL_REGISTATIONS 144
+#define STMT_144_INFO {"STMT_DELETE_EXTERNAL_REGISTATIONS", NULL}
+#define STMT_144 \
"DELETE FROM externals " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_SELECT_COMMITTABLE_EXTERNALS_BELOW 142
-#define STMT_142_INFO {"STMT_SELECT_COMMITTABLE_EXTERNALS_BELOW", NULL}
-#define STMT_142 \
+#define STMT_SELECT_COMMITTABLE_EXTERNALS_BELOW 145
+#define STMT_145_INFO {"STMT_SELECT_COMMITTABLE_EXTERNALS_BELOW", NULL}
+#define STMT_145 \
"SELECT local_relpath, kind, def_repos_relpath, " \
" (SELECT root FROM repository AS r WHERE r.id = e.repos_id) " \
"FROM externals e " \
@@ -1462,9 +1551,9 @@
" AND nodes.local_relpath = e.parent_relpath)) " \
""
-#define STMT_SELECT_COMMITTABLE_EXTERNALS_IMMEDIATELY_BELOW 143
-#define STMT_143_INFO {"STMT_SELECT_COMMITTABLE_EXTERNALS_IMMEDIATELY_BELOW", NULL}
-#define STMT_143 \
+#define STMT_SELECT_COMMITTABLE_EXTERNALS_IMMEDIATELY_BELOW 146
+#define STMT_146_INFO {"STMT_SELECT_COMMITTABLE_EXTERNALS_IMMEDIATELY_BELOW", NULL}
+#define STMT_146 \
"SELECT local_relpath, kind, def_repos_relpath, " \
" (SELECT root FROM repository AS r WHERE r.id = e.repos_id) " \
"FROM externals e " \
@@ -1483,25 +1572,25 @@
" AND nodes.local_relpath = e.parent_relpath)) " \
""
-#define STMT_SELECT_EXTERNALS_DEFINED 144
-#define STMT_144_INFO {"STMT_SELECT_EXTERNALS_DEFINED", NULL}
-#define STMT_144 \
+#define STMT_SELECT_EXTERNALS_DEFINED 147
+#define STMT_147_INFO {"STMT_SELECT_EXTERNALS_DEFINED", NULL}
+#define STMT_147 \
"SELECT local_relpath, def_local_relpath " \
"FROM externals " \
"WHERE (wc_id = ?1 AND def_local_relpath = ?2) " \
" OR (wc_id = ?1 AND (((def_local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((def_local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
""
-#define STMT_DELETE_EXTERNAL 145
-#define STMT_145_INFO {"STMT_DELETE_EXTERNAL", NULL}
-#define STMT_145 \
+#define STMT_DELETE_EXTERNAL 148
+#define STMT_148_INFO {"STMT_DELETE_EXTERNAL", NULL}
+#define STMT_148 \
"DELETE FROM externals " \
"WHERE wc_id = ?1 AND local_relpath = ?2 " \
""
-#define STMT_SELECT_EXTERNAL_PROPERTIES 146
-#define STMT_146_INFO {"STMT_SELECT_EXTERNAL_PROPERTIES", NULL}
-#define STMT_146 \
+#define STMT_SELECT_EXTERNAL_PROPERTIES 149
+#define STMT_149_INFO {"STMT_SELECT_EXTERNAL_PROPERTIES", NULL}
+#define STMT_149 \
"SELECT IFNULL((SELECT properties FROM actual_node a " \
" WHERE a.wc_id = ?1 AND A.local_relpath = n.local_relpath), " \
" properties), " \
@@ -1519,9 +1608,9 @@
" AND kind = 'dir' AND presence IN ('normal', 'incomplete') " \
""
-#define STMT_SELECT_CURRENT_PROPS_RECURSIVE 147
-#define STMT_147_INFO {"STMT_SELECT_CURRENT_PROPS_RECURSIVE", NULL}
-#define STMT_147 \
+#define STMT_SELECT_CURRENT_PROPS_RECURSIVE 150
+#define STMT_150_INFO {"STMT_SELECT_CURRENT_PROPS_RECURSIVE", NULL}
+#define STMT_150 \
"SELECT IFNULL((SELECT properties FROM actual_node a " \
" WHERE a.wc_id = ?1 AND A.local_relpath = n.local_relpath), " \
" properties), " \
@@ -1531,57 +1620,44 @@
" OR (wc_id = ?1 AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
""
-#define STMT_PRAGMA_LOCKING_MODE 148
-#define STMT_148_INFO {"STMT_PRAGMA_LOCKING_MODE", NULL}
-#define STMT_148 \
- "PRAGMA locking_mode = exclusive " \
+#define STMT_PRAGMA_LOCKING_MODE 151
+#define STMT_151_INFO {"STMT_PRAGMA_LOCKING_MODE", NULL}
+#define STMT_151 \
+ "PRAGMA locking_mode = exclusive; " \
+ "PRAGMA journal_mode = DELETE " \
""
-#define STMT_INSERT_ACTUAL_NODE 149
-#define STMT_149_INFO {"STMT_INSERT_ACTUAL_NODE", NULL}
-#define STMT_149 \
+#define STMT_INSERT_ACTUAL_NODE 152
+#define STMT_152_INFO {"STMT_INSERT_ACTUAL_NODE", NULL}
+#define STMT_152 \
"INSERT OR REPLACE INTO actual_node ( " \
" wc_id, local_relpath, parent_relpath, properties, changelist, conflict_data) " \
"VALUES (?1, ?2, ?3, ?4, ?5, ?6) " \
""
-#define STMT_UPDATE_ACTUAL_CONFLICT_DATA 150
-#define STMT_150_INFO {"STMT_UPDATE_ACTUAL_CONFLICT_DATA", NULL}
-#define STMT_150 \
- "UPDATE actual_node SET conflict_data = ?3 " \
- "WHERE wc_id = ?1 AND local_relpath = ?2 " \
- ""
-
-#define STMT_INSERT_ACTUAL_CONFLICT_DATA 151
-#define STMT_151_INFO {"STMT_INSERT_ACTUAL_CONFLICT_DATA", NULL}
-#define STMT_151 \
- "INSERT INTO actual_node (wc_id, local_relpath, conflict_data, parent_relpath) " \
- "VALUES (?1, ?2, ?3, ?4) " \
- ""
-
-#define STMT_SELECT_ALL_FILES 152
-#define STMT_152_INFO {"STMT_SELECT_ALL_FILES", NULL}
-#define STMT_152 \
+#define STMT_SELECT_ALL_FILES 153
+#define STMT_153_INFO {"STMT_SELECT_ALL_FILES", NULL}
+#define STMT_153 \
"SELECT local_relpath FROM nodes_current " \
"WHERE wc_id = ?1 AND parent_relpath = ?2 AND kind = 'file' " \
""
-#define STMT_UPDATE_NODE_PROPS 153
-#define STMT_153_INFO {"STMT_UPDATE_NODE_PROPS", NULL}
-#define STMT_153 \
+#define STMT_UPDATE_NODE_PROPS 154
+#define STMT_154_INFO {"STMT_UPDATE_NODE_PROPS", NULL}
+#define STMT_154 \
"UPDATE nodes SET properties = ?4 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
""
-#define STMT_PRAGMA_TABLE_INFO_NODES 154
-#define STMT_154_INFO {"STMT_PRAGMA_TABLE_INFO_NODES", NULL}
-#define STMT_154 \
+#define STMT_PRAGMA_TABLE_INFO_NODES 155
+#define STMT_155_INFO {"STMT_PRAGMA_TABLE_INFO_NODES", NULL}
+#define STMT_155 \
"PRAGMA table_info(\"NODES\") " \
""
-#define STMT_CREATE_TARGET_PROP_CACHE 155
-#define STMT_155_INFO {"STMT_CREATE_TARGET_PROP_CACHE", NULL}
-#define STMT_155 \
+#define STMT_CREATE_TARGET_PROP_CACHE 156
+#define STMT_156_INFO {"STMT_CREATE_TARGET_PROP_CACHE", NULL}
+#define STMT_156 \
"DROP TABLE IF EXISTS target_prop_cache; " \
"CREATE TEMPORARY TABLE target_prop_cache ( " \
" local_relpath TEXT NOT NULL PRIMARY KEY, " \
@@ -1590,9 +1666,9 @@
"); " \
""
-#define STMT_CACHE_TARGET_PROPS 156
-#define STMT_156_INFO {"STMT_CACHE_TARGET_PROPS", NULL}
-#define STMT_156 \
+#define STMT_CACHE_TARGET_PROPS 157
+#define STMT_157_INFO {"STMT_CACHE_TARGET_PROPS", NULL}
+#define STMT_157 \
"INSERT INTO target_prop_cache(local_relpath, kind, properties) " \
" SELECT n.local_relpath, n.kind, " \
" IFNULL((SELECT properties FROM actual_node AS a " \
@@ -1611,9 +1687,9 @@
" ORDER BY t.local_relpath " \
""
-#define STMT_CACHE_TARGET_PRISTINE_PROPS 157
-#define STMT_157_INFO {"STMT_CACHE_TARGET_PRISTINE_PROPS", NULL}
-#define STMT_157 \
+#define STMT_CACHE_TARGET_PRISTINE_PROPS 158
+#define STMT_158_INFO {"STMT_CACHE_TARGET_PRISTINE_PROPS", NULL}
+#define STMT_158 \
"INSERT INTO target_prop_cache(local_relpath, kind, properties) " \
" SELECT n.local_relpath, n.kind, " \
" CASE n.presence " \
@@ -1638,22 +1714,22 @@
" ORDER BY t.local_relpath " \
""
-#define STMT_SELECT_ALL_TARGET_PROP_CACHE 158
-#define STMT_158_INFO {"STMT_SELECT_ALL_TARGET_PROP_CACHE", NULL}
-#define STMT_158 \
+#define STMT_SELECT_ALL_TARGET_PROP_CACHE 159
+#define STMT_159_INFO {"STMT_SELECT_ALL_TARGET_PROP_CACHE", NULL}
+#define STMT_159 \
"SELECT local_relpath, properties FROM target_prop_cache " \
"ORDER BY local_relpath " \
""
-#define STMT_DROP_TARGET_PROP_CACHE 159
-#define STMT_159_INFO {"STMT_DROP_TARGET_PROP_CACHE", NULL}
-#define STMT_159 \
+#define STMT_DROP_TARGET_PROP_CACHE 160
+#define STMT_160_INFO {"STMT_DROP_TARGET_PROP_CACHE", NULL}
+#define STMT_160 \
"DROP TABLE target_prop_cache; " \
""
-#define STMT_CREATE_REVERT_LIST 160
-#define STMT_160_INFO {"STMT_CREATE_REVERT_LIST", NULL}
-#define STMT_160 \
+#define STMT_CREATE_REVERT_LIST 161
+#define STMT_161_INFO {"STMT_CREATE_REVERT_LIST", NULL}
+#define STMT_161 \
"DROP TABLE IF EXISTS revert_list; " \
"CREATE TEMPORARY TABLE revert_list ( " \
" local_relpath TEXT NOT NULL, " \
@@ -1687,8 +1763,9 @@
" WHERE n.wc_id = OLD.wc_id " \
" AND n.local_relpath = OLD.local_relpath) " \
" THEN 1 " \
- " ELSE NULL " \
- " END; " \
+ " END notify " \
+ " WHERE OLD.conflict_data IS NOT NULL " \
+ " OR notify IS NOT NULL; " \
"END; " \
"DROP TRIGGER IF EXISTS trigger_revert_list_actual_update; " \
"CREATE TEMPORARY TRIGGER trigger_revert_list_actual_update " \
@@ -1704,31 +1781,32 @@
" WHERE n.wc_id = OLD.wc_id " \
" AND n.local_relpath = OLD.local_relpath) " \
" THEN 1 " \
- " ELSE NULL " \
- " END; " \
+ " END notify " \
+ " WHERE OLD.conflict_data IS NOT NULL " \
+ " OR notify IS NOT NULL; " \
"END " \
""
-#define STMT_DROP_REVERT_LIST_TRIGGERS 161
-#define STMT_161_INFO {"STMT_DROP_REVERT_LIST_TRIGGERS", NULL}
-#define STMT_161 \
+#define STMT_DROP_REVERT_LIST_TRIGGERS 162
+#define STMT_162_INFO {"STMT_DROP_REVERT_LIST_TRIGGERS", NULL}
+#define STMT_162 \
"DROP TRIGGER trigger_revert_list_nodes; " \
"DROP TRIGGER trigger_revert_list_actual_delete; " \
"DROP TRIGGER trigger_revert_list_actual_update " \
""
-#define STMT_SELECT_REVERT_LIST 162
-#define STMT_162_INFO {"STMT_SELECT_REVERT_LIST", NULL}
-#define STMT_162 \
+#define STMT_SELECT_REVERT_LIST 163
+#define STMT_163_INFO {"STMT_SELECT_REVERT_LIST", NULL}
+#define STMT_163 \
"SELECT actual, notify, kind, op_depth, repos_id, conflict_data " \
"FROM revert_list " \
"WHERE local_relpath = ?1 " \
"ORDER BY actual DESC " \
""
-#define STMT_SELECT_REVERT_LIST_COPIED_CHILDREN 163
-#define STMT_163_INFO {"STMT_SELECT_REVERT_LIST_COPIED_CHILDREN", NULL}
-#define STMT_163 \
+#define STMT_SELECT_REVERT_LIST_COPIED_CHILDREN 164
+#define STMT_164_INFO {"STMT_SELECT_REVERT_LIST_COPIED_CHILDREN", NULL}
+#define STMT_164 \
"SELECT local_relpath, kind " \
"FROM revert_list " \
"WHERE (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END)) " \
@@ -1737,113 +1815,125 @@
"ORDER BY local_relpath " \
""
-#define STMT_DELETE_REVERT_LIST 164
-#define STMT_164_INFO {"STMT_DELETE_REVERT_LIST", NULL}
-#define STMT_164 \
- "DELETE FROM revert_list WHERE local_relpath = ?1 " \
- ""
-
-#define STMT_SELECT_REVERT_LIST_RECURSIVE 165
-#define STMT_165_INFO {"STMT_SELECT_REVERT_LIST_RECURSIVE", NULL}
+#define STMT_DELETE_REVERT_LIST 165
+#define STMT_165_INFO {"STMT_DELETE_REVERT_LIST", NULL}
#define STMT_165 \
- "SELECT DISTINCT local_relpath " \
- "FROM revert_list " \
- "WHERE (local_relpath = ?1 " \
- " OR (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END))) " \
- " AND (notify OR actual = 0) " \
- "ORDER BY local_relpath " \
+ "DELETE FROM revert_list WHERE local_relpath = ?1 " \
""
-#define STMT_DELETE_REVERT_LIST_RECURSIVE 166
-#define STMT_166_INFO {"STMT_DELETE_REVERT_LIST_RECURSIVE", NULL}
+#define STMT_SELECT_REVERT_LIST_RECURSIVE 166
+#define STMT_166_INFO {"STMT_SELECT_REVERT_LIST_RECURSIVE", NULL}
#define STMT_166 \
+ "SELECT p.local_relpath, n.kind, a.notify, a.kind " \
+ "FROM (SELECT DISTINCT local_relpath " \
+ " FROM revert_list " \
+ " WHERE (local_relpath = ?1 " \
+ " OR (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END)))) p " \
+ "LEFT JOIN revert_list n ON n.local_relpath=p.local_relpath AND n.actual=0 " \
+ "LEFT JOIN revert_list a ON a.local_relpath=p.local_relpath AND a.actual=1 " \
+ "ORDER BY p.local_relpath " \
+ ""
+
+#define STMT_DELETE_REVERT_LIST_RECURSIVE 167
+#define STMT_167_INFO {"STMT_DELETE_REVERT_LIST_RECURSIVE", NULL}
+#define STMT_167 \
"DELETE FROM revert_list " \
"WHERE (local_relpath = ?1 " \
" OR (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END))) " \
""
-#define STMT_DROP_REVERT_LIST 167
-#define STMT_167_INFO {"STMT_DROP_REVERT_LIST", NULL}
-#define STMT_167 \
+#define STMT_DROP_REVERT_LIST 168
+#define STMT_168_INFO {"STMT_DROP_REVERT_LIST", NULL}
+#define STMT_168 \
"DROP TABLE IF EXISTS revert_list " \
""
-#define STMT_CREATE_DELETE_LIST 168
-#define STMT_168_INFO {"STMT_CREATE_DELETE_LIST", NULL}
-#define STMT_168 \
+#define STMT_CREATE_DELETE_LIST 169
+#define STMT_169_INFO {"STMT_CREATE_DELETE_LIST", NULL}
+#define STMT_169 \
"DROP TABLE IF EXISTS delete_list; " \
"CREATE TEMPORARY TABLE delete_list ( " \
" local_relpath TEXT PRIMARY KEY NOT NULL UNIQUE " \
" ) " \
""
-#define STMT_INSERT_DELETE_LIST 169
-#define STMT_169_INFO {"STMT_INSERT_DELETE_LIST", NULL}
-#define STMT_169 \
+#define STMT_INSERT_DELETE_LIST 170
+#define STMT_170_INFO {"STMT_INSERT_DELETE_LIST", NULL}
+#define STMT_170 \
"INSERT INTO delete_list(local_relpath) " \
+ "SELECT ?2 " \
+ "UNION ALL " \
"SELECT local_relpath FROM nodes AS n " \
"WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 " \
- " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
+ " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
" AND op_depth >= ?3 " \
" AND op_depth = (SELECT MAX(s.op_depth) FROM nodes AS s " \
" WHERE s.wc_id = ?1 " \
" AND s.local_relpath = n.local_relpath) " \
" AND presence NOT IN ('base-deleted', 'not-present', 'excluded', 'server-excluded') " \
" AND file_external IS NULL " \
+ "ORDER by local_relpath " \
""
-#define STMT_SELECT_DELETE_LIST 170
-#define STMT_170_INFO {"STMT_SELECT_DELETE_LIST", NULL}
-#define STMT_170 \
+#define STMT_SELECT_DELETE_LIST 171
+#define STMT_171_INFO {"STMT_SELECT_DELETE_LIST", NULL}
+#define STMT_171 \
"SELECT local_relpath FROM delete_list " \
"ORDER BY local_relpath " \
""
-#define STMT_FINALIZE_DELETE 171
-#define STMT_171_INFO {"STMT_FINALIZE_DELETE", NULL}
-#define STMT_171 \
+#define STMT_FINALIZE_DELETE 172
+#define STMT_172_INFO {"STMT_FINALIZE_DELETE", NULL}
+#define STMT_172 \
"DROP TABLE IF EXISTS delete_list " \
""
-#define STMT_CREATE_UPDATE_MOVE_LIST 172
-#define STMT_172_INFO {"STMT_CREATE_UPDATE_MOVE_LIST", NULL}
-#define STMT_172 \
+#define STMT_CREATE_UPDATE_MOVE_LIST 173
+#define STMT_173_INFO {"STMT_CREATE_UPDATE_MOVE_LIST", NULL}
+#define STMT_173 \
"DROP TABLE IF EXISTS update_move_list; " \
"CREATE TEMPORARY TABLE update_move_list ( " \
" local_relpath TEXT PRIMARY KEY NOT NULL UNIQUE, " \
" action INTEGER NOT NULL, " \
- " kind INTEGER NOT NULL, " \
+ " kind TEXT NOT NULL, " \
" content_state INTEGER NOT NULL, " \
" prop_state INTEGER NOT NULL " \
" ) " \
""
-#define STMT_INSERT_UPDATE_MOVE_LIST 173
-#define STMT_173_INFO {"STMT_INSERT_UPDATE_MOVE_LIST", NULL}
-#define STMT_173 \
+#define STMT_INSERT_UPDATE_MOVE_LIST 174
+#define STMT_174_INFO {"STMT_INSERT_UPDATE_MOVE_LIST", NULL}
+#define STMT_174 \
"INSERT INTO update_move_list(local_relpath, action, kind, content_state, " \
" prop_state) " \
"VALUES (?1, ?2, ?3, ?4, ?5) " \
""
-#define STMT_SELECT_UPDATE_MOVE_LIST 174
-#define STMT_174_INFO {"STMT_SELECT_UPDATE_MOVE_LIST", NULL}
-#define STMT_174 \
+#define STMT_SELECT_UPDATE_MOVE_LIST 175
+#define STMT_175_INFO {"STMT_SELECT_UPDATE_MOVE_LIST", NULL}
+#define STMT_175 \
"SELECT local_relpath, action, kind, content_state, prop_state " \
"FROM update_move_list " \
"ORDER BY local_relpath " \
""
-#define STMT_FINALIZE_UPDATE_MOVE 175
-#define STMT_175_INFO {"STMT_FINALIZE_UPDATE_MOVE", NULL}
-#define STMT_175 \
+#define STMT_FINALIZE_UPDATE_MOVE 176
+#define STMT_176_INFO {"STMT_FINALIZE_UPDATE_MOVE", NULL}
+#define STMT_176 \
"DROP TABLE IF EXISTS update_move_list " \
""
-#define STMT_SELECT_MIN_MAX_REVISIONS 176
-#define STMT_176_INFO {"STMT_SELECT_MIN_MAX_REVISIONS", NULL}
-#define STMT_176 \
+#define STMT_MOVE_NOTIFY_TO_REVERT 177
+#define STMT_177_INFO {"STMT_MOVE_NOTIFY_TO_REVERT", NULL}
+#define STMT_177 \
+ "INSERT INTO revert_list (local_relpath, notify, kind, actual) " \
+ " SELECT local_relpath, 2, kind, 1 FROM update_move_list; " \
+ "DROP TABLE update_move_list " \
+ ""
+
+#define STMT_SELECT_MIN_MAX_REVISIONS 178
+#define STMT_178_INFO {"STMT_SELECT_MIN_MAX_REVISIONS", NULL}
+#define STMT_178 \
"SELECT MIN(revision), MAX(revision), " \
" MIN(changed_revision), MAX(changed_revision) FROM nodes " \
" WHERE wc_id = ?1 " \
@@ -1854,9 +1944,9 @@
" AND op_depth = 0 " \
""
-#define STMT_HAS_SPARSE_NODES 177
-#define STMT_177_INFO {"STMT_HAS_SPARSE_NODES", NULL}
-#define STMT_177 \
+#define STMT_HAS_SPARSE_NODES 179
+#define STMT_179_INFO {"STMT_HAS_SPARSE_NODES", NULL}
+#define STMT_179 \
"SELECT 1 FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
@@ -1868,9 +1958,9 @@
"LIMIT 1 " \
""
-#define STMT_SUBTREE_HAS_TREE_MODIFICATIONS 178
-#define STMT_178_INFO {"STMT_SUBTREE_HAS_TREE_MODIFICATIONS", NULL}
-#define STMT_178 \
+#define STMT_SUBTREE_HAS_TREE_MODIFICATIONS 180
+#define STMT_180_INFO {"STMT_SUBTREE_HAS_TREE_MODIFICATIONS", NULL}
+#define STMT_180 \
"SELECT 1 FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
@@ -1879,9 +1969,9 @@
"LIMIT 1 " \
""
-#define STMT_SUBTREE_HAS_PROP_MODIFICATIONS 179
-#define STMT_179_INFO {"STMT_SUBTREE_HAS_PROP_MODIFICATIONS", NULL}
-#define STMT_179 \
+#define STMT_SUBTREE_HAS_PROP_MODIFICATIONS 181
+#define STMT_181_INFO {"STMT_SUBTREE_HAS_PROP_MODIFICATIONS", NULL}
+#define STMT_181 \
"SELECT 1 FROM actual_node " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
@@ -1890,9 +1980,9 @@
"LIMIT 1 " \
""
-#define STMT_HAS_SWITCHED 180
-#define STMT_180_INFO {"STMT_HAS_SWITCHED", NULL}
-#define STMT_180 \
+#define STMT_HAS_SWITCHED 182
+#define STMT_182_INFO {"STMT_HAS_SWITCHED", NULL}
+#define STMT_182 \
"SELECT 1 " \
"FROM nodes " \
"WHERE wc_id = ?1 " \
@@ -1904,60 +1994,47 @@
"LIMIT 1 " \
""
-#define STMT_SELECT_BASE_FILES_RECURSIVE 181
-#define STMT_181_INFO {"STMT_SELECT_BASE_FILES_RECURSIVE", NULL}
-#define STMT_181 \
- "SELECT local_relpath, translated_size, last_mod_time FROM nodes AS n " \
- "WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 " \
- " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND op_depth = 0 " \
- " AND kind='file' " \
- " AND presence='normal' " \
- " AND file_external IS NULL " \
- ""
-
-#define STMT_SELECT_MOVED_FROM_RELPATH 182
-#define STMT_182_INFO {"STMT_SELECT_MOVED_FROM_RELPATH", NULL}
-#define STMT_182 \
+#define STMT_SELECT_MOVED_FROM_RELPATH 183
+#define STMT_183_INFO {"STMT_SELECT_MOVED_FROM_RELPATH", NULL}
+#define STMT_183 \
"SELECT local_relpath, op_depth FROM nodes " \
"WHERE wc_id = ?1 AND moved_to = ?2 AND op_depth > 0 " \
""
-#define STMT_UPDATE_MOVED_TO_RELPATH 183
-#define STMT_183_INFO {"STMT_UPDATE_MOVED_TO_RELPATH", NULL}
-#define STMT_183 \
+#define STMT_UPDATE_MOVED_TO_RELPATH 184
+#define STMT_184_INFO {"STMT_UPDATE_MOVED_TO_RELPATH", NULL}
+#define STMT_184 \
"UPDATE nodes SET moved_to = ?4 " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
""
-#define STMT_CLEAR_MOVED_TO_RELPATH 184
-#define STMT_184_INFO {"STMT_CLEAR_MOVED_TO_RELPATH", NULL}
-#define STMT_184 \
+#define STMT_CLEAR_MOVED_TO_RELPATH 185
+#define STMT_185_INFO {"STMT_CLEAR_MOVED_TO_RELPATH", NULL}
+#define STMT_185 \
"UPDATE nodes SET moved_to = NULL " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \
""
-#define STMT_CLEAR_MOVED_HERE_RECURSIVE 185
-#define STMT_185_INFO {"STMT_CLEAR_MOVED_HERE_RECURSIVE", NULL}
-#define STMT_185 \
+#define STMT_CLEAR_MOVED_HERE_RECURSIVE 186
+#define STMT_186_INFO {"STMT_CLEAR_MOVED_HERE_RECURSIVE", NULL}
+#define STMT_186 \
"UPDATE nodes SET moved_here = NULL " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
" AND op_depth = ?3 " \
""
-#define STMT_SELECT_MOVED_HERE_CHILDREN 186
-#define STMT_186_INFO {"STMT_SELECT_MOVED_HERE_CHILDREN", NULL}
-#define STMT_186 \
+#define STMT_SELECT_MOVED_HERE_CHILDREN 187
+#define STMT_187_INFO {"STMT_SELECT_MOVED_HERE_CHILDREN", NULL}
+#define STMT_187 \
"SELECT moved_to, local_relpath FROM nodes " \
"WHERE wc_id = ?1 AND op_depth > 0 " \
" AND (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_SELECT_MOVED_FOR_DELETE 187
-#define STMT_187_INFO {"STMT_SELECT_MOVED_FOR_DELETE", NULL}
-#define STMT_187 \
+#define STMT_SELECT_MOVED_FOR_DELETE 188
+#define STMT_188_INFO {"STMT_SELECT_MOVED_FOR_DELETE", NULL}
+#define STMT_188 \
"SELECT local_relpath, moved_to, op_depth, " \
" (SELECT CASE WHEN r.moved_here THEN r.op_depth END FROM nodes r " \
" WHERE r.wc_id = ?1 " \
@@ -1971,9 +2048,9 @@
" AND op_depth >= ?3 " \
""
-#define STMT_SELECT_MOVED_FROM_FOR_DELETE 188
-#define STMT_188_INFO {"STMT_SELECT_MOVED_FROM_FOR_DELETE", NULL}
-#define STMT_188 \
+#define STMT_SELECT_MOVED_FROM_FOR_DELETE 189
+#define STMT_189_INFO {"STMT_SELECT_MOVED_FROM_FOR_DELETE", NULL}
+#define STMT_189 \
"SELECT local_relpath, op_depth, " \
" (SELECT CASE WHEN r.moved_here THEN r.op_depth END FROM nodes r " \
" WHERE r.wc_id = ?1 " \
@@ -1984,48 +2061,48 @@
"WHERE wc_id = ?1 AND moved_to = ?2 AND op_depth > 0 " \
""
-#define STMT_UPDATE_MOVED_TO_DESCENDANTS 189
-#define STMT_189_INFO {"STMT_UPDATE_MOVED_TO_DESCENDANTS", NULL}
-#define STMT_189 \
+#define STMT_UPDATE_MOVED_TO_DESCENDANTS 190
+#define STMT_190_INFO {"STMT_UPDATE_MOVED_TO_DESCENDANTS", NULL}
+#define STMT_190 \
"UPDATE nodes SET moved_to = (CASE WHEN (?2) = '' THEN (CASE WHEN (?3) = '' THEN (moved_to) WHEN (moved_to) = '' THEN (?3) ELSE (?3) || '/' || (moved_to) END) WHEN (?3) = '' THEN (CASE WHEN (?2) = '' THEN (moved_to) WHEN SUBSTR((moved_to), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(moved_to) THEN '' WHEN SUBSTR((moved_to), LENGTH(?2)+1, 1) = '/' THEN SUBSTR((moved_to), LENGTH(?2)+2) END END) WHEN SUBSTR((moved_to), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(moved_to) THEN (?3) WHEN SUBSTR((moved_to), LENGTH(?2)+1, 1) = '/' THEN (?3) || SUBSTR((moved_to), LENGTH(?2)+1) END END) " \
" WHERE wc_id = ?1 " \
" AND (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_CLEAR_MOVED_TO_DESCENDANTS 190
-#define STMT_190_INFO {"STMT_CLEAR_MOVED_TO_DESCENDANTS", NULL}
-#define STMT_190 \
+#define STMT_CLEAR_MOVED_TO_DESCENDANTS 191
+#define STMT_191_INFO {"STMT_CLEAR_MOVED_TO_DESCENDANTS", NULL}
+#define STMT_191 \
"UPDATE nodes SET moved_to = NULL " \
" WHERE wc_id = ?1 " \
" AND (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_SELECT_MOVED_PAIR2 191
-#define STMT_191_INFO {"STMT_SELECT_MOVED_PAIR2", NULL}
-#define STMT_191 \
- "SELECT local_relpath, moved_to, op_depth FROM nodes " \
- "WHERE wc_id = ?1 " \
- " AND (local_relpath = ?2 OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
- " AND moved_to IS NOT NULL " \
- " AND NOT (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND op_depth >= (SELECT MAX(op_depth) FROM nodes o " \
- " WHERE o.wc_id = ?1 " \
- " AND o.local_relpath = ?2) " \
- ""
-
#define STMT_SELECT_MOVED_PAIR3 192
#define STMT_192_INFO {"STMT_SELECT_MOVED_PAIR3", NULL}
#define STMT_192 \
- "SELECT local_relpath, moved_to, op_depth, kind FROM nodes " \
- "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 " \
- " AND moved_to IS NOT NULL " \
+ "SELECT n.local_relpath, d.moved_to, d.op_depth, n.kind " \
+ "FROM nodes n " \
+ "JOIN nodes d ON d.wc_id = ?1 AND d.local_relpath = n.local_relpath " \
+ " AND d.op_depth = (SELECT MIN(dd.op_depth) " \
+ " FROM nodes dd " \
+ " WHERE dd.wc_id = ?1 " \
+ " AND dd.local_relpath = d.local_relpath " \
+ " AND dd.op_depth > ?3) " \
+ "WHERE n.wc_id = ?1 AND n.local_relpath = ?2 AND n.op_depth = ?3 " \
+ " AND d.moved_to IS NOT NULL " \
"UNION ALL " \
- "SELECT local_relpath, moved_to, op_depth, kind FROM nodes " \
- "WHERE wc_id = ?1 " \
- " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND op_depth > ?3 " \
- " AND moved_to IS NOT NULL " \
- "ORDER BY local_relpath, op_depth " \
+ "SELECT n.local_relpath, d.moved_to, d.op_depth, n.kind " \
+ "FROM nodes n " \
+ "JOIN nodes d ON d.wc_id = ?1 AND d.local_relpath = n.local_relpath " \
+ " AND d.op_depth = (SELECT MIN(dd.op_depth) " \
+ " FROM nodes dd " \
+ " WHERE dd.wc_id = ?1 " \
+ " AND dd.local_relpath = d.local_relpath " \
+ " AND dd.op_depth > ?3) " \
+ "WHERE n.wc_id = ?1 AND (((n.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((n.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
+ " AND n.op_depth = ?3 " \
+ " AND d.moved_to IS NOT NULL " \
+ "ORDER BY n.local_relpath " \
""
#define STMT_SELECT_MOVED_OUTSIDE 193
@@ -2039,44 +2116,27 @@
" AND NOT (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
""
-#define STMT_SELECT_OP_DEPTH_MOVED_PAIR 194
-#define STMT_194_INFO {"STMT_SELECT_OP_DEPTH_MOVED_PAIR", NULL}
+#define STMT_SELECT_MOVED_DESCENDANTS_SRC 194
+#define STMT_194_INFO {"STMT_SELECT_MOVED_DESCENDANTS_SRC", NULL}
#define STMT_194 \
- "SELECT n.local_relpath, n.moved_to, " \
- " (SELECT o.repos_path FROM nodes AS o " \
- " WHERE o.wc_id = n.wc_id " \
- " AND o.local_relpath = n.local_relpath " \
- " AND o.op_depth < ?3 ORDER BY o.op_depth DESC LIMIT 1) " \
- "FROM nodes AS n " \
- "WHERE n.wc_id = ?1 " \
- " AND (((n.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((n.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND n.op_depth = ?3 " \
- " AND n.moved_to IS NOT NULL " \
- ""
-
-#define STMT_SELECT_MOVED_DESCENDANTS 195
-#define STMT_195_INFO {"STMT_SELECT_MOVED_DESCENDANTS", NULL}
+ "SELECT s.op_depth, n.local_relpath, n.kind, n.repos_path, s.moved_to " \
+ "FROM nodes n " \
+ "JOIN nodes s ON s.wc_id = n.wc_id AND s.local_relpath = n.local_relpath " \
+ " AND s.op_depth = (SELECT MIN(d.op_depth) " \
+ " FROM nodes d " \
+ " WHERE d.wc_id = ?1 " \
+ " AND d.local_relpath = s.local_relpath " \
+ " AND d.op_depth > ?3) " \
+ "WHERE n.wc_id = ?1 AND n.op_depth = ?3 " \
+ " AND (n.local_relpath = ?2 OR (((n.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((n.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \
+ " AND s.moved_to IS NOT NULL " \
+ ""
+
+#define STMT_COMMIT_UPDATE_ORIGIN 195
+#define STMT_195_INFO {"STMT_COMMIT_UPDATE_ORIGIN", NULL}
#define STMT_195 \
- "SELECT n.local_relpath, h.moved_to " \
- "FROM nodes n, nodes h " \
- "WHERE n.wc_id = ?1 " \
- " AND h.wc_id = ?1 " \
- " AND (((n.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((n.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND h.local_relpath = n.local_relpath " \
- " AND n.op_depth = ?3 " \
- " AND h.op_depth = (SELECT MIN(o.op_depth) " \
- " FROM nodes o " \
- " WHERE o.wc_id = ?1 " \
- " AND o.local_relpath = n.local_relpath " \
- " AND o.op_depth > ?3) " \
- " AND h.moved_to IS NOT NULL " \
- ""
-
-#define STMT_COMMIT_UPDATE_ORIGIN 196
-#define STMT_196_INFO {"STMT_COMMIT_UPDATE_ORIGIN", NULL}
-#define STMT_196 \
"UPDATE nodes SET repos_id = ?4, " \
- " repos_path = ?5 || SUBSTR(local_relpath, LENGTH(?2)+1), " \
+ " repos_path = (CASE WHEN (?2) = '' THEN (CASE WHEN (?5) = '' THEN (local_relpath) WHEN (local_relpath) = '' THEN (?5) ELSE (?5) || '/' || (local_relpath) END) WHEN (?5) = '' THEN (CASE WHEN (?2) = '' THEN (local_relpath) WHEN SUBSTR((local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(local_relpath) THEN '' WHEN SUBSTR((local_relpath), LENGTH(?2)+1, 1) = '/' THEN SUBSTR((local_relpath), LENGTH(?2)+2) END END) WHEN SUBSTR((local_relpath), 1, LENGTH(?2)) = (?2) THEN CASE WHEN LENGTH(?2) = LENGTH(local_relpath) THEN (?5) WHEN SUBSTR((local_relpath), LENGTH(?2)+1, 1) = '/' THEN (?5) || SUBSTR((local_relpath), LENGTH(?2)+1) END END), " \
" revision = ?6 " \
"WHERE wc_id = ?1 " \
" AND (local_relpath = ?2 " \
@@ -2084,16 +2144,16 @@
" AND op_depth = ?3 " \
""
-#define STMT_HAS_LAYER_BETWEEN 197
-#define STMT_197_INFO {"STMT_HAS_LAYER_BETWEEN", NULL}
-#define STMT_197 \
+#define STMT_HAS_LAYER_BETWEEN 196
+#define STMT_196_INFO {"STMT_HAS_LAYER_BETWEEN", NULL}
+#define STMT_196 \
"SELECT 1 FROM NODES " \
"WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 AND op_depth < ?4 " \
""
-#define STMT_SELECT_REPOS_PATH_REVISION 198
-#define STMT_198_INFO {"STMT_SELECT_REPOS_PATH_REVISION", NULL}
-#define STMT_198 \
+#define STMT_SELECT_REPOS_PATH_REVISION 197
+#define STMT_197_INFO {"STMT_SELECT_REPOS_PATH_REVISION", NULL}
+#define STMT_197 \
"SELECT local_relpath, repos_path, revision FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
@@ -2101,50 +2161,52 @@
"ORDER BY local_relpath " \
""
-#define STMT_SELECT_HAS_NON_FILE_CHILDREN 199
-#define STMT_199_INFO {"STMT_SELECT_HAS_NON_FILE_CHILDREN", NULL}
-#define STMT_199 \
+#define STMT_SELECT_HAS_NON_FILE_CHILDREN 198
+#define STMT_198_INFO {"STMT_SELECT_HAS_NON_FILE_CHILDREN", NULL}
+#define STMT_198 \
"SELECT 1 FROM nodes " \
- "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 AND kind != 'file' " \
+ "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = ?3 AND kind != 'file' " \
+ "LIMIT 1 " \
""
-#define STMT_SELECT_HAS_GRANDCHILDREN 200
-#define STMT_200_INFO {"STMT_SELECT_HAS_GRANDCHILDREN", NULL}
-#define STMT_200 \
+#define STMT_SELECT_HAS_GRANDCHILDREN 199
+#define STMT_199_INFO {"STMT_SELECT_HAS_GRANDCHILDREN", NULL}
+#define STMT_199 \
"SELECT 1 FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((parent_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((parent_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
- " AND op_depth = 0 " \
+ " AND op_depth = ?3 " \
" AND file_external IS NULL " \
+ "LIMIT 1 " \
""
-#define STMT_SELECT_ALL_NODES 201
-#define STMT_201_INFO {"STMT_SELECT_ALL_NODES", NULL}
-#define STMT_201 \
+#define STMT_SELECT_ALL_NODES 200
+#define STMT_200_INFO {"STMT_SELECT_ALL_NODES", NULL}
+#define STMT_200 \
"SELECT op_depth, local_relpath, parent_relpath, file_external FROM nodes " \
"WHERE wc_id = ?1 " \
""
-#define STMT_SELECT_IPROPS 202
-#define STMT_202_INFO {"STMT_SELECT_IPROPS", NULL}
-#define STMT_202 \
+#define STMT_SELECT_IPROPS 201
+#define STMT_201_INFO {"STMT_SELECT_IPROPS", NULL}
+#define STMT_201 \
"SELECT inherited_props FROM nodes " \
"WHERE wc_id = ?1 " \
" AND local_relpath = ?2 " \
" AND op_depth = 0 " \
""
-#define STMT_UPDATE_IPROP 203
-#define STMT_203_INFO {"STMT_UPDATE_IPROP", NULL}
-#define STMT_203 \
+#define STMT_UPDATE_IPROP 202
+#define STMT_202_INFO {"STMT_UPDATE_IPROP", NULL}
+#define STMT_202 \
"UPDATE nodes " \
"SET inherited_props = ?3 " \
"WHERE (wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0) " \
""
-#define STMT_SELECT_IPROPS_NODE 204
-#define STMT_204_INFO {"STMT_SELECT_IPROPS_NODE", NULL}
-#define STMT_204 \
+#define STMT_SELECT_IPROPS_NODE 203
+#define STMT_203_INFO {"STMT_SELECT_IPROPS_NODE", NULL}
+#define STMT_203 \
"SELECT local_relpath, repos_path FROM nodes " \
"WHERE wc_id = ?1 " \
" AND local_relpath = ?2 " \
@@ -2152,9 +2214,9 @@
" AND (inherited_props not null) " \
""
-#define STMT_SELECT_IPROPS_RECURSIVE 205
-#define STMT_205_INFO {"STMT_SELECT_IPROPS_RECURSIVE", NULL}
-#define STMT_205 \
+#define STMT_SELECT_IPROPS_RECURSIVE 204
+#define STMT_204_INFO {"STMT_SELECT_IPROPS_RECURSIVE", NULL}
+#define STMT_204 \
"SELECT local_relpath, repos_path FROM nodes " \
"WHERE wc_id = ?1 " \
" AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \
@@ -2162,9 +2224,9 @@
" AND (inherited_props not null) " \
""
-#define STMT_SELECT_IPROPS_CHILDREN 206
-#define STMT_206_INFO {"STMT_SELECT_IPROPS_CHILDREN", NULL}
-#define STMT_206 \
+#define STMT_SELECT_IPROPS_CHILDREN 205
+#define STMT_205_INFO {"STMT_SELECT_IPROPS_CHILDREN", NULL}
+#define STMT_205 \
"SELECT local_relpath, repos_path FROM nodes " \
"WHERE wc_id = ?1 " \
" AND parent_relpath = ?2 " \
@@ -2172,16 +2234,16 @@
" AND (inherited_props not null) " \
""
-#define STMT_HAVE_STAT1_TABLE 207
-#define STMT_207_INFO {"STMT_HAVE_STAT1_TABLE", NULL}
-#define STMT_207 \
+#define STMT_HAVE_STAT1_TABLE 206
+#define STMT_206_INFO {"STMT_HAVE_STAT1_TABLE", NULL}
+#define STMT_206 \
"SELECT 1 FROM sqlite_master WHERE name='sqlite_stat1' AND type='table' " \
"LIMIT 1 " \
""
-#define STMT_CREATE_SCHEMA 208
-#define STMT_208_INFO {"STMT_CREATE_SCHEMA", NULL}
-#define STMT_208 \
+#define STMT_CREATE_SCHEMA 207
+#define STMT_207_INFO {"STMT_CREATE_SCHEMA", NULL}
+#define STMT_207 \
"CREATE TABLE REPOSITORY ( " \
" id INTEGER PRIMARY KEY AUTOINCREMENT, " \
" root TEXT UNIQUE NOT NULL, " \
@@ -2246,9 +2308,9 @@
"; " \
""
-#define STMT_CREATE_NODES 209
-#define STMT_209_INFO {"STMT_CREATE_NODES", NULL}
-#define STMT_209 \
+#define STMT_CREATE_NODES 208
+#define STMT_208_INFO {"STMT_CREATE_NODES", NULL}
+#define STMT_208 \
"CREATE TABLE NODES ( " \
" wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \
" local_relpath TEXT NOT NULL, " \
@@ -2288,9 +2350,9 @@
" WHERE op_depth = 0; " \
""
-#define STMT_CREATE_NODES_TRIGGERS 210
-#define STMT_210_INFO {"STMT_CREATE_NODES_TRIGGERS", NULL}
-#define STMT_210 \
+#define STMT_CREATE_NODES_TRIGGERS 209
+#define STMT_209_INFO {"STMT_CREATE_NODES_TRIGGERS", NULL}
+#define STMT_209 \
"CREATE TRIGGER nodes_insert_trigger " \
"AFTER INSERT ON nodes " \
"WHEN NEW.checksum IS NOT NULL " \
@@ -2316,9 +2378,9 @@
"END; " \
""
-#define STMT_CREATE_EXTERNALS 211
-#define STMT_211_INFO {"STMT_CREATE_EXTERNALS", NULL}
-#define STMT_211 \
+#define STMT_CREATE_EXTERNALS 210
+#define STMT_210_INFO {"STMT_CREATE_EXTERNALS", NULL}
+#define STMT_210 \
"CREATE TABLE EXTERNALS ( " \
" wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \
" local_relpath TEXT NOT NULL, " \
@@ -2337,32 +2399,36 @@
" local_relpath); " \
""
-#define STMT_INSTALL_SCHEMA_STATISTICS 212
-#define STMT_212_INFO {"STMT_INSTALL_SCHEMA_STATISTICS", NULL}
-#define STMT_212 \
+#define STMT_INSTALL_SCHEMA_STATISTICS 211
+#define STMT_211_INFO {"STMT_INSTALL_SCHEMA_STATISTICS", NULL}
+#define STMT_211 \
"ANALYZE sqlite_master; " \
"DELETE FROM sqlite_stat1 " \
- "WHERE tbl in ('NODES', 'ACTUAL_NODE', 'LOCK', 'WC_LOCK'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "WHERE tbl in ('NODES', 'ACTUAL_NODE', 'LOCK', 'WC_LOCK', 'EXTERNALS'); " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('NODES', 'sqlite_autoindex_NODES_1', '8000 8000 2 1'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('NODES', 'I_NODES_PARENT', '8000 8000 10 2 1'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('NODES', 'I_NODES_MOVED', '8000 8000 1 1'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('ACTUAL_NODE', 'sqlite_autoindex_ACTUAL_NODE_1', '8000 8000 1'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('ACTUAL_NODE', 'I_ACTUAL_PARENT', '8000 8000 10 1'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('LOCK', 'sqlite_autoindex_LOCK_1', '100 100 1'); " \
- "INSERT OR REPLACE INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
" ('WC_LOCK', 'sqlite_autoindex_WC_LOCK_1', '100 100 1'); " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ " ('EXTERNALS','sqlite_autoindex_EXTERNALS_1', '100 100 1'); " \
+ "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \
+ " ('EXTERNALS','I_EXTERNALS_DEFINED', '100 100 3 1'); " \
"ANALYZE sqlite_master; " \
""
-#define STMT_UPGRADE_TO_20 213
-#define STMT_213_INFO {"STMT_UPGRADE_TO_20", NULL}
-#define STMT_213 \
+#define STMT_UPGRADE_TO_20 212
+#define STMT_212_INFO {"STMT_UPGRADE_TO_20", NULL}
+#define STMT_212 \
"UPDATE BASE_NODE SET checksum = (SELECT checksum FROM pristine " \
" WHERE md5_checksum = BASE_NODE.checksum) " \
"WHERE EXISTS (SELECT 1 FROM pristine WHERE md5_checksum = BASE_NODE.checksum); " \
@@ -2403,59 +2469,59 @@
"PRAGMA user_version = 20; " \
""
-#define STMT_UPGRADE_TO_21 214
-#define STMT_214_INFO {"STMT_UPGRADE_TO_21", NULL}
-#define STMT_214 \
+#define STMT_UPGRADE_TO_21 213
+#define STMT_213_INFO {"STMT_UPGRADE_TO_21", NULL}
+#define STMT_213 \
"PRAGMA user_version = 21; " \
""
-#define STMT_UPGRADE_21_SELECT_OLD_TREE_CONFLICT 215
-#define STMT_215_INFO {"STMT_UPGRADE_21_SELECT_OLD_TREE_CONFLICT", NULL}
-#define STMT_215 \
+#define STMT_UPGRADE_21_SELECT_OLD_TREE_CONFLICT 214
+#define STMT_214_INFO {"STMT_UPGRADE_21_SELECT_OLD_TREE_CONFLICT", NULL}
+#define STMT_214 \
"SELECT wc_id, local_relpath, tree_conflict_data " \
"FROM actual_node " \
"WHERE tree_conflict_data IS NOT NULL " \
""
-#define STMT_UPGRADE_21_ERASE_OLD_CONFLICTS 216
-#define STMT_216_INFO {"STMT_UPGRADE_21_ERASE_OLD_CONFLICTS", NULL}
-#define STMT_216 \
+#define STMT_UPGRADE_21_ERASE_OLD_CONFLICTS 215
+#define STMT_215_INFO {"STMT_UPGRADE_21_ERASE_OLD_CONFLICTS", NULL}
+#define STMT_215 \
"UPDATE actual_node SET tree_conflict_data = NULL " \
""
-#define STMT_UPGRADE_TO_22 217
-#define STMT_217_INFO {"STMT_UPGRADE_TO_22", NULL}
-#define STMT_217 \
+#define STMT_UPGRADE_TO_22 216
+#define STMT_216_INFO {"STMT_UPGRADE_TO_22", NULL}
+#define STMT_216 \
"UPDATE actual_node SET tree_conflict_data = conflict_data; " \
"UPDATE actual_node SET conflict_data = NULL; " \
"PRAGMA user_version = 22; " \
""
-#define STMT_UPGRADE_TO_23 218
-#define STMT_218_INFO {"STMT_UPGRADE_TO_23", NULL}
-#define STMT_218 \
+#define STMT_UPGRADE_TO_23 217
+#define STMT_217_INFO {"STMT_UPGRADE_TO_23", NULL}
+#define STMT_217 \
"PRAGMA user_version = 23; " \
""
-#define STMT_UPGRADE_23_HAS_WORKING_NODES 219
-#define STMT_219_INFO {"STMT_UPGRADE_23_HAS_WORKING_NODES", NULL}
-#define STMT_219 \
+#define STMT_UPGRADE_23_HAS_WORKING_NODES 218
+#define STMT_218_INFO {"STMT_UPGRADE_23_HAS_WORKING_NODES", NULL}
+#define STMT_218 \
"SELECT 1 FROM nodes WHERE op_depth > 0 " \
"LIMIT 1 " \
""
-#define STMT_UPGRADE_TO_24 220
-#define STMT_220_INFO {"STMT_UPGRADE_TO_24", NULL}
-#define STMT_220 \
+#define STMT_UPGRADE_TO_24 219
+#define STMT_219_INFO {"STMT_UPGRADE_TO_24", NULL}
+#define STMT_219 \
"UPDATE pristine SET refcount = " \
" (SELECT COUNT(*) FROM nodes " \
" WHERE checksum = pristine.checksum ); " \
"PRAGMA user_version = 24; " \
""
-#define STMT_UPGRADE_TO_25 221
-#define STMT_221_INFO {"STMT_UPGRADE_TO_25", NULL}
-#define STMT_221 \
+#define STMT_UPGRADE_TO_25 220
+#define STMT_220_INFO {"STMT_UPGRADE_TO_25", NULL}
+#define STMT_220 \
"DROP VIEW IF EXISTS NODES_CURRENT; " \
"CREATE VIEW NODES_CURRENT AS " \
" SELECT * FROM nodes " \
@@ -2467,9 +2533,9 @@
"PRAGMA user_version = 25; " \
""
-#define STMT_UPGRADE_TO_26 222
-#define STMT_222_INFO {"STMT_UPGRADE_TO_26", NULL}
-#define STMT_222 \
+#define STMT_UPGRADE_TO_26 221
+#define STMT_221_INFO {"STMT_UPGRADE_TO_26", NULL}
+#define STMT_221 \
"DROP VIEW IF EXISTS NODES_BASE; " \
"CREATE VIEW NODES_BASE AS " \
" SELECT * FROM nodes " \
@@ -2477,15 +2543,15 @@
"PRAGMA user_version = 26; " \
""
-#define STMT_UPGRADE_TO_27 223
-#define STMT_223_INFO {"STMT_UPGRADE_TO_27", NULL}
-#define STMT_223 \
+#define STMT_UPGRADE_TO_27 222
+#define STMT_222_INFO {"STMT_UPGRADE_TO_27", NULL}
+#define STMT_222 \
"PRAGMA user_version = 27; " \
""
-#define STMT_UPGRADE_27_HAS_ACTUAL_NODES_CONFLICTS 224
-#define STMT_224_INFO {"STMT_UPGRADE_27_HAS_ACTUAL_NODES_CONFLICTS", NULL}
-#define STMT_224 \
+#define STMT_UPGRADE_27_HAS_ACTUAL_NODES_CONFLICTS 223
+#define STMT_223_INFO {"STMT_UPGRADE_27_HAS_ACTUAL_NODES_CONFLICTS", NULL}
+#define STMT_223 \
"SELECT 1 FROM actual_node " \
"WHERE NOT ((prop_reject IS NULL) AND (conflict_old IS NULL) " \
" AND (conflict_new IS NULL) AND (conflict_working IS NULL) " \
@@ -2493,18 +2559,18 @@
"LIMIT 1 " \
""
-#define STMT_UPGRADE_TO_28 225
-#define STMT_225_INFO {"STMT_UPGRADE_TO_28", NULL}
-#define STMT_225 \
+#define STMT_UPGRADE_TO_28 224
+#define STMT_224_INFO {"STMT_UPGRADE_TO_28", NULL}
+#define STMT_224 \
"UPDATE NODES SET checksum = (SELECT checksum FROM pristine " \
" WHERE md5_checksum = nodes.checksum) " \
"WHERE EXISTS (SELECT 1 FROM pristine WHERE md5_checksum = nodes.checksum); " \
"PRAGMA user_version = 28; " \
""
-#define STMT_UPGRADE_TO_29 226
-#define STMT_226_INFO {"STMT_UPGRADE_TO_29", NULL}
-#define STMT_226 \
+#define STMT_UPGRADE_TO_29 225
+#define STMT_225_INFO {"STMT_UPGRADE_TO_29", NULL}
+#define STMT_225 \
"DROP TRIGGER IF EXISTS nodes_update_checksum_trigger; " \
"DROP TRIGGER IF EXISTS nodes_insert_trigger; " \
"DROP TRIGGER IF EXISTS nodes_delete_trigger; " \
@@ -2534,9 +2600,9 @@
"PRAGMA user_version = 29; " \
""
-#define STMT_UPGRADE_TO_30 227
-#define STMT_227_INFO {"STMT_UPGRADE_TO_30", NULL}
-#define STMT_227 \
+#define STMT_UPGRADE_TO_30 226
+#define STMT_226_INFO {"STMT_UPGRADE_TO_30", NULL}
+#define STMT_226 \
"CREATE UNIQUE INDEX IF NOT EXISTS I_NODES_MOVED " \
"ON NODES (wc_id, moved_to, op_depth); " \
"CREATE INDEX IF NOT EXISTS I_PRISTINE_MD5 ON PRISTINE (md5_checksum); " \
@@ -2544,9 +2610,9 @@
"UPDATE nodes SET file_external=1 WHERE file_external IS NOT NULL; " \
""
-#define STMT_UPGRADE_30_SELECT_CONFLICT_SEPARATE 228
-#define STMT_228_INFO {"STMT_UPGRADE_30_SELECT_CONFLICT_SEPARATE", NULL}
-#define STMT_228 \
+#define STMT_UPGRADE_30_SELECT_CONFLICT_SEPARATE 227
+#define STMT_227_INFO {"STMT_UPGRADE_30_SELECT_CONFLICT_SEPARATE", NULL}
+#define STMT_227 \
"SELECT wc_id, local_relpath, " \
" conflict_old, conflict_working, conflict_new, prop_reject, tree_conflict_data " \
"FROM actual_node " \
@@ -2558,24 +2624,24 @@
"ORDER by wc_id, local_relpath " \
""
-#define STMT_UPGRADE_30_SET_CONFLICT 229
-#define STMT_229_INFO {"STMT_UPGRADE_30_SET_CONFLICT", NULL}
-#define STMT_229 \
+#define STMT_UPGRADE_30_SET_CONFLICT 228
+#define STMT_228_INFO {"STMT_UPGRADE_30_SET_CONFLICT", NULL}
+#define STMT_228 \
"UPDATE actual_node SET conflict_data = ?3, conflict_old = NULL, " \
" conflict_working = NULL, conflict_new = NULL, prop_reject = NULL, " \
" tree_conflict_data = NULL " \
"WHERE wc_id = ?1 and local_relpath = ?2 " \
""
-#define STMT_UPGRADE_TO_31_ALTER_TABLE 230
-#define STMT_230_INFO {"STMT_UPGRADE_TO_31_ALTER_TABLE", NULL}
-#define STMT_230 \
+#define STMT_UPGRADE_TO_31_ALTER_TABLE 229
+#define STMT_229_INFO {"STMT_UPGRADE_TO_31_ALTER_TABLE", NULL}
+#define STMT_229 \
"ALTER TABLE NODES ADD COLUMN inherited_props BLOB; " \
""
-#define STMT_UPGRADE_TO_31_FINALIZE 231
-#define STMT_231_INFO {"STMT_UPGRADE_TO_31_FINALIZE", NULL}
-#define STMT_231 \
+#define STMT_UPGRADE_TO_31_FINALIZE 230
+#define STMT_230_INFO {"STMT_UPGRADE_TO_31_FINALIZE", NULL}
+#define STMT_230 \
"DROP INDEX IF EXISTS I_ACTUAL_CHANGELIST; " \
"DROP INDEX IF EXISTS I_EXTERNALS_PARENT; " \
"DROP INDEX I_NODES_PARENT; " \
@@ -2587,9 +2653,9 @@
"PRAGMA user_version = 31; " \
""
-#define STMT_UPGRADE_31_SELECT_WCROOT_NODES 232
-#define STMT_232_INFO {"STMT_UPGRADE_31_SELECT_WCROOT_NODES", NULL}
-#define STMT_232 \
+#define STMT_UPGRADE_31_SELECT_WCROOT_NODES 231
+#define STMT_231_INFO {"STMT_UPGRADE_31_SELECT_WCROOT_NODES", NULL}
+#define STMT_231 \
"SELECT l.wc_id, l.local_relpath FROM nodes as l " \
"LEFT OUTER JOIN nodes as r " \
"ON l.wc_id = r.wc_id " \
@@ -2601,9 +2667,9 @@
" OR (l.repos_path IS NOT (CASE WHEN (r.local_relpath) = '' THEN (CASE WHEN (r.repos_path) = '' THEN (l.local_relpath) WHEN (l.local_relpath) = '' THEN (r.repos_path) ELSE (r.repos_path) || '/' || (l.local_relpath) END) WHEN (r.repos_path) = '' THEN (CASE WHEN (r.local_relpath) = '' THEN (l.local_relpath) WHEN SUBSTR((l.local_relpath), 1, LENGTH(r.local_relpath)) = (r.local_relpath) THEN CASE WHEN LENGTH(r.local_relpath) = LENGTH(l.local_relpath) THEN '' WHEN SUBSTR((l.local_relpath), LENGTH(r.local_relpath)+1, 1) = '/' THEN SUBSTR((l.local_relpath), LENGTH(r.local_relpath)+2) END END) WHEN SUBSTR((l.local_relpath), 1, LENGTH(r.local_relpath)) = (r.local_relpath) THEN CASE WHEN LENGTH(r.local_relpath) = LENGTH(l.local_relpath) THEN (r.repos_path) WHEN SUBSTR((l.local_relpath), LENGTH(r.local_relpath)+1, 1) = '/' THEN (r.repos_path) || SUBSTR((l.local_relpath), LENGTH(r.local_relpath)+1) END END))) " \
""
-#define STMT_UPGRADE_TO_32 233
-#define STMT_233_INFO {"STMT_UPGRADE_TO_32", NULL}
-#define STMT_233 \
+#define STMT_UPGRADE_TO_32 232
+#define STMT_232_INFO {"STMT_UPGRADE_TO_32", NULL}
+#define STMT_232 \
"DROP INDEX IF EXISTS I_ACTUAL_CHANGELIST; " \
"DROP INDEX IF EXISTS I_EXTERNALS_PARENT; " \
"CREATE INDEX I_EXTERNALS_PARENT ON EXTERNALS (wc_id, parent_relpath); " \
@@ -2656,9 +2722,9 @@
"DROP TABLE ACTUAL_NODE_BACKUP; " \
""
-#define STMT_VERIFICATION_TRIGGERS 234
-#define STMT_234_INFO {"STMT_VERIFICATION_TRIGGERS", NULL}
-#define STMT_234 \
+#define STMT_VERIFICATION_TRIGGERS 233
+#define STMT_233_INFO {"STMT_VERIFICATION_TRIGGERS", NULL}
+#define STMT_233 \
"CREATE TEMPORARY TRIGGER no_repository_updates BEFORE UPDATE ON repository " \
"BEGIN " \
" SELECT RAISE(FAIL, 'Updates to REPOSITORY are not allowed.'); " \
@@ -2697,6 +2763,179 @@
"END; " \
""
+#define STMT_STATIC_VERIFY 234
+#define STMT_234_INFO {"STMT_STATIC_VERIFY", NULL}
+#define STMT_234 \
+ "SELECT local_relpath, op_depth, 1, 'Invalid parent relpath set in NODES' " \
+ "FROM nodes n WHERE local_relpath != '' " \
+ " AND (parent_relpath IS NULL " \
+ " OR NOT (((local_relpath) > (CASE (parent_relpath) WHEN '' THEN '' ELSE (parent_relpath) || '/' END)) AND ((local_relpath) < CASE (parent_relpath) WHEN '' THEN X'FFFF' ELSE (parent_relpath) || '0' END)) " \
+ " OR relpath_depth(local_relpath) != relpath_depth(parent_relpath)+1) " \
+ "UNION ALL " \
+ "SELECT local_relpath, -1, 2, 'Invalid parent relpath set in ACTUAL' " \
+ "FROM actual_node a WHERE local_relpath != '' " \
+ " AND (parent_relpath IS NULL " \
+ " OR NOT (((local_relpath) > (CASE (parent_relpath) WHEN '' THEN '' ELSE (parent_relpath) || '/' END)) AND ((local_relpath) < CASE (parent_relpath) WHEN '' THEN X'FFFF' ELSE (parent_relpath) || '0' END)) " \
+ " OR relpath_depth(local_relpath) != relpath_depth(parent_relpath)+1) " \
+ "UNION ALL " \
+ "SELECT local_relpath, -1, 10, 'No ancestor in ACTUAL' " \
+ "FROM actual_node a WHERE local_relpath != '' " \
+ " AND NOT EXISTS(SELECT 1 from nodes i " \
+ " WHERE i.wc_id=a.wc_id " \
+ " AND i.local_relpath=a.parent_relpath) " \
+ " AND NOT EXISTS(SELECT 1 from nodes i " \
+ " WHERE i.wc_id=a.wc_id " \
+ " AND i.local_relpath=a.local_relpath) " \
+ "UNION ALL " \
+ "SELECT a.local_relpath, -1, 11, 'Bad or Unneeded actual data' " \
+ "FROM actual_node a " \
+ "LEFT JOIN nodes n on n.wc_id = a.wc_id AND n.local_relpath = a.local_relpath " \
+ " AND n.op_depth = (SELECT MAX(op_depth) from nodes i " \
+ " WHERE i.wc_id=a.wc_id AND i.local_relpath=a.local_relpath) " \
+ "WHERE (a.properties IS NOT NULL " \
+ " AND (n.presence IS NULL " \
+ " OR n.presence NOT IN ('normal', 'incomplete'))) " \
+ " OR (a.changelist IS NOT NULL AND (n.kind IS NOT NULL AND n.kind != 'file')) " \
+ " OR (a.conflict_data IS NULL AND a.properties IS NULL AND a.changelist IS NULL) " \
+ " AND NOT EXISTS(SELECT 1 from nodes i " \
+ " WHERE i.wc_id=a.wc_id " \
+ " AND i.local_relpath=a.parent_relpath) " \
+ "UNION ALL " \
+ "SELECT local_relpath, op_depth, 20, 'No ancestor in NODES' " \
+ "FROM nodes n WHERE local_relpath != '' " \
+ " AND file_external IS NULL " \
+ " AND NOT EXISTS(SELECT 1 from nodes i " \
+ " WHERE i.wc_id=n.wc_id " \
+ " AND i.local_relpath=n.parent_relpath " \
+ " AND i.op_depth <= n.op_depth) " \
+ "UNION ALL " \
+ "SELECT local_relpath, op_depth, 21, 'Unneeded node data' " \
+ "FROM nodes " \
+ "WHERE presence NOT IN ('normal', 'incomplete') " \
+ "AND (properties IS NOT NULL " \
+ " OR checksum IS NOT NULL " \
+ " OR depth IS NOT NULL " \
+ " OR symlink_target IS NOT NULL " \
+ " OR changed_revision IS NOT NULL " \
+ " OR (changed_date IS NOT NULL AND changed_date != 0) " \
+ " OR changed_author IS NOT NULL " \
+ " OR translated_size IS NOT NULL " \
+ " OR last_mod_time IS NOT NULL " \
+ " OR dav_cache IS NOT NULL " \
+ " OR file_external IS NOT NULL " \
+ " OR inherited_props IS NOT NULL) " \
+ "UNION ALL " \
+ "SELECT local_relpath, op_depth, 22, 'Unneeded base-deleted node data' " \
+ "FROM nodes " \
+ "WHERE presence IN ('base-deleted') " \
+ "AND (repos_id IS NOT NULL " \
+ " OR repos_path IS NOT NULL " \
+ " OR revision IS NOT NULL) " \
+ "UNION ALL " \
+ "SELECT local_relpath, op_depth, 23, 'Kind specific data invalid on normal' " \
+ "FROM nodes " \
+ "WHERE presence IN ('normal', 'incomplete') " \
+ "AND (kind IS NULL " \
+ " OR (repos_path IS NULL " \
+ " AND (properties IS NOT NULL " \
+ " OR changed_revision IS NOT NULL " \
+ " OR changed_author IS NOT NULL " \
+ " OR (changed_date IS NOT NULL AND changed_date != 0))) " \
+ " OR (CASE WHEN kind = 'file' AND repos_path IS NOT NULL " \
+ " THEN checksum IS NULL " \
+ " ELSE checksum IS NOT NULL END) " \
+ " OR (CASE WHEN kind = 'dir' THEN depth IS NULL " \
+ " ELSE depth IS NOT NULL END) " \
+ " OR (CASE WHEN kind = 'symlink' THEN symlink_target IS NULL " \
+ " ELSE symlink_target IS NOT NULL END)) " \
+ "UNION ALL " \
+ "SELECT local_relpath, op_depth, 24, 'Invalid op-depth for local add' " \
+ "FROM nodes " \
+ "WHERE presence IN ('normal', 'incomplete') " \
+ " AND repos_path IS NULL " \
+ " AND op_depth != relpath_depth(local_relpath) " \
+ "UNION ALL " \
+ "SELECT local_relpath, op_depth, 25, 'Node missing op-depth ancestor' " \
+ "FROM nodes n " \
+ "WHERE op_depth < relpath_depth(local_relpath) " \
+ " AND file_external IS NULL " \
+ " AND NOT EXISTS(SELECT 1 FROM nodes p " \
+ " WHERE p.wc_id=n.wc_id AND p.local_relpath=n.parent_relpath " \
+ " AND p.op_depth=n.op_depth " \
+ " AND (p.presence IN ('normal', 'incomplete') " \
+ " OR (p.presence IN ('base-deleted', 'not-present') " \
+ " AND n.presence = 'base-deleted'))) " \
+ "UNION ALL " \
+ "SELECT n.local_relpath, n.op_depth, 26, 'Copied descendant mismatch' " \
+ "FROM nodes n " \
+ "JOIN nodes p " \
+ " ON p.wc_id=n.wc_id AND p.local_relpath=n.parent_relpath " \
+ " AND n.op_depth=p.op_depth " \
+ "WHERE n.op_depth > 0 AND n.presence IN ('normal', 'incomplete') " \
+ " AND (n.repos_id != p.repos_id " \
+ " OR n.repos_path != " \
+ " (CASE WHEN (n.parent_relpath) = '' THEN (CASE WHEN (p.repos_path) = '' THEN (n.local_relpath) WHEN (n.local_relpath) = '' THEN (p.repos_path) ELSE (p.repos_path) || '/' || (n.local_relpath) END) WHEN (p.repos_path) = '' THEN (CASE WHEN (n.parent_relpath) = '' THEN (n.local_relpath) WHEN SUBSTR((n.local_relpath), 1, LENGTH(n.parent_relpath)) = (n.parent_relpath) THEN CASE WHEN LENGTH(n.parent_relpath) = LENGTH(n.local_relpath) THEN '' WHEN SUBSTR((n.local_relpath), LENGTH(n.parent_relpath)+1, 1) = '/' THEN SUBSTR((n.local_relpath), LENGTH(n.parent_relpath)+2) END END) WHEN SUBSTR((n.local_relpath), 1, LENGTH(n.parent_relpath)) = (n.parent_relpath) THEN CASE WHEN LENGTH(n.parent_relpath) = LENGTH(n.local_relpath) THEN (p.repos_path) WHEN SUBSTR((n.local_relpath), LENGTH(n.parent_relpath)+1, 1) = '/' THEN (p.repos_path) || SUBSTR((n.local_relpath), LENGTH(n.parent_relpath)+1) END END) " \
+ " OR n.revision != p.revision " \
+ " OR p.kind != 'dir' " \
+ " OR n.moved_here IS NOT p.moved_here) " \
+ "UNION ALL " \
+ "SELECT n.local_relpath, n.op_depth, 27, 'Invalid op-root presence' " \
+ "FROM nodes n " \
+ "WHERE n.op_depth = relpath_depth(local_relpath) " \
+ " AND presence NOT IN ('normal', 'incomplete', 'base-deleted') " \
+ "UNION ALL " \
+ "SELECT n.local_relpath, s.op_depth, 28, 'Incomplete shadowing' " \
+ "FROM nodes n " \
+ "JOIN nodes s ON s.wc_id=n.wc_id AND s.local_relpath=n.local_relpath " \
+ " AND s.op_depth = relpath_depth(s.local_relpath) " \
+ " AND s.op_depth = (SELECT MIN(op_depth) FROM nodes d " \
+ " WHERE d.wc_id=s.wc_id AND d.local_relpath=s.local_relpath " \
+ " AND d.op_depth > n.op_depth) " \
+ "WHERE n.presence IN ('normal', 'incomplete') " \
+ " AND EXISTS(SELECT 1 " \
+ " FROM nodes dn " \
+ " WHERE dn.wc_id=n.wc_id AND dn.op_depth=n.op_depth " \
+ " AND dn.presence IN ('normal', 'incomplete') " \
+ " AND (((dn.local_relpath) > (CASE (n.local_relpath) WHEN '' THEN '' ELSE (n.local_relpath) || '/' END)) AND ((dn.local_relpath) < CASE (n.local_relpath) WHEN '' THEN X'FFFF' ELSE (n.local_relpath) || '0' END)) " \
+ " AND dn.file_external IS NULL " \
+ " AND NOT EXISTS(SELECT 1 " \
+ " FROM nodes ds " \
+ " WHERE ds.wc_id=n.wc_id AND ds.op_depth=s.op_depth " \
+ " AND ds.local_relpath=dn.local_relpath)) " \
+ "UNION ALL " \
+ "SELECT s.local_relpath, s.op_depth, 29, 'Invalid base-delete' " \
+ "FROM nodes s " \
+ "LEFT JOIN nodes n ON n.wc_id=s.wc_id AND n.local_relpath=s.local_relpath " \
+ " AND n.op_depth = (SELECT MAX(op_depth) FROM nodes d " \
+ " WHERE d.wc_id=s.wc_id AND d.local_relpath=s.local_relpath " \
+ " AND d.op_depth < s.op_depth) " \
+ "WHERE s.presence = 'base-deleted' " \
+ " AND (n.presence IS NULL " \
+ " OR n.presence NOT IN ('normal', 'incomplete') " \
+ " ) " \
+ "UNION ALL " \
+ "SELECT n.local_relpath, n.op_depth, 30, 'Invalid data for BASE' " \
+ "FROM nodes n " \
+ "WHERE n.op_depth = 0 " \
+ " AND (n.moved_to IS NOT NULL " \
+ " OR n.moved_here IS NOT NULL) " \
+ "UNION ALL " \
+ "SELECT d.local_relpath, d.op_depth, 60, 'Moved here without origin' " \
+ "FROM nodes d " \
+ "WHERE d.op_depth = relpath_depth(d.local_relpath) " \
+ " AND d.moved_here IS NOT NULL " \
+ " AND NOT EXISTS(SELECT 1 FROM nodes s " \
+ " WHERE s.wc_id = d.wc_id AND s.moved_to = d.local_relpath) " \
+ "UNION ALL " \
+ "SELECT s.local_relpath, s.op_depth, 61, 'Moved to without target' " \
+ "FROM nodes s " \
+ "WHERE s.moved_to IS NOT NULL " \
+ " AND NOT EXISTS(SELECT 1 FROM nodes d " \
+ " WHERE d.wc_id = s.wc_id AND d.local_relpath = s.moved_to " \
+ " AND d.op_depth = relpath_depth(d.local_relpath) " \
+ " AND d.moved_here =1 AND d.repos_path IS NOT NULL) " \
+ ""
+
#define WC_QUERIES_SQL_DECLARE_STATEMENTS(varname) \
static const char * const varname[] = { \
STMT_0, \