wc-queries.h revision 369302
1/* This file is automatically generated from wc-queries.sql and token-map.h. 2 * Do not edit this file -- edit the source and rerun gen-make.py */ 3 4#define STMT_SELECT_NODE_INFO 0 5#define STMT_0_INFO {"STMT_SELECT_NODE_INFO", NULL} 6#define STMT_0 \ 7 "SELECT op_depth, repos_id, repos_path, presence, kind, revision, checksum, " \ 8 " translated_size, changed_revision, changed_date, changed_author, depth, " \ 9 " symlink_target, last_mod_time, properties, moved_here, inherited_props, " \ 10 " moved_to " \ 11 "FROM nodes " \ 12 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 13 "ORDER BY op_depth DESC " \ 14 "" 15 16#define STMT_SELECT_NODE_INFO_WITH_LOCK 1 17#define STMT_1_INFO {"STMT_SELECT_NODE_INFO_WITH_LOCK", NULL} 18#define STMT_1 \ 19 "SELECT op_depth, nodes.repos_id, nodes.repos_path, presence, kind, revision, " \ 20 " checksum, translated_size, changed_revision, changed_date, changed_author, " \ 21 " depth, symlink_target, last_mod_time, properties, moved_here, " \ 22 " inherited_props, " \ 23 " lock_token, lock_owner, lock_comment, lock_date " \ 24 "FROM nodes " \ 25 "LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \ 26 " AND nodes.repos_path = lock.repos_relpath AND nodes.op_depth=0 " \ 27 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 28 "ORDER BY op_depth DESC " \ 29 "" 30 31#define STMT_SELECT_BASE_NODE 2 32#define STMT_2_INFO {"STMT_SELECT_BASE_NODE", NULL} 33#define STMT_2 \ 34 "SELECT repos_id, repos_path, presence, kind, revision, checksum, " \ 35 " translated_size, changed_revision, changed_date, changed_author, depth, " \ 36 " symlink_target, last_mod_time, properties, file_external " \ 37 "FROM nodes " \ 38 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 39 "" 40 41#define STMT_SELECT_BASE_NODE_WITH_LOCK 3 42#define STMT_3_INFO {"STMT_SELECT_BASE_NODE_WITH_LOCK", NULL} 43#define STMT_3 \ 44 "SELECT nodes.repos_id, nodes.repos_path, presence, kind, revision, " \ 45 " checksum, translated_size, changed_revision, changed_date, changed_author, " \ 46 " depth, symlink_target, last_mod_time, properties, file_external, " \ 47 " lock_token, lock_owner, lock_comment, lock_date " \ 48 "FROM nodes " \ 49 "LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \ 50 " AND nodes.repos_path = lock.repos_relpath " \ 51 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 52 "" 53 54#define STMT_SELECT_BASE_CHILDREN_INFO 4 55#define STMT_4_INFO {"STMT_SELECT_BASE_CHILDREN_INFO", NULL} 56#define STMT_4 \ 57 "SELECT local_relpath, nodes.repos_id, nodes.repos_path, presence, kind, " \ 58 " revision, depth, file_external " \ 59 "FROM nodes " \ 60 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \ 61 "" 62 63#define STMT_SELECT_BASE_CHILDREN_INFO_LOCK 5 64#define STMT_5_INFO {"STMT_SELECT_BASE_CHILDREN_INFO_LOCK", NULL} 65#define STMT_5 \ 66 "SELECT local_relpath, nodes.repos_id, nodes.repos_path, presence, kind, " \ 67 " revision, depth, file_external, " \ 68 " lock_token, lock_owner, lock_comment, lock_date " \ 69 "FROM nodes " \ 70 "LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \ 71 " AND nodes.repos_path = lock.repos_relpath " \ 72 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \ 73 "" 74 75#define STMT_SELECT_WORKING_NODE 6 76#define STMT_6_INFO {"STMT_SELECT_WORKING_NODE", NULL} 77#define STMT_6 \ 78 "SELECT op_depth, presence, kind, checksum, translated_size, " \ 79 " changed_revision, changed_date, changed_author, depth, symlink_target, " \ 80 " repos_id, repos_path, revision, " \ 81 " moved_here, moved_to, last_mod_time, properties " \ 82 "FROM nodes " \ 83 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > 0 " \ 84 "ORDER BY op_depth DESC " \ 85 "LIMIT 1 " \ 86 "" 87 88#define STMT_SELECT_DEPTH_NODE 7 89#define STMT_7_INFO {"STMT_SELECT_DEPTH_NODE", NULL} 90#define STMT_7 \ 91 "SELECT repos_id, repos_path, presence, kind, revision, checksum, " \ 92 " translated_size, changed_revision, changed_date, changed_author, depth, " \ 93 " symlink_target, properties, moved_to, moved_here " \ 94 "FROM nodes " \ 95 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 96 "" 97 98#define STMT_SELECT_LOWEST_WORKING_NODE 8 99#define STMT_8_INFO {"STMT_SELECT_LOWEST_WORKING_NODE", NULL} 100#define STMT_8 \ 101 "SELECT op_depth, presence, kind, moved_to " \ 102 "FROM nodes " \ 103 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 " \ 104 "ORDER BY op_depth " \ 105 "LIMIT 1 " \ 106 "" 107 108#define STMT_SELECT_HIGHEST_WORKING_NODE 9 109#define STMT_9_INFO {"STMT_SELECT_HIGHEST_WORKING_NODE", NULL} 110#define STMT_9 \ 111 "SELECT op_depth " \ 112 "FROM nodes " \ 113 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth < ?3 " \ 114 "ORDER BY op_depth DESC " \ 115 "LIMIT 1 " \ 116 "" 117 118#define STMT_SELECT_PRESENT_HIGHEST_WORKING_NODES_BY_BASENAME_AND_KIND 10 119#define STMT_10_INFO {"STMT_SELECT_PRESENT_HIGHEST_WORKING_NODES_BY_BASENAME_AND_KIND", NULL} 120#define STMT_10 \ 121 "SELECT presence, local_relpath " \ 122 "FROM nodes n " \ 123 "WHERE wc_id = ?1 AND local_relpath = (CASE WHEN (parent_relpath) = '' THEN (?2) WHEN (?2) = '' THEN (parent_relpath) ELSE (parent_relpath) || '/' || (?2) END) " \ 124 " AND kind = ?3 " \ 125 " AND presence in ('normal', 'incomplete') " \ 126 " AND op_depth = (SELECT MAX(op_depth) " \ 127 " FROM NODES w " \ 128 " WHERE w.wc_id = ?1 " \ 129 " AND w.local_relpath = n.local_relpath) " \ 130 "" 131 132#define STMT_SELECT_ACTUAL_NODE 11 133#define STMT_11_INFO {"STMT_SELECT_ACTUAL_NODE", NULL} 134#define STMT_11 \ 135 "SELECT changelist, properties, conflict_data " \ 136 "FROM actual_node " \ 137 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 138 "" 139 140#define STMT_SELECT_NODE_CHILDREN_INFO 12 141#define STMT_12_INFO {"STMT_SELECT_NODE_CHILDREN_INFO", NULL} 142#define STMT_12 \ 143 "SELECT op_depth, nodes.repos_id, nodes.repos_path, presence, kind, revision, " \ 144 " checksum, translated_size, changed_revision, changed_date, changed_author, " \ 145 " depth, symlink_target, last_mod_time, properties, lock_token, lock_owner, " \ 146 " lock_comment, lock_date, local_relpath, moved_here, moved_to, file_external " \ 147 "FROM nodes " \ 148 "LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \ 149 " AND nodes.repos_path = lock.repos_relpath AND nodes.op_depth = 0 " \ 150 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 151 "ORDER BY local_relpath DESC, op_depth DESC " \ 152 "" 153 154#define STMT_SELECT_BASE_NODE_CHILDREN_INFO 13 155#define STMT_13_INFO {"STMT_SELECT_BASE_NODE_CHILDREN_INFO", NULL} 156#define STMT_13 \ 157 "SELECT op_depth, nodes.repos_id, nodes.repos_path, presence, kind, revision, " \ 158 " checksum, translated_size, changed_revision, changed_date, changed_author, " \ 159 " depth, symlink_target, last_mod_time, properties, lock_token, lock_owner, " \ 160 " lock_comment, lock_date, local_relpath, moved_here, moved_to, file_external " \ 161 "FROM nodes " \ 162 "LEFT OUTER JOIN lock ON nodes.repos_id = lock.repos_id " \ 163 " AND nodes.repos_path = lock.repos_relpath " \ 164 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \ 165 "ORDER BY local_relpath DESC " \ 166 "" 167 168#define STMT_SELECT_NODE_CHILDREN_WALKER_INFO 14 169#define STMT_14_INFO {"STMT_SELECT_NODE_CHILDREN_WALKER_INFO", NULL} 170#define STMT_14 \ 171 "SELECT local_relpath, op_depth, presence, kind " \ 172 "FROM nodes_current " \ 173 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 174 "ORDER BY local_relpath " \ 175 "" 176 177#define STMT_SELECT_ACTUAL_CHILDREN_INFO 15 178#define STMT_15_INFO {"STMT_SELECT_ACTUAL_CHILDREN_INFO", NULL} 179#define STMT_15 \ 180 "SELECT local_relpath, changelist, properties, conflict_data " \ 181 "FROM actual_node " \ 182 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 183 "" 184 185#define STMT_SELECT_REPOSITORY_BY_ID 16 186#define STMT_16_INFO {"STMT_SELECT_REPOSITORY_BY_ID", NULL} 187#define STMT_16 \ 188 "SELECT root, uuid FROM repository WHERE id = ?1 " \ 189 "" 190 191#define STMT_SELECT_WCROOT_NULL 17 192#define STMT_17_INFO {"STMT_SELECT_WCROOT_NULL", NULL} 193#define STMT_17 \ 194 "SELECT id FROM wcroot WHERE local_abspath IS NULL " \ 195 "" 196 197#define STMT_SELECT_REPOSITORY 18 198#define STMT_18_INFO {"STMT_SELECT_REPOSITORY", NULL} 199#define STMT_18 \ 200 "SELECT id FROM repository WHERE root = ?1 " \ 201 "" 202 203#define STMT_INSERT_REPOSITORY 19 204#define STMT_19_INFO {"STMT_INSERT_REPOSITORY", NULL} 205#define STMT_19 \ 206 "INSERT INTO repository (root, uuid) VALUES (?1, ?2) " \ 207 "" 208 209#define STMT_INSERT_NODE 20 210#define STMT_20_INFO {"STMT_INSERT_NODE", NULL} 211#define STMT_20 \ 212 "INSERT OR REPLACE INTO nodes ( " \ 213 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, repos_path, " \ 214 " revision, presence, depth, kind, changed_revision, changed_date, " \ 215 " changed_author, checksum, properties, translated_size, last_mod_time, " \ 216 " dav_cache, symlink_target, file_external, moved_to, moved_here, " \ 217 " inherited_props) " \ 218 "VALUES (?1, ?2, ?3, ?4, ?5, ?6, ?7, ?8, ?9, ?10, ?11, ?12, ?13, ?14, " \ 219 " ?15, ?16, ?17, ?18, ?19, ?20, ?21, ?22, ?23) " \ 220 "" 221 222#define STMT_SELECT_WORKING_PRESENT 21 223#define STMT_21_INFO {"STMT_SELECT_WORKING_PRESENT", NULL} 224#define STMT_21 \ 225 "SELECT local_relpath, kind, checksum, translated_size, last_mod_time " \ 226 "FROM nodes n " \ 227 "WHERE wc_id = ?1 " \ 228 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 229 " AND presence in ('normal', 'incomplete') " \ 230 " AND op_depth = (SELECT MAX(op_depth) " \ 231 " FROM NODES w " \ 232 " WHERE w.wc_id = ?1 " \ 233 " AND w.local_relpath = n.local_relpath) " \ 234 "ORDER BY local_relpath DESC " \ 235 "" 236 237#define STMT_DELETE_NODE_RECURSIVE 22 238#define STMT_22_INFO {"STMT_DELETE_NODE_RECURSIVE", NULL} 239#define STMT_22 \ 240 "DELETE FROM NODES " \ 241 "WHERE wc_id = ?1 " \ 242 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 243 "" 244 245#define STMT_DELETE_NODE 23 246#define STMT_23_INFO {"STMT_DELETE_NODE", NULL} 247#define STMT_23 \ 248 "DELETE " \ 249 "FROM NODES " \ 250 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 251 "" 252 253#define STMT_DELETE_ACTUAL_FOR_BASE_RECURSIVE 24 254#define STMT_24_INFO {"STMT_DELETE_ACTUAL_FOR_BASE_RECURSIVE", NULL} 255#define STMT_24 \ 256 "DELETE FROM actual_node " \ 257 "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)) " \ 258 " AND EXISTS(SELECT 1 FROM NODES b " \ 259 " WHERE b.wc_id = ?1 " \ 260 " AND b.local_relpath = actual_node.local_relpath " \ 261 " AND op_depth = 0) " \ 262 " AND NOT EXISTS(SELECT 1 FROM NODES w " \ 263 " WHERE w.wc_id = ?1 " \ 264 " AND w.local_relpath = actual_node.local_relpath " \ 265 " AND op_depth > 0 " \ 266 " AND presence in ('normal', 'incomplete', 'not-present')) " \ 267 "" 268 269#define STMT_DELETE_WORKING_BASE_DELETE 25 270#define STMT_25_INFO {"STMT_DELETE_WORKING_BASE_DELETE", NULL} 271#define STMT_25 \ 272 "DELETE FROM nodes " \ 273 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 274 " AND presence = 'base-deleted' " \ 275 " AND op_depth > ?3 " \ 276 " AND op_depth = (SELECT MIN(op_depth) FROM nodes n " \ 277 " WHERE n.wc_id = ?1 " \ 278 " AND n.local_relpath = nodes.local_relpath " \ 279 " AND op_depth > ?3) " \ 280 "" 281 282#define STMT_DELETE_WORKING_BASE_DELETE_RECURSIVE 26 283#define STMT_26_INFO {"STMT_DELETE_WORKING_BASE_DELETE_RECURSIVE", NULL} 284#define STMT_26 \ 285 "DELETE FROM nodes " \ 286 "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)) " \ 287 " AND presence = 'base-deleted' " \ 288 " AND op_depth > ?3 " \ 289 " AND op_depth = (SELECT MIN(op_depth) FROM nodes n " \ 290 " WHERE n.wc_id = ?1 " \ 291 " AND n.local_relpath = nodes.local_relpath " \ 292 " AND op_depth > ?3) " \ 293 "" 294 295#define STMT_DELETE_WORKING_RECURSIVE 27 296#define STMT_27_INFO {"STMT_DELETE_WORKING_RECURSIVE", NULL} 297#define STMT_27 \ 298 "DELETE FROM nodes " \ 299 "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)) " \ 300 " AND op_depth > 0 " \ 301 "" 302 303#define STMT_DELETE_BASE_RECURSIVE 28 304#define STMT_28_INFO {"STMT_DELETE_BASE_RECURSIVE", NULL} 305#define STMT_28 \ 306 "DELETE FROM nodes " \ 307 "WHERE wc_id = ?1 AND (local_relpath = ?2 " \ 308 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 309 " AND op_depth = 0 " \ 310 "" 311 312#define STMT_DELETE_WORKING_OP_DEPTH 29 313#define STMT_29_INFO {"STMT_DELETE_WORKING_OP_DEPTH", NULL} 314#define STMT_29 \ 315 "DELETE FROM nodes " \ 316 "WHERE wc_id = ?1 " \ 317 " 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))) " \ 318 " AND op_depth = ?3 " \ 319 "" 320 321#define STMT_SELECT_LAYER_FOR_REPLACE 30 322#define STMT_30_INFO {"STMT_SELECT_LAYER_FOR_REPLACE", NULL} 323#define STMT_30 \ 324 "SELECT s.local_relpath, s.kind, " \ 325 " (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' " \ 326 "FROM nodes s " \ 327 "WHERE s.wc_id = ?1 AND s.local_relpath = ?2 AND s.op_depth = ?3 " \ 328 "UNION ALL " \ 329 "SELECT s.local_relpath, s.kind, " \ 330 " (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 " \ 331 "FROM nodes s " \ 332 "LEFT OUTER JOIN nodes d ON d.wc_id= ?1 AND d.op_depth = ?5 " \ 333 " AND d.local_relpath = drp " \ 334 "WHERE s.wc_id = ?1 " \ 335 " 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)) " \ 336 " AND s.op_depth = ?3 " \ 337 "ORDER BY s.local_relpath " \ 338 "" 339 340#define STMT_SELECT_DESCENDANTS_OP_DEPTH_RV 31 341#define STMT_31_INFO {"STMT_SELECT_DESCENDANTS_OP_DEPTH_RV", NULL} 342#define STMT_31 \ 343 "SELECT local_relpath, kind " \ 344 "FROM nodes " \ 345 "WHERE wc_id = ?1 " \ 346 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 347 " AND op_depth = ?3 " \ 348 " AND presence in ('normal', 'incomplete') " \ 349 "ORDER BY local_relpath DESC " \ 350 "" 351 352#define STMT_COPY_NODE_MOVE 32 353#define STMT_32_INFO {"STMT_COPY_NODE_MOVE", NULL} 354#define STMT_32 \ 355 "INSERT OR REPLACE INTO nodes ( " \ 356 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, repos_path, " \ 357 " revision, presence, depth, kind, changed_revision, changed_date, " \ 358 " changed_author, checksum, properties, translated_size, last_mod_time, " \ 359 " symlink_target, moved_here, moved_to ) " \ 360 "SELECT " \ 361 " s.wc_id, ?4 , ?5 , ?6 , " \ 362 " s.repos_id, " \ 363 " s.repos_path, s.revision, s.presence, s.depth, s.kind, s.changed_revision, " \ 364 " s.changed_date, s.changed_author, s.checksum, s.properties, " \ 365 " CASE WHEN d.checksum=s.checksum THEN d.translated_size END, " \ 366 " CASE WHEN d.checksum=s.checksum THEN d.last_mod_time END, " \ 367 " s.symlink_target, 1, d.moved_to " \ 368 "FROM nodes s " \ 369 "LEFT JOIN nodes d ON d.wc_id=?1 AND d.local_relpath=?4 AND d.op_depth=?5 " \ 370 "WHERE s.wc_id = ?1 AND s.local_relpath = ?2 AND s.op_depth = ?3 " \ 371 "" 372 373#define STMT_SELECT_NO_LONGER_MOVED_RV 33 374#define STMT_33_INFO {"STMT_SELECT_NO_LONGER_MOVED_RV", NULL} 375#define STMT_33 \ 376 "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, " \ 377 " b.presence, b.op_depth " \ 378 "FROM nodes d " \ 379 "LEFT OUTER JOIN nodes b ON b.wc_id = ?1 AND b.local_relpath = d.local_relpath " \ 380 " AND b.op_depth = (SELECT MAX(x.op_depth) FROM nodes x " \ 381 " WHERE x.wc_id = ?1 " \ 382 " AND x.local_relpath = b.local_relpath " \ 383 " AND x.op_depth < ?3) " \ 384 "WHERE d.wc_id = ?1 " \ 385 " 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)) " \ 386 " AND d.op_depth = ?3 " \ 387 " AND NOT EXISTS(SELECT * FROM nodes s " \ 388 " WHERE s.wc_id = ?1 " \ 389 " AND s.local_relpath = srp " \ 390 " AND s.op_depth = ?5) " \ 391 "ORDER BY d.local_relpath DESC " \ 392 "" 393 394#define STMT_SELECT_OP_DEPTH_CHILDREN 34 395#define STMT_34_INFO {"STMT_SELECT_OP_DEPTH_CHILDREN", NULL} 396#define STMT_34 \ 397 "SELECT local_relpath, kind FROM nodes " \ 398 "WHERE wc_id = ?1 " \ 399 " AND parent_relpath = ?2 " \ 400 " AND op_depth = ?3 " \ 401 " AND presence != 'base-deleted' " \ 402 " AND file_external is NULL " \ 403 "ORDER BY local_relpath " \ 404 "" 405 406#define STMT_SELECT_OP_DEPTH_CHILDREN_EXISTS 35 407#define STMT_35_INFO {"STMT_SELECT_OP_DEPTH_CHILDREN_EXISTS", NULL} 408#define STMT_35 \ 409 "SELECT local_relpath, kind FROM nodes " \ 410 "WHERE wc_id = ?1 " \ 411 " AND parent_relpath = ?2 " \ 412 " AND op_depth = ?3 " \ 413 " AND presence IN ('normal', 'incomplete') " \ 414 "ORDER BY local_relpath " \ 415 "" 416 417#define STMT_SELECT_GE_OP_DEPTH_CHILDREN 36 418#define STMT_36_INFO {"STMT_SELECT_GE_OP_DEPTH_CHILDREN", NULL} 419#define STMT_36 \ 420 "SELECT 1 FROM nodes " \ 421 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 422 " AND (op_depth > ?3 OR (op_depth = ?3 " \ 423 " AND presence IN ('normal', 'incomplete'))) " \ 424 "UNION ALL " \ 425 "SELECT 1 FROM ACTUAL_NODE a " \ 426 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 427 " AND NOT EXISTS (SELECT 1 FROM nodes n " \ 428 " WHERE wc_id = ?1 AND n.local_relpath = a.local_relpath) " \ 429 "" 430 431#define STMT_DELETE_SHADOWED_RECURSIVE 37 432#define STMT_37_INFO {"STMT_DELETE_SHADOWED_RECURSIVE", NULL} 433#define STMT_37 \ 434 "DELETE FROM nodes " \ 435 "WHERE wc_id = ?1 " \ 436 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 437 " AND (op_depth < ?3 " \ 438 " OR (op_depth = ?3 AND presence = 'base-deleted')) " \ 439 "" 440 441#define STMT_CLEAR_MOVED_TO_FROM_DEST 38 442#define STMT_38_INFO {"STMT_CLEAR_MOVED_TO_FROM_DEST", NULL} 443#define STMT_38 \ 444 "UPDATE NODES SET moved_to = NULL " \ 445 "WHERE wc_id = ?1 " \ 446 " AND moved_to = ?2 " \ 447 "" 448 449#define STMT_SELECT_NOT_PRESENT_DESCENDANTS 39 450#define STMT_39_INFO {"STMT_SELECT_NOT_PRESENT_DESCENDANTS", NULL} 451#define STMT_39 \ 452 "SELECT local_relpath FROM nodes " \ 453 "WHERE wc_id = ?1 AND op_depth = ?3 " \ 454 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 455 " AND presence = 'not-present' " \ 456 "" 457 458#define STMT_COMMIT_DESCENDANTS_TO_BASE 40 459#define STMT_40_INFO {"STMT_COMMIT_DESCENDANTS_TO_BASE", NULL} 460#define STMT_40 \ 461 "UPDATE NODES SET op_depth = 0, " \ 462 " repos_id = ?4, " \ 463 " 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), " \ 464 " revision = ?6, " \ 465 " dav_cache = NULL, " \ 466 " moved_here = NULL, " \ 467 " moved_to = NULL, " \ 468 " presence = CASE presence " \ 469 " WHEN 'normal' THEN 'normal' " \ 470 " WHEN 'excluded' THEN 'excluded' " \ 471 " ELSE 'not-present' " \ 472 " END " \ 473 "WHERE wc_id = ?1 " \ 474 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 475 " AND op_depth = ?3 " \ 476 "" 477 478#define STMT_SELECT_NODE_CHILDREN 41 479#define STMT_41_INFO {"STMT_SELECT_NODE_CHILDREN", NULL} 480#define STMT_41 \ 481 "SELECT DISTINCT local_relpath FROM nodes " \ 482 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 483 "ORDER BY local_relpath " \ 484 "" 485 486#define STMT_SELECT_WORKING_CHILDREN 42 487#define STMT_42_INFO {"STMT_SELECT_WORKING_CHILDREN", NULL} 488#define STMT_42 \ 489 "SELECT DISTINCT local_relpath FROM nodes " \ 490 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 491 " AND (op_depth > (SELECT MAX(op_depth) FROM nodes " \ 492 " WHERE wc_id = ?1 AND local_relpath = ?2) " \ 493 " OR " \ 494 " (op_depth = (SELECT MAX(op_depth) FROM nodes " \ 495 " WHERE wc_id = ?1 AND local_relpath = ?2) " \ 496 " AND presence IN ('normal', 'incomplete'))) " \ 497 "ORDER BY local_relpath " \ 498 "" 499 500#define STMT_SELECT_BASE_NOT_PRESENT_CHILDREN 43 501#define STMT_43_INFO {"STMT_SELECT_BASE_NOT_PRESENT_CHILDREN", NULL} 502#define STMT_43 \ 503 "SELECT local_relpath FROM nodes " \ 504 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = 0 " \ 505 " AND presence = 'not-present' " \ 506 "ORDER BY local_relpath " \ 507 "" 508 509#define STMT_SELECT_NODE_PROPS 44 510#define STMT_44_INFO {"STMT_SELECT_NODE_PROPS", NULL} 511#define STMT_44 \ 512 "SELECT properties, presence FROM nodes " \ 513 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 514 "ORDER BY op_depth DESC " \ 515 "" 516 517#define STMT_SELECT_ACTUAL_PROPS 45 518#define STMT_45_INFO {"STMT_SELECT_ACTUAL_PROPS", NULL} 519#define STMT_45 \ 520 "SELECT properties FROM actual_node " \ 521 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 522 "" 523 524#define STMT_UPDATE_ACTUAL_PROPS 46 525#define STMT_46_INFO {"STMT_UPDATE_ACTUAL_PROPS", NULL} 526#define STMT_46 \ 527 "UPDATE actual_node SET properties = ?3 " \ 528 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 529 "" 530 531#define STMT_INSERT_ACTUAL_PROPS 47 532#define STMT_47_INFO {"STMT_INSERT_ACTUAL_PROPS", NULL} 533#define STMT_47 \ 534 "INSERT INTO actual_node (wc_id, local_relpath, parent_relpath, properties) " \ 535 "VALUES (?1, ?2, ?3, ?4) " \ 536 "" 537 538#define STMT_INSERT_LOCK 48 539#define STMT_48_INFO {"STMT_INSERT_LOCK", NULL} 540#define STMT_48 \ 541 "INSERT OR REPLACE INTO lock " \ 542 "(repos_id, repos_relpath, lock_token, lock_owner, lock_comment, " \ 543 " lock_date) " \ 544 "VALUES (?1, ?2, ?3, ?4, ?5, ?6) " \ 545 "" 546 547#define STMT_SELECT_BASE_NODE_LOCK_TOKENS_RECURSIVE 49 548#define STMT_49_INFO {"STMT_SELECT_BASE_NODE_LOCK_TOKENS_RECURSIVE", NULL} 549#define STMT_49 \ 550 "SELECT nodes.repos_id, nodes.repos_path, lock_token " \ 551 "FROM nodes " \ 552 "LEFT JOIN lock ON nodes.repos_id = lock.repos_id " \ 553 " AND nodes.repos_path = lock.repos_relpath " \ 554 "WHERE wc_id = ?1 AND op_depth = 0 " \ 555 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 556 "" 557 558#define STMT_INSERT_WCROOT 50 559#define STMT_50_INFO {"STMT_INSERT_WCROOT", NULL} 560#define STMT_50 \ 561 "INSERT INTO wcroot (local_abspath) " \ 562 "VALUES (?1) " \ 563 "" 564 565#define STMT_UPDATE_BASE_NODE_DAV_CACHE 51 566#define STMT_51_INFO {"STMT_UPDATE_BASE_NODE_DAV_CACHE", NULL} 567#define STMT_51 \ 568 "UPDATE nodes SET dav_cache = ?3 " \ 569 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 570 "" 571 572#define STMT_SELECT_BASE_DAV_CACHE 52 573#define STMT_52_INFO {"STMT_SELECT_BASE_DAV_CACHE", NULL} 574#define STMT_52 \ 575 "SELECT dav_cache FROM nodes " \ 576 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 577 "" 578 579#define STMT_SELECT_DELETION_INFO 53 580#define STMT_53_INFO {"STMT_SELECT_DELETION_INFO", NULL} 581#define STMT_53 \ 582 "SELECT b.presence, w.presence, w.op_depth, w.moved_to " \ 583 "FROM nodes w " \ 584 "LEFT JOIN nodes b ON b.wc_id = ?1 AND b.local_relpath = ?2 AND b.op_depth = 0 " \ 585 "WHERE w.wc_id = ?1 AND w.local_relpath = ?2 " \ 586 " AND w.op_depth = (SELECT MAX(op_depth) FROM nodes d " \ 587 " WHERE d.wc_id = ?1 AND d.local_relpath = ?2 " \ 588 " AND d.op_depth > 0) " \ 589 "LIMIT 1 " \ 590 "" 591 592#define STMT_SELECT_MOVED_TO_NODE 54 593#define STMT_54_INFO {"STMT_SELECT_MOVED_TO_NODE", NULL} 594#define STMT_54 \ 595 "SELECT op_depth, moved_to " \ 596 "FROM nodes " \ 597 "WHERE wc_id = ?1 AND local_relpath = ?2 AND moved_to IS NOT NULL " \ 598 "ORDER BY op_depth DESC " \ 599 "" 600 601#define STMT_SELECT_OP_DEPTH_MOVED_TO 55 602#define STMT_55_INFO {"STMT_SELECT_OP_DEPTH_MOVED_TO", NULL} 603#define STMT_55 \ 604 "SELECT op_depth, moved_to " \ 605 "FROM nodes " \ 606 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 " \ 607 " AND EXISTS(SELECT * from nodes " \ 608 " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 609 " AND presence IN ('normal', 'incomplete')) " \ 610 "ORDER BY op_depth ASC " \ 611 "LIMIT 1 " \ 612 "" 613 614#define STMT_SELECT_MOVED_TO 56 615#define STMT_56_INFO {"STMT_SELECT_MOVED_TO", NULL} 616#define STMT_56 \ 617 "SELECT moved_to " \ 618 "FROM nodes " \ 619 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 620 "" 621 622#define STMT_SELECT_MOVED_BACK 57 623#define STMT_57_INFO {"STMT_SELECT_MOVED_BACK", NULL} 624#define STMT_57 \ 625 "SELECT u.local_relpath, " \ 626 " u.presence, u.repos_id, u.repos_path, u.revision, " \ 627 " l.presence, l.repos_id, l.repos_path, l.revision, " \ 628 " u.moved_here, u.moved_to " \ 629 "FROM nodes u " \ 630 "LEFT OUTER JOIN nodes l ON l.wc_id = ?1 " \ 631 " AND l.local_relpath = u.local_relpath " \ 632 " AND l.op_depth = ?3 " \ 633 "WHERE u.wc_id = ?1 " \ 634 " AND u.local_relpath = ?2 " \ 635 " AND u.op_depth = ?4 " \ 636 "UNION ALL " \ 637 "SELECT u.local_relpath, " \ 638 " u.presence, u.repos_id, u.repos_path, u.revision, " \ 639 " l.presence, l.repos_id, l.repos_path, l.revision, " \ 640 " u.moved_here, NULL " \ 641 "FROM nodes u " \ 642 "LEFT OUTER JOIN nodes l ON l.wc_id=?1 " \ 643 " AND l.local_relpath=u.local_relpath " \ 644 " AND l.op_depth=?3 " \ 645 "WHERE u.wc_id = ?1 " \ 646 " AND (((u.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((u.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 647 " AND u.op_depth = ?4 " \ 648 "" 649 650#define STMT_DELETE_LOCK 58 651#define STMT_58_INFO {"STMT_DELETE_LOCK", NULL} 652#define STMT_58 \ 653 "DELETE FROM lock " \ 654 "WHERE repos_id = ?1 AND repos_relpath = ?2 " \ 655 "" 656 657#define STMT_DELETE_LOCK_RECURSIVELY 59 658#define STMT_59_INFO {"STMT_DELETE_LOCK_RECURSIVELY", NULL} 659#define STMT_59 \ 660 "DELETE FROM lock " \ 661 "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))) " \ 662 "" 663 664#define STMT_CLEAR_BASE_NODE_RECURSIVE_DAV_CACHE 60 665#define STMT_60_INFO {"STMT_CLEAR_BASE_NODE_RECURSIVE_DAV_CACHE", NULL} 666#define STMT_60 \ 667 "UPDATE nodes SET dav_cache = NULL " \ 668 "WHERE dav_cache IS NOT NULL AND wc_id = ?1 AND op_depth = 0 " \ 669 " AND (local_relpath = ?2 " \ 670 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 671 "" 672 673#define STMT_RECURSIVE_UPDATE_NODE_REPO 61 674#define STMT_61_INFO {"STMT_RECURSIVE_UPDATE_NODE_REPO", NULL} 675#define STMT_61 \ 676 "UPDATE nodes SET repos_id = ?4, dav_cache = NULL " \ 677 "WHERE (wc_id = ?1 AND local_relpath = ?2 AND repos_id = ?3) " \ 678 " 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)) " \ 679 " AND repos_id = ?3) " \ 680 "" 681 682#define STMT_UPDATE_LOCK_REPOS_ID 62 683#define STMT_62_INFO {"STMT_UPDATE_LOCK_REPOS_ID", NULL} 684#define STMT_62 \ 685 "UPDATE lock SET repos_id = ?2 " \ 686 "WHERE repos_id = ?1 " \ 687 "" 688 689#define STMT_UPDATE_NODE_FILEINFO 63 690#define STMT_63_INFO {"STMT_UPDATE_NODE_FILEINFO", NULL} 691#define STMT_63 \ 692 "UPDATE nodes SET translated_size = ?3, last_mod_time = ?4 " \ 693 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 694 " AND op_depth = (SELECT MAX(op_depth) FROM nodes " \ 695 " WHERE wc_id = ?1 AND local_relpath = ?2) " \ 696 "" 697 698#define STMT_INSERT_ACTUAL_CONFLICT 64 699#define STMT_64_INFO {"STMT_INSERT_ACTUAL_CONFLICT", NULL} 700#define STMT_64 \ 701 "INSERT INTO actual_node (wc_id, local_relpath, conflict_data, parent_relpath) " \ 702 "VALUES (?1, ?2, ?3, ?4) " \ 703 "" 704 705#define STMT_UPDATE_ACTUAL_CONFLICT 65 706#define STMT_65_INFO {"STMT_UPDATE_ACTUAL_CONFLICT", NULL} 707#define STMT_65 \ 708 "UPDATE actual_node SET conflict_data = ?3 " \ 709 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 710 "" 711 712#define STMT_UPDATE_ACTUAL_CHANGELISTS 66 713#define STMT_66_INFO {"STMT_UPDATE_ACTUAL_CHANGELISTS", NULL} 714#define STMT_66 \ 715 "UPDATE actual_node SET changelist = ?3 " \ 716 "WHERE wc_id = ?1 " \ 717 " 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))) " \ 718 " AND local_relpath = (SELECT local_relpath FROM targets_list AS t " \ 719 " WHERE wc_id = ?1 " \ 720 " AND t.local_relpath = actual_node.local_relpath " \ 721 " AND kind = 'file') " \ 722 "" 723 724#define STMT_UPDATE_ACTUAL_CLEAR_CHANGELIST 67 725#define STMT_67_INFO {"STMT_UPDATE_ACTUAL_CLEAR_CHANGELIST", NULL} 726#define STMT_67 \ 727 "UPDATE actual_node SET changelist = NULL " \ 728 " WHERE wc_id = ?1 AND local_relpath = ?2 " \ 729 "" 730 731#define STMT_MARK_SKIPPED_CHANGELIST_DIRS 68 732#define STMT_68_INFO {"STMT_MARK_SKIPPED_CHANGELIST_DIRS", NULL} 733#define STMT_68 \ 734 "INSERT INTO changelist_list (wc_id, local_relpath, notify, changelist) " \ 735 "SELECT wc_id, local_relpath, 7, ?3 " \ 736 "FROM targets_list " \ 737 "WHERE wc_id = ?1 " \ 738 " 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))) " \ 739 " AND kind = 'dir' " \ 740 "" 741 742#define STMT_RESET_ACTUAL_WITH_CHANGELIST 69 743#define STMT_69_INFO {"STMT_RESET_ACTUAL_WITH_CHANGELIST", NULL} 744#define STMT_69 \ 745 "REPLACE INTO actual_node ( " \ 746 " wc_id, local_relpath, parent_relpath, changelist) " \ 747 "VALUES (?1, ?2, ?3, ?4) " \ 748 "" 749 750#define STMT_CREATE_CHANGELIST_LIST 70 751#define STMT_70_INFO {"STMT_CREATE_CHANGELIST_LIST", NULL} 752#define STMT_70 \ 753 "DROP TABLE IF EXISTS changelist_list; " \ 754 "CREATE TEMPORARY TABLE changelist_list ( " \ 755 " wc_id INTEGER NOT NULL, " \ 756 " local_relpath TEXT NOT NULL, " \ 757 " notify INTEGER NOT NULL, " \ 758 " changelist TEXT NOT NULL, " \ 759 " PRIMARY KEY (wc_id, local_relpath, notify DESC) " \ 760 ") " \ 761 "" 762 763#define STMT_CREATE_CHANGELIST_TRIGGER 71 764#define STMT_71_INFO {"STMT_CREATE_CHANGELIST_TRIGGER", NULL} 765#define STMT_71 \ 766 "DROP TRIGGER IF EXISTS trigger_changelist_list_change; " \ 767 "CREATE TEMPORARY TRIGGER trigger_changelist_list_change " \ 768 "BEFORE UPDATE ON actual_node " \ 769 "WHEN old.changelist IS NOT new.changelist " \ 770 "BEGIN " \ 771 " INSERT INTO changelist_list(wc_id, local_relpath, notify, changelist) " \ 772 " SELECT old.wc_id, old.local_relpath, 27, old.changelist " \ 773 " WHERE old.changelist is NOT NULL; " \ 774 " INSERT INTO changelist_list(wc_id, local_relpath, notify, changelist) " \ 775 " SELECT new.wc_id, new.local_relpath, 26, new.changelist " \ 776 " WHERE new.changelist IS NOT NULL; " \ 777 "END " \ 778 "" 779 780#define STMT_FINALIZE_CHANGELIST 72 781#define STMT_72_INFO {"STMT_FINALIZE_CHANGELIST", NULL} 782#define STMT_72 \ 783 "DROP TRIGGER trigger_changelist_list_change; " \ 784 "DROP TABLE changelist_list; " \ 785 "DROP TABLE targets_list " \ 786 "" 787 788#define STMT_SELECT_CHANGELIST_LIST 73 789#define STMT_73_INFO {"STMT_SELECT_CHANGELIST_LIST", NULL} 790#define STMT_73 \ 791 "SELECT wc_id, local_relpath, notify, changelist " \ 792 "FROM changelist_list " \ 793 "ORDER BY wc_id, local_relpath ASC, notify DESC " \ 794 "" 795 796#define STMT_CREATE_TARGETS_LIST 74 797#define STMT_74_INFO {"STMT_CREATE_TARGETS_LIST", NULL} 798#define STMT_74 \ 799 "DROP TABLE IF EXISTS targets_list; " \ 800 "CREATE TEMPORARY TABLE targets_list ( " \ 801 " wc_id INTEGER NOT NULL, " \ 802 " local_relpath TEXT NOT NULL, " \ 803 " parent_relpath TEXT, " \ 804 " kind TEXT NOT NULL, " \ 805 " PRIMARY KEY (wc_id, local_relpath) " \ 806 " ); " \ 807 "" 808 809#define STMT_DROP_TARGETS_LIST 75 810#define STMT_75_INFO {"STMT_DROP_TARGETS_LIST", NULL} 811#define STMT_75 \ 812 "DROP TABLE targets_list " \ 813 "" 814 815#define STMT_INSERT_TARGET 76 816#define STMT_76_INFO {"STMT_INSERT_TARGET", NULL} 817#define STMT_76 \ 818 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 819 "SELECT wc_id, local_relpath, parent_relpath, kind " \ 820 "FROM nodes_current " \ 821 "WHERE wc_id = ?1 " \ 822 " AND local_relpath = ?2 " \ 823 "" 824 825#define STMT_INSERT_TARGET_DEPTH_FILES 77 826#define STMT_77_INFO {"STMT_INSERT_TARGET_DEPTH_FILES", NULL} 827#define STMT_77 \ 828 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 829 "SELECT wc_id, local_relpath, parent_relpath, kind " \ 830 "FROM nodes_current " \ 831 "WHERE wc_id = ?1 " \ 832 " AND parent_relpath = ?2 " \ 833 " AND kind = 'file' " \ 834 "" 835 836#define STMT_INSERT_TARGET_DEPTH_IMMEDIATES 78 837#define STMT_78_INFO {"STMT_INSERT_TARGET_DEPTH_IMMEDIATES", NULL} 838#define STMT_78 \ 839 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 840 "SELECT wc_id, local_relpath, parent_relpath, kind " \ 841 "FROM nodes_current " \ 842 "WHERE wc_id = ?1 " \ 843 " AND parent_relpath = ?2 " \ 844 "" 845 846#define STMT_INSERT_TARGET_DEPTH_INFINITY 79 847#define STMT_79_INFO {"STMT_INSERT_TARGET_DEPTH_INFINITY", NULL} 848#define STMT_79 \ 849 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 850 "SELECT wc_id, local_relpath, parent_relpath, kind " \ 851 "FROM nodes_current " \ 852 "WHERE wc_id = ?1 " \ 853 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 854 "" 855 856#define STMT_INSERT_TARGET_WITH_CHANGELIST 80 857#define STMT_80_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST", NULL} 858#define STMT_80 \ 859 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 860 "SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \ 861 " FROM actual_node AS A JOIN nodes_current AS N " \ 862 " ON A.wc_id = N.wc_id AND A.local_relpath = N.local_relpath " \ 863 " WHERE N.wc_id = ?1 " \ 864 " AND N.local_relpath = ?2 " \ 865 " AND A.changelist = ?3 " \ 866 "" 867 868#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_FILES 81 869#define STMT_81_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_FILES", NULL} 870#define STMT_81 \ 871 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 872 "SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \ 873 " FROM actual_node AS A JOIN nodes_current AS N " \ 874 " ON A.wc_id = N.wc_id AND A.local_relpath = N.local_relpath " \ 875 " WHERE N.wc_id = ?1 " \ 876 " AND N.parent_relpath = ?2 " \ 877 " AND kind = 'file' " \ 878 " AND A.changelist = ?3 " \ 879 "" 880 881#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_IMMEDIATES 82 882#define STMT_82_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_IMMEDIATES", NULL} 883#define STMT_82 \ 884 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 885 "SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \ 886 " FROM actual_node AS A JOIN nodes_current AS N " \ 887 " ON A.wc_id = N.wc_id AND A.local_relpath = N.local_relpath " \ 888 " WHERE N.wc_id = ?1 " \ 889 " AND N.parent_relpath = ?2 " \ 890 " AND A.changelist = ?3 " \ 891 "" 892 893#define STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_INFINITY 83 894#define STMT_83_INFO {"STMT_INSERT_TARGET_WITH_CHANGELIST_DEPTH_INFINITY", NULL} 895#define STMT_83 \ 896 "INSERT INTO targets_list(wc_id, local_relpath, parent_relpath, kind) " \ 897 "SELECT N.wc_id, N.local_relpath, N.parent_relpath, N.kind " \ 898 " FROM actual_node AS A JOIN nodes_current AS N " \ 899 " ON A.wc_id = N.wc_id AND A.local_relpath = N.local_relpath " \ 900 " WHERE N.wc_id = ?1 " \ 901 " 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)) " \ 902 " AND A.changelist = ?3 " \ 903 "" 904 905#define STMT_INSERT_ACTUAL_EMPTIES 84 906#define STMT_84_INFO {"STMT_INSERT_ACTUAL_EMPTIES", NULL} 907#define STMT_84 \ 908 "INSERT OR IGNORE INTO actual_node ( " \ 909 " wc_id, local_relpath, parent_relpath) " \ 910 "SELECT wc_id, local_relpath, parent_relpath " \ 911 "FROM targets_list " \ 912 "" 913 914#define STMT_INSERT_ACTUAL_EMPTIES_FILES 85 915#define STMT_85_INFO {"STMT_INSERT_ACTUAL_EMPTIES_FILES", NULL} 916#define STMT_85 \ 917 "INSERT OR IGNORE INTO actual_node ( " \ 918 " wc_id, local_relpath, parent_relpath) " \ 919 "SELECT wc_id, local_relpath, parent_relpath " \ 920 "FROM targets_list " \ 921 "WHERE kind='file' " \ 922 "" 923 924#define STMT_DELETE_ACTUAL_EMPTY 86 925#define STMT_86_INFO {"STMT_DELETE_ACTUAL_EMPTY", NULL} 926#define STMT_86 \ 927 "DELETE FROM actual_node " \ 928 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 929 " AND properties IS NULL " \ 930 " AND conflict_data IS NULL " \ 931 " AND changelist IS NULL " \ 932 " AND text_mod IS NULL " \ 933 " AND older_checksum IS NULL " \ 934 " AND right_checksum IS NULL " \ 935 " AND left_checksum IS NULL " \ 936 "" 937 938#define STMT_DELETE_ACTUAL_EMPTIES 87 939#define STMT_87_INFO {"STMT_DELETE_ACTUAL_EMPTIES", NULL} 940#define STMT_87 \ 941 "DELETE FROM actual_node " \ 942 "WHERE wc_id = ?1 " \ 943 " 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))) " \ 944 " AND properties IS NULL " \ 945 " AND conflict_data IS NULL " \ 946 " AND changelist IS NULL " \ 947 " AND text_mod IS NULL " \ 948 " AND older_checksum IS NULL " \ 949 " AND right_checksum IS NULL " \ 950 " AND left_checksum IS NULL " \ 951 "" 952 953#define STMT_DELETE_BASE_NODE 88 954#define STMT_88_INFO {"STMT_DELETE_BASE_NODE", NULL} 955#define STMT_88 \ 956 "DELETE FROM nodes " \ 957 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 958 "" 959 960#define STMT_DELETE_WORKING_NODE 89 961#define STMT_89_INFO {"STMT_DELETE_WORKING_NODE", NULL} 962#define STMT_89 \ 963 "DELETE FROM nodes " \ 964 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 965 " AND op_depth = (SELECT MAX(op_depth) FROM nodes " \ 966 " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > 0) " \ 967 "" 968 969#define STMT_DELETE_LOWEST_WORKING_NODE 90 970#define STMT_90_INFO {"STMT_DELETE_LOWEST_WORKING_NODE", NULL} 971#define STMT_90 \ 972 "DELETE FROM nodes " \ 973 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 974 " AND op_depth = (SELECT MIN(op_depth) FROM nodes " \ 975 " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3) " \ 976 " AND presence = 'base-deleted' " \ 977 "" 978 979#define STMT_DELETE_NODE_ALL_LAYERS 91 980#define STMT_91_INFO {"STMT_DELETE_NODE_ALL_LAYERS", NULL} 981#define STMT_91 \ 982 "DELETE FROM nodes " \ 983 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 984 "" 985 986#define STMT_DELETE_NODES_ABOVE_DEPTH_RECURSIVE 92 987#define STMT_92_INFO {"STMT_DELETE_NODES_ABOVE_DEPTH_RECURSIVE", NULL} 988#define STMT_92 \ 989 "DELETE FROM nodes " \ 990 "WHERE wc_id = ?1 " \ 991 " AND (local_relpath = ?2 " \ 992 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 993 " AND op_depth >= ?3 " \ 994 "" 995 996#define STMT_DELETE_ACTUAL_NODE 93 997#define STMT_93_INFO {"STMT_DELETE_ACTUAL_NODE", NULL} 998#define STMT_93 \ 999 "DELETE FROM actual_node " \ 1000 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1001 "" 1002 1003#define STMT_DELETE_ACTUAL_NODE_RECURSIVE 94 1004#define STMT_94_INFO {"STMT_DELETE_ACTUAL_NODE_RECURSIVE", NULL} 1005#define STMT_94 \ 1006 "DELETE FROM actual_node " \ 1007 "WHERE wc_id = ?1 " \ 1008 " AND (local_relpath = ?2 " \ 1009 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1010 "" 1011 1012#define STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST 95 1013#define STMT_95_INFO {"STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST", NULL} 1014#define STMT_95 \ 1015 "DELETE FROM actual_node " \ 1016 "WHERE wc_id = ?1 " \ 1017 " AND local_relpath = ?2 " \ 1018 " AND (changelist IS NULL " \ 1019 " OR NOT EXISTS (SELECT 1 FROM nodes_current c " \ 1020 " WHERE c.wc_id = ?1 AND c.local_relpath = ?2 " \ 1021 " AND c.kind = 'file')) " \ 1022 "" 1023 1024#define STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE 96 1025#define STMT_96_INFO {"STMT_DELETE_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE", NULL} 1026#define STMT_96 \ 1027 "DELETE FROM actual_node " \ 1028 "WHERE wc_id = ?1 " \ 1029 " AND (local_relpath = ?2 " \ 1030 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1031 " AND (changelist IS NULL " \ 1032 " OR NOT EXISTS (SELECT 1 FROM nodes_current c " \ 1033 " WHERE c.wc_id = ?1 " \ 1034 " AND c.local_relpath = actual_node.local_relpath " \ 1035 " AND c.kind = 'file')) " \ 1036 "" 1037 1038#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST 97 1039#define STMT_97_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST", NULL} 1040#define STMT_97 \ 1041 "UPDATE actual_node " \ 1042 "SET properties = NULL, " \ 1043 " text_mod = NULL, " \ 1044 " conflict_data = NULL, " \ 1045 " tree_conflict_data = NULL, " \ 1046 " older_checksum = NULL, " \ 1047 " left_checksum = NULL, " \ 1048 " right_checksum = NULL " \ 1049 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1050 "" 1051 1052#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CONFLICT 98 1053#define STMT_98_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CONFLICT", NULL} 1054#define STMT_98 \ 1055 "UPDATE actual_node " \ 1056 "SET properties = NULL, " \ 1057 " text_mod = NULL, " \ 1058 " tree_conflict_data = NULL, " \ 1059 " older_checksum = NULL, " \ 1060 " left_checksum = NULL, " \ 1061 " right_checksum = NULL, " \ 1062 " changelist = NULL " \ 1063 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1064 "" 1065 1066#define STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE 99 1067#define STMT_99_INFO {"STMT_CLEAR_ACTUAL_NODE_LEAVING_CHANGELIST_RECURSIVE", NULL} 1068#define STMT_99 \ 1069 "UPDATE actual_node " \ 1070 "SET properties = NULL, " \ 1071 " text_mod = NULL, " \ 1072 " conflict_data = NULL, " \ 1073 " tree_conflict_data = NULL, " \ 1074 " older_checksum = NULL, " \ 1075 " left_checksum = NULL, " \ 1076 " right_checksum = NULL " \ 1077 "WHERE wc_id = ?1 " \ 1078 " AND (local_relpath = ?2 " \ 1079 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1080 "" 1081 1082#define STMT_UPDATE_NODE_BASE_DEPTH 100 1083#define STMT_100_INFO {"STMT_UPDATE_NODE_BASE_DEPTH", NULL} 1084#define STMT_100 \ 1085 "UPDATE nodes SET depth = ?3 " \ 1086 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1087 " AND kind='dir' " \ 1088 " AND presence IN ('normal', 'incomplete') " \ 1089 "" 1090 1091#define STMT_UPDATE_NODE_BASE_PRESENCE 101 1092#define STMT_101_INFO {"STMT_UPDATE_NODE_BASE_PRESENCE", NULL} 1093#define STMT_101 \ 1094 "UPDATE nodes SET presence = ?3 " \ 1095 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1096 "" 1097 1098#define STMT_UPDATE_BASE_NODE_PRESENCE_REVNUM_AND_REPOS_PATH 102 1099#define STMT_102_INFO {"STMT_UPDATE_BASE_NODE_PRESENCE_REVNUM_AND_REPOS_PATH", NULL} 1100#define STMT_102 \ 1101 "UPDATE nodes SET presence = ?3, revision = ?4, repos_path = ?5 " \ 1102 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1103 "" 1104 1105#define STMT_LOOK_FOR_WORK 103 1106#define STMT_103_INFO {"STMT_LOOK_FOR_WORK", NULL} 1107#define STMT_103 \ 1108 "SELECT id FROM work_queue LIMIT 1 " \ 1109 "" 1110 1111#define STMT_INSERT_WORK_ITEM 104 1112#define STMT_104_INFO {"STMT_INSERT_WORK_ITEM", NULL} 1113#define STMT_104 \ 1114 "INSERT INTO work_queue (work) VALUES (?1) " \ 1115 "" 1116 1117#define STMT_SELECT_WORK_ITEM 105 1118#define STMT_105_INFO {"STMT_SELECT_WORK_ITEM", NULL} 1119#define STMT_105 \ 1120 "SELECT id, work FROM work_queue ORDER BY id LIMIT 1 " \ 1121 "" 1122 1123#define STMT_DELETE_WORK_ITEM 106 1124#define STMT_106_INFO {"STMT_DELETE_WORK_ITEM", NULL} 1125#define STMT_106 \ 1126 "DELETE FROM work_queue WHERE id = ?1 " \ 1127 "" 1128 1129#define STMT_INSERT_OR_IGNORE_PRISTINE 107 1130#define STMT_107_INFO {"STMT_INSERT_OR_IGNORE_PRISTINE", NULL} 1131#define STMT_107 \ 1132 "INSERT OR IGNORE INTO pristine (checksum, md5_checksum, size, refcount) " \ 1133 "VALUES (?1, ?2, ?3, 0) " \ 1134 "" 1135 1136#define STMT_INSERT_PRISTINE 108 1137#define STMT_108_INFO {"STMT_INSERT_PRISTINE", NULL} 1138#define STMT_108 \ 1139 "INSERT INTO pristine (checksum, md5_checksum, size, refcount) " \ 1140 "VALUES (?1, ?2, ?3, 0) " \ 1141 "" 1142 1143#define STMT_SELECT_PRISTINE 109 1144#define STMT_109_INFO {"STMT_SELECT_PRISTINE", NULL} 1145#define STMT_109 \ 1146 "SELECT md5_checksum " \ 1147 "FROM pristine " \ 1148 "WHERE checksum = ?1 " \ 1149 "" 1150 1151#define STMT_SELECT_PRISTINE_SIZE 110 1152#define STMT_110_INFO {"STMT_SELECT_PRISTINE_SIZE", NULL} 1153#define STMT_110 \ 1154 "SELECT size " \ 1155 "FROM pristine " \ 1156 "WHERE checksum = ?1 LIMIT 1 " \ 1157 "" 1158 1159#define STMT_SELECT_PRISTINE_BY_MD5 111 1160#define STMT_111_INFO {"STMT_SELECT_PRISTINE_BY_MD5", NULL} 1161#define STMT_111 \ 1162 "SELECT checksum " \ 1163 "FROM pristine " \ 1164 "WHERE md5_checksum = ?1 " \ 1165 "" 1166 1167#define STMT_SELECT_UNREFERENCED_PRISTINES 112 1168#define STMT_112_INFO {"STMT_SELECT_UNREFERENCED_PRISTINES", NULL} 1169#define STMT_112 \ 1170 "SELECT checksum " \ 1171 "FROM pristine " \ 1172 "WHERE refcount = 0 " \ 1173 "" 1174 1175#define STMT_DELETE_PRISTINE_IF_UNREFERENCED 113 1176#define STMT_113_INFO {"STMT_DELETE_PRISTINE_IF_UNREFERENCED", NULL} 1177#define STMT_113 \ 1178 "DELETE FROM pristine " \ 1179 "WHERE checksum = ?1 AND refcount = 0 " \ 1180 "" 1181 1182#define STMT_SELECT_COPY_PRISTINES 114 1183#define STMT_114_INFO {"STMT_SELECT_COPY_PRISTINES", NULL} 1184#define STMT_114 \ 1185 "SELECT n.checksum, md5_checksum, size " \ 1186 "FROM nodes_current n " \ 1187 "LEFT JOIN pristine p ON n.checksum = p.checksum " \ 1188 "WHERE wc_id = ?1 " \ 1189 " AND n.local_relpath = ?2 " \ 1190 " AND n.checksum IS NOT NULL " \ 1191 "UNION ALL " \ 1192 "SELECT n.checksum, md5_checksum, size " \ 1193 "FROM nodes n " \ 1194 "LEFT JOIN pristine p ON n.checksum = p.checksum " \ 1195 "WHERE wc_id = ?1 " \ 1196 " 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)) " \ 1197 " AND op_depth >= " \ 1198 " (SELECT MAX(op_depth) FROM nodes WHERE wc_id = ?1 AND local_relpath = ?2) " \ 1199 " AND n.checksum IS NOT NULL " \ 1200 "" 1201 1202#define STMT_VACUUM 115 1203#define STMT_115_INFO {"STMT_VACUUM", NULL} 1204#define STMT_115 \ 1205 "VACUUM " \ 1206 "" 1207 1208#define STMT_SELECT_CONFLICT_VICTIMS 116 1209#define STMT_116_INFO {"STMT_SELECT_CONFLICT_VICTIMS", NULL} 1210#define STMT_116 \ 1211 "SELECT local_relpath, conflict_data " \ 1212 "FROM actual_node " \ 1213 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND " \ 1214 " NOT (conflict_data IS NULL) " \ 1215 "" 1216 1217#define STMT_INSERT_WC_LOCK 117 1218#define STMT_117_INFO {"STMT_INSERT_WC_LOCK", NULL} 1219#define STMT_117 \ 1220 "INSERT INTO wc_lock (wc_id, local_dir_relpath, locked_levels) " \ 1221 "VALUES (?1, ?2, ?3) " \ 1222 "" 1223 1224#define STMT_SELECT_WC_LOCK 118 1225#define STMT_118_INFO {"STMT_SELECT_WC_LOCK", NULL} 1226#define STMT_118 \ 1227 "SELECT locked_levels FROM wc_lock " \ 1228 "WHERE wc_id = ?1 AND local_dir_relpath = ?2 " \ 1229 "" 1230 1231#define STMT_SELECT_ANCESTOR_WCLOCKS 119 1232#define STMT_119_INFO {"STMT_SELECT_ANCESTOR_WCLOCKS", NULL} 1233#define STMT_119 \ 1234 "SELECT local_dir_relpath, locked_levels FROM wc_lock " \ 1235 "WHERE wc_id = ?1 " \ 1236 " AND ((local_dir_relpath >= ?3 AND local_dir_relpath <= ?2) " \ 1237 " OR local_dir_relpath = '') " \ 1238 "" 1239 1240#define STMT_DELETE_WC_LOCK 120 1241#define STMT_120_INFO {"STMT_DELETE_WC_LOCK", NULL} 1242#define STMT_120 \ 1243 "DELETE FROM wc_lock " \ 1244 "WHERE wc_id = ?1 AND local_dir_relpath = ?2 " \ 1245 "" 1246 1247#define STMT_FIND_WC_LOCK 121 1248#define STMT_121_INFO {"STMT_FIND_WC_LOCK", NULL} 1249#define STMT_121 \ 1250 "SELECT local_dir_relpath FROM wc_lock " \ 1251 "WHERE wc_id = ?1 " \ 1252 " 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)) " \ 1253 "" 1254 1255#define STMT_FIND_CONFLICT_DESCENDANT 122 1256#define STMT_122_INFO {"STMT_FIND_CONFLICT_DESCENDANT", NULL} 1257#define STMT_122 \ 1258 "SELECT 1 FROM actual_node " \ 1259 "WHERE wc_id = ?1 " \ 1260 " AND local_relpath > (?2 || '/') " \ 1261 " AND local_relpath < (?2 || '0') " \ 1262 " AND conflict_data IS NOT NULL " \ 1263 "LIMIT 1 " \ 1264 "" 1265 1266#define STMT_DELETE_WC_LOCK_ORPHAN 123 1267#define STMT_123_INFO {"STMT_DELETE_WC_LOCK_ORPHAN", NULL} 1268#define STMT_123 \ 1269 "DELETE FROM wc_lock " \ 1270 "WHERE wc_id = ?1 AND local_dir_relpath = ?2 " \ 1271 "AND NOT EXISTS (SELECT 1 FROM nodes " \ 1272 " WHERE nodes.wc_id = ?1 " \ 1273 " AND nodes.local_relpath = wc_lock.local_dir_relpath) " \ 1274 "" 1275 1276#define STMT_DELETE_WC_LOCK_ORPHAN_RECURSIVE 124 1277#define STMT_124_INFO {"STMT_DELETE_WC_LOCK_ORPHAN_RECURSIVE", NULL} 1278#define STMT_124 \ 1279 "DELETE FROM wc_lock " \ 1280 "WHERE wc_id = ?1 " \ 1281 " AND (local_dir_relpath = ?2 " \ 1282 " OR (((local_dir_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_dir_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1283 " AND NOT EXISTS (SELECT 1 FROM nodes " \ 1284 " WHERE nodes.wc_id = ?1 " \ 1285 " AND nodes.local_relpath = wc_lock.local_dir_relpath) " \ 1286 "" 1287 1288#define STMT_APPLY_CHANGES_TO_BASE_NODE 125 1289#define STMT_125_INFO {"STMT_APPLY_CHANGES_TO_BASE_NODE", NULL} 1290#define STMT_125 \ 1291 "INSERT OR REPLACE INTO nodes ( " \ 1292 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, repos_path, " \ 1293 " revision, presence, depth, kind, changed_revision, changed_date, " \ 1294 " changed_author, checksum, properties, dav_cache, symlink_target, " \ 1295 " inherited_props, file_external ) " \ 1296 "VALUES (?1, ?2, 0, " \ 1297 " ?3, ?4, ?5, ?6, ?7, ?8, ?9, ?10, ?11, ?12, ?13, ?14, ?15, ?16, ?17, " \ 1298 " (SELECT file_external FROM nodes " \ 1299 " WHERE wc_id = ?1 " \ 1300 " AND local_relpath = ?2 " \ 1301 " AND op_depth = 0)) " \ 1302 "" 1303 1304#define STMT_INSTALL_WORKING_NODE_FOR_DELETE 126 1305#define STMT_126_INFO {"STMT_INSTALL_WORKING_NODE_FOR_DELETE", NULL} 1306#define STMT_126 \ 1307 "INSERT INTO nodes ( " \ 1308 " wc_id, local_relpath, op_depth, " \ 1309 " parent_relpath, presence, kind) " \ 1310 "VALUES(?1, ?2, ?3, ?4, 'base-deleted', ?5) " \ 1311 "" 1312 1313#define STMT_REPLACE_WITH_BASE_DELETED 127 1314#define STMT_127_INFO {"STMT_REPLACE_WITH_BASE_DELETED", NULL} 1315#define STMT_127 \ 1316 "INSERT OR REPLACE INTO nodes (wc_id, local_relpath, op_depth, parent_relpath, " \ 1317 " kind, moved_to, presence) " \ 1318 "SELECT wc_id, local_relpath, op_depth, parent_relpath, " \ 1319 " kind, moved_to, 'base-deleted' " \ 1320 " FROM nodes " \ 1321 " WHERE wc_id = ?1 " \ 1322 " AND local_relpath = ?2 " \ 1323 " AND op_depth = ?3 " \ 1324 "" 1325 1326#define STMT_INSERT_DELETE_FROM_NODE_RECURSIVE 128 1327#define STMT_128_INFO {"STMT_INSERT_DELETE_FROM_NODE_RECURSIVE", NULL} 1328#define STMT_128 \ 1329 "INSERT INTO nodes ( " \ 1330 " wc_id, local_relpath, op_depth, parent_relpath, presence, kind) " \ 1331 "SELECT wc_id, local_relpath, ?4 , parent_relpath, 'base-deleted', " \ 1332 " kind " \ 1333 "FROM nodes " \ 1334 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 1335 "UNION ALL " \ 1336 "SELECT wc_id, local_relpath, ?4 , parent_relpath, 'base-deleted', " \ 1337 " kind " \ 1338 "FROM nodes " \ 1339 "WHERE wc_id = ?1 " \ 1340 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1341 " AND op_depth = ?3 " \ 1342 " AND presence NOT IN ('base-deleted', 'not-present', 'excluded', 'server-excluded') " \ 1343 " AND file_external IS NULL " \ 1344 "ORDER BY local_relpath " \ 1345 "" 1346 1347#define STMT_INSERT_WORKING_NODE_FROM_BASE_COPY 129 1348#define STMT_129_INFO {"STMT_INSERT_WORKING_NODE_FROM_BASE_COPY", NULL} 1349#define STMT_129 \ 1350 "INSERT OR REPLACE INTO nodes ( " \ 1351 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, repos_path, " \ 1352 " revision, presence, depth, kind, changed_revision, changed_date, " \ 1353 " changed_author, checksum, properties, translated_size, last_mod_time, " \ 1354 " symlink_target, moved_to ) " \ 1355 "SELECT wc_id, local_relpath, ?3 , parent_relpath, repos_id, " \ 1356 " repos_path, revision, presence, depth, kind, changed_revision, " \ 1357 " changed_date, changed_author, checksum, properties, translated_size, " \ 1358 " last_mod_time, symlink_target, " \ 1359 " (SELECT moved_to FROM nodes " \ 1360 " WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3) moved_to " \ 1361 "FROM nodes " \ 1362 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1363 "" 1364 1365#define STMT_INSERT_DELETE_FROM_BASE 130 1366#define STMT_130_INFO {"STMT_INSERT_DELETE_FROM_BASE", NULL} 1367#define STMT_130 \ 1368 "INSERT INTO nodes ( " \ 1369 " wc_id, local_relpath, op_depth, parent_relpath, presence, kind) " \ 1370 "SELECT wc_id, local_relpath, ?3 , parent_relpath, " \ 1371 " 'base-deleted', kind " \ 1372 "FROM nodes " \ 1373 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1374 "" 1375 1376#define STMT_UPDATE_OP_DEPTH_INCREASE_RECURSIVE 131 1377#define STMT_131_INFO {"STMT_UPDATE_OP_DEPTH_INCREASE_RECURSIVE", NULL} 1378#define STMT_131 \ 1379 "UPDATE nodes SET op_depth = ?3 + 1 " \ 1380 "WHERE wc_id = ?1 " \ 1381 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1382 " AND op_depth = ?3 " \ 1383 "" 1384 1385#define STMT_COPY_OP_DEPTH_RECURSIVE 132 1386#define STMT_132_INFO {"STMT_COPY_OP_DEPTH_RECURSIVE", NULL} 1387#define STMT_132 \ 1388 "INSERT INTO nodes ( " \ 1389 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, repos_path, " \ 1390 " revision, presence, depth, kind, changed_revision, changed_date, " \ 1391 " changed_author, checksum, properties, translated_size, last_mod_time, " \ 1392 " symlink_target, moved_here, moved_to ) " \ 1393 "SELECT " \ 1394 " wc_id, local_relpath, ?4, parent_relpath, repos_id, " \ 1395 " repos_path, revision, presence, depth, kind, changed_revision, " \ 1396 " changed_date, changed_author, checksum, properties, translated_size, " \ 1397 " last_mod_time, symlink_target, NULL, NULL " \ 1398 "FROM nodes " \ 1399 "WHERE wc_id = ?1 AND op_depth = ?3 AND local_relpath = ?2 " \ 1400 "UNION ALL " \ 1401 "SELECT " \ 1402 " wc_id, local_relpath, ?4, parent_relpath, repos_id, " \ 1403 " repos_path, revision, presence, depth, kind, changed_revision, " \ 1404 " changed_date, changed_author, checksum, properties, translated_size, " \ 1405 " last_mod_time, symlink_target, NULL, NULL " \ 1406 "FROM nodes " \ 1407 "WHERE wc_id = ?1 AND op_depth = ?3 " \ 1408 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1409 "ORDER BY local_relpath " \ 1410 "" 1411 1412#define STMT_DOES_NODE_EXIST 133 1413#define STMT_133_INFO {"STMT_DOES_NODE_EXIST", NULL} 1414#define STMT_133 \ 1415 "SELECT 1 FROM nodes WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1416 "LIMIT 1 " \ 1417 "" 1418 1419#define STMT_HAS_SERVER_EXCLUDED_DESCENDANTS 134 1420#define STMT_134_INFO {"STMT_HAS_SERVER_EXCLUDED_DESCENDANTS", NULL} 1421#define STMT_134 \ 1422 "SELECT local_relpath FROM nodes " \ 1423 "WHERE wc_id = ?1 " \ 1424 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1425 " AND op_depth = 0 AND presence = 'server-excluded' " \ 1426 "LIMIT 1 " \ 1427 "" 1428 1429#define STMT_SELECT_ALL_EXCLUDED_DESCENDANTS 135 1430#define STMT_135_INFO {"STMT_SELECT_ALL_EXCLUDED_DESCENDANTS", NULL} 1431#define STMT_135 \ 1432 "SELECT local_relpath FROM nodes " \ 1433 "WHERE wc_id = ?1 " \ 1434 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1435 " AND op_depth = 0 " \ 1436 " AND (presence = 'server-excluded' OR presence = 'excluded') " \ 1437 "" 1438 1439#define STMT_INSERT_WORKING_NODE_COPY_FROM 136 1440#define STMT_136_INFO {"STMT_INSERT_WORKING_NODE_COPY_FROM", NULL} 1441#define STMT_136 \ 1442 "INSERT OR REPLACE INTO nodes ( " \ 1443 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, " \ 1444 " repos_path, revision, presence, depth, moved_here, kind, changed_revision, " \ 1445 " changed_date, changed_author, checksum, properties, translated_size, " \ 1446 " last_mod_time, symlink_target, moved_to ) " \ 1447 "SELECT wc_id, ?3 , ?4 , ?5 , " \ 1448 " repos_id, repos_path, revision, ?6 , depth, " \ 1449 " ?7, kind, changed_revision, changed_date, " \ 1450 " changed_author, checksum, properties, translated_size, " \ 1451 " last_mod_time, symlink_target, " \ 1452 " (SELECT dst.moved_to FROM nodes AS dst " \ 1453 " WHERE dst.wc_id = ?1 " \ 1454 " AND dst.local_relpath = ?3 " \ 1455 " AND dst.op_depth = ?4) " \ 1456 "FROM nodes_current " \ 1457 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1458 "" 1459 1460#define STMT_INSERT_WORKING_NODE_COPY_FROM_DEPTH 137 1461#define STMT_137_INFO {"STMT_INSERT_WORKING_NODE_COPY_FROM_DEPTH", NULL} 1462#define STMT_137 \ 1463 "INSERT OR REPLACE INTO nodes ( " \ 1464 " wc_id, local_relpath, op_depth, parent_relpath, repos_id, " \ 1465 " repos_path, revision, presence, depth, moved_here, kind, changed_revision, " \ 1466 " changed_date, changed_author, checksum, properties, translated_size, " \ 1467 " last_mod_time, symlink_target, moved_to ) " \ 1468 "SELECT wc_id, ?3 , ?4 , ?5 , " \ 1469 " repos_id, repos_path, revision, ?6 , depth, " \ 1470 " ?8 , kind, changed_revision, changed_date, " \ 1471 " changed_author, checksum, properties, translated_size, " \ 1472 " last_mod_time, symlink_target, " \ 1473 " (SELECT dst.moved_to FROM nodes AS dst " \ 1474 " WHERE dst.wc_id = ?1 " \ 1475 " AND dst.local_relpath = ?3 " \ 1476 " AND dst.op_depth = ?4) " \ 1477 "FROM nodes " \ 1478 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?7 " \ 1479 "" 1480 1481#define STMT_UPDATE_BASE_REVISION 138 1482#define STMT_138_INFO {"STMT_UPDATE_BASE_REVISION", NULL} 1483#define STMT_138 \ 1484 "UPDATE nodes SET revision = ?3 " \ 1485 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1486 "" 1487 1488#define STMT_UPDATE_BASE_REPOS 139 1489#define STMT_139_INFO {"STMT_UPDATE_BASE_REPOS", NULL} 1490#define STMT_139 \ 1491 "UPDATE nodes SET repos_id = ?3, repos_path = ?4 " \ 1492 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0 " \ 1493 "" 1494 1495#define STMT_ACTUAL_HAS_CHILDREN 140 1496#define STMT_140_INFO {"STMT_ACTUAL_HAS_CHILDREN", NULL} 1497#define STMT_140 \ 1498 "SELECT 1 FROM actual_node " \ 1499 "WHERE wc_id = ?1 AND parent_relpath = ?2 " \ 1500 "LIMIT 1 " \ 1501 "" 1502 1503#define STMT_INSERT_EXTERNAL 141 1504#define STMT_141_INFO {"STMT_INSERT_EXTERNAL", NULL} 1505#define STMT_141 \ 1506 "INSERT OR REPLACE INTO externals ( " \ 1507 " wc_id, local_relpath, parent_relpath, presence, kind, def_local_relpath, " \ 1508 " repos_id, def_repos_relpath, def_operational_revision, def_revision) " \ 1509 "VALUES (?1, ?2, ?3, ?4, ?5, ?6, ?7, ?8, ?9, ?10) " \ 1510 "" 1511 1512#define STMT_SELECT_EXTERNAL_INFO 142 1513#define STMT_142_INFO {"STMT_SELECT_EXTERNAL_INFO", NULL} 1514#define STMT_142 \ 1515 "SELECT presence, kind, def_local_relpath, repos_id, " \ 1516 " def_repos_relpath, def_operational_revision, def_revision " \ 1517 "FROM externals WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1518 "LIMIT 1 " \ 1519 "" 1520 1521#define STMT_DELETE_FILE_EXTERNALS 143 1522#define STMT_143_INFO {"STMT_DELETE_FILE_EXTERNALS", NULL} 1523#define STMT_143 \ 1524 "DELETE FROM nodes " \ 1525 "WHERE wc_id = ?1 " \ 1526 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1527 " AND op_depth = 0 " \ 1528 " AND file_external IS NOT NULL " \ 1529 "" 1530 1531#define STMT_DELETE_FILE_EXTERNAL_REGISTATIONS 144 1532#define STMT_144_INFO {"STMT_DELETE_FILE_EXTERNAL_REGISTATIONS", NULL} 1533#define STMT_144 \ 1534 "DELETE FROM externals " \ 1535 "WHERE wc_id = ?1 " \ 1536 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1537 " AND kind != 'dir' " \ 1538 "" 1539 1540#define STMT_DELETE_EXTERNAL_REGISTATIONS 145 1541#define STMT_145_INFO {"STMT_DELETE_EXTERNAL_REGISTATIONS", NULL} 1542#define STMT_145 \ 1543 "DELETE FROM externals " \ 1544 "WHERE wc_id = ?1 " \ 1545 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1546 "" 1547 1548#define STMT_SELECT_COMMITTABLE_EXTERNALS_BELOW 146 1549#define STMT_146_INFO {"STMT_SELECT_COMMITTABLE_EXTERNALS_BELOW", NULL} 1550#define STMT_146 \ 1551 "SELECT local_relpath, kind, def_repos_relpath, " \ 1552 " (SELECT root FROM repository AS r WHERE r.id = e.repos_id) " \ 1553 "FROM externals e " \ 1554 "WHERE wc_id = ?1 " \ 1555 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1556 " AND def_revision IS NULL " \ 1557 " AND repos_id = (SELECT repos_id " \ 1558 " FROM nodes AS n " \ 1559 " WHERE n.wc_id = ?1 " \ 1560 " AND n.local_relpath = '' " \ 1561 " AND n.op_depth = 0) " \ 1562 " AND ((kind='dir') " \ 1563 " OR EXISTS (SELECT 1 FROM nodes " \ 1564 " WHERE nodes.wc_id = e.wc_id " \ 1565 " AND nodes.local_relpath = e.parent_relpath)) " \ 1566 "" 1567 1568#define STMT_SELECT_COMMITTABLE_EXTERNALS_IMMEDIATELY_BELOW 147 1569#define STMT_147_INFO {"STMT_SELECT_COMMITTABLE_EXTERNALS_IMMEDIATELY_BELOW", NULL} 1570#define STMT_147 \ 1571 "SELECT local_relpath, kind, def_repos_relpath, " \ 1572 " (SELECT root FROM repository AS r WHERE r.id = e.repos_id) " \ 1573 "FROM externals e " \ 1574 "WHERE wc_id = ?1 " \ 1575 " AND (((e.local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((e.local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1576 " AND parent_relpath = ?2 " \ 1577 " AND def_revision IS NULL " \ 1578 " AND repos_id = (SELECT repos_id " \ 1579 " FROM nodes AS n " \ 1580 " WHERE n.wc_id = ?1 " \ 1581 " AND n.local_relpath = '' " \ 1582 " AND n.op_depth = 0) " \ 1583 " AND ((kind='dir') " \ 1584 " OR EXISTS (SELECT 1 FROM nodes " \ 1585 " WHERE nodes.wc_id = e.wc_id " \ 1586 " AND nodes.local_relpath = e.parent_relpath)) " \ 1587 "" 1588 1589#define STMT_SELECT_EXTERNALS_DEFINED 148 1590#define STMT_148_INFO {"STMT_SELECT_EXTERNALS_DEFINED", NULL} 1591#define STMT_148 \ 1592 "SELECT local_relpath, def_local_relpath " \ 1593 "FROM externals " \ 1594 "WHERE (wc_id = ?1 AND def_local_relpath = ?2) " \ 1595 " 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))) " \ 1596 "" 1597 1598#define STMT_DELETE_EXTERNAL 149 1599#define STMT_149_INFO {"STMT_DELETE_EXTERNAL", NULL} 1600#define STMT_149 \ 1601 "DELETE FROM externals " \ 1602 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1603 "" 1604 1605#define STMT_SELECT_EXTERNAL_PROPERTIES 150 1606#define STMT_150_INFO {"STMT_SELECT_EXTERNAL_PROPERTIES", NULL} 1607#define STMT_150 \ 1608 "SELECT IFNULL((SELECT properties FROM actual_node a " \ 1609 " WHERE a.wc_id = ?1 AND A.local_relpath = n.local_relpath), " \ 1610 " properties), " \ 1611 " local_relpath, depth " \ 1612 "FROM nodes_current n " \ 1613 "WHERE wc_id = ?1 AND local_relpath = ?2 " \ 1614 " AND kind = 'dir' AND presence IN ('normal', 'incomplete') " \ 1615 "UNION ALL " \ 1616 "SELECT IFNULL((SELECT properties FROM actual_node a " \ 1617 " WHERE a.wc_id = ?1 AND A.local_relpath = n.local_relpath), " \ 1618 " properties), " \ 1619 " local_relpath, depth " \ 1620 "FROM nodes_current n " \ 1621 "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)) " \ 1622 " AND kind = 'dir' AND presence IN ('normal', 'incomplete') " \ 1623 "" 1624 1625#define STMT_SELECT_CURRENT_PROPS_RECURSIVE 151 1626#define STMT_151_INFO {"STMT_SELECT_CURRENT_PROPS_RECURSIVE", NULL} 1627#define STMT_151 \ 1628 "SELECT IFNULL((SELECT properties FROM actual_node a " \ 1629 " WHERE a.wc_id = ?1 AND A.local_relpath = n.local_relpath), " \ 1630 " properties), " \ 1631 " local_relpath " \ 1632 "FROM nodes_current n " \ 1633 "WHERE (wc_id = ?1 AND local_relpath = ?2) " \ 1634 " 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))) " \ 1635 "" 1636 1637#define STMT_PRAGMA_LOCKING_MODE 152 1638#define STMT_152_INFO {"STMT_PRAGMA_LOCKING_MODE", NULL} 1639#define STMT_152 \ 1640 "PRAGMA locking_mode = exclusive; " \ 1641 "PRAGMA journal_mode = DELETE " \ 1642 "" 1643 1644#define STMT_FIND_REPOS_PATH_IN_WC 153 1645#define STMT_153_INFO {"STMT_FIND_REPOS_PATH_IN_WC", NULL} 1646#define STMT_153 \ 1647 "SELECT local_relpath FROM nodes_current " \ 1648 " WHERE wc_id = ?1 AND repos_path = ?2 " \ 1649 "" 1650 1651#define STMT_INSERT_ACTUAL_NODE 154 1652#define STMT_154_INFO {"STMT_INSERT_ACTUAL_NODE", NULL} 1653#define STMT_154 \ 1654 "INSERT OR REPLACE INTO actual_node ( " \ 1655 " wc_id, local_relpath, parent_relpath, properties, changelist, conflict_data) " \ 1656 "VALUES (?1, ?2, ?3, ?4, ?5, ?6) " \ 1657 "" 1658 1659#define STMT_SELECT_ALL_FILES 155 1660#define STMT_155_INFO {"STMT_SELECT_ALL_FILES", NULL} 1661#define STMT_155 \ 1662 "SELECT local_relpath FROM nodes_current " \ 1663 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND kind = 'file' " \ 1664 "" 1665 1666#define STMT_UPDATE_NODE_PROPS 156 1667#define STMT_156_INFO {"STMT_UPDATE_NODE_PROPS", NULL} 1668#define STMT_156 \ 1669 "UPDATE nodes SET properties = ?4 " \ 1670 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 1671 "" 1672 1673#define STMT_PRAGMA_TABLE_INFO_NODES 157 1674#define STMT_157_INFO {"STMT_PRAGMA_TABLE_INFO_NODES", NULL} 1675#define STMT_157 \ 1676 "PRAGMA table_info(\"NODES\") " \ 1677 "" 1678 1679#define STMT_CREATE_TARGET_PROP_CACHE 158 1680#define STMT_158_INFO {"STMT_CREATE_TARGET_PROP_CACHE", NULL} 1681#define STMT_158 \ 1682 "DROP TABLE IF EXISTS target_prop_cache; " \ 1683 "CREATE TEMPORARY TABLE target_prop_cache ( " \ 1684 " local_relpath TEXT NOT NULL PRIMARY KEY, " \ 1685 " kind TEXT NOT NULL, " \ 1686 " properties BLOB " \ 1687 "); " \ 1688 "" 1689 1690#define STMT_CACHE_TARGET_PROPS 159 1691#define STMT_159_INFO {"STMT_CACHE_TARGET_PROPS", NULL} 1692#define STMT_159 \ 1693 "INSERT INTO target_prop_cache(local_relpath, kind, properties) " \ 1694 " SELECT n.local_relpath, n.kind, " \ 1695 " IFNULL((SELECT properties FROM actual_node AS a " \ 1696 " WHERE a.wc_id = n.wc_id " \ 1697 " AND a.local_relpath = n.local_relpath), " \ 1698 " n.properties) " \ 1699 " FROM targets_list AS t " \ 1700 " JOIN nodes AS n " \ 1701 " ON n.wc_id = ?1 " \ 1702 " AND n.local_relpath = t.local_relpath " \ 1703 " AND n.op_depth = (SELECT MAX(op_depth) FROM nodes AS n3 " \ 1704 " WHERE n3.wc_id = ?1 " \ 1705 " AND n3.local_relpath = t.local_relpath) " \ 1706 " WHERE t.wc_id = ?1 " \ 1707 " AND (presence='normal' OR presence='incomplete') " \ 1708 " ORDER BY t.local_relpath " \ 1709 "" 1710 1711#define STMT_CACHE_TARGET_PRISTINE_PROPS 160 1712#define STMT_160_INFO {"STMT_CACHE_TARGET_PRISTINE_PROPS", NULL} 1713#define STMT_160 \ 1714 "INSERT INTO target_prop_cache(local_relpath, kind, properties) " \ 1715 " SELECT n.local_relpath, n.kind, " \ 1716 " CASE n.presence " \ 1717 " WHEN 'base-deleted' " \ 1718 " THEN (SELECT properties FROM nodes AS p " \ 1719 " WHERE p.wc_id = n.wc_id " \ 1720 " AND p.local_relpath = n.local_relpath " \ 1721 " AND p.op_depth < n.op_depth " \ 1722 " ORDER BY p.op_depth DESC ) " \ 1723 " ELSE properties END " \ 1724 " FROM targets_list AS t " \ 1725 " JOIN nodes AS n " \ 1726 " ON n.wc_id = ?1 " \ 1727 " AND n.local_relpath = t.local_relpath " \ 1728 " AND n.op_depth = (SELECT MAX(op_depth) FROM nodes AS n3 " \ 1729 " WHERE n3.wc_id = ?1 " \ 1730 " AND n3.local_relpath = t.local_relpath) " \ 1731 " WHERE t.wc_id = ?1 " \ 1732 " AND (presence = 'normal' " \ 1733 " OR presence = 'incomplete' " \ 1734 " OR presence = 'base-deleted') " \ 1735 " ORDER BY t.local_relpath " \ 1736 "" 1737 1738#define STMT_SELECT_ALL_TARGET_PROP_CACHE 161 1739#define STMT_161_INFO {"STMT_SELECT_ALL_TARGET_PROP_CACHE", NULL} 1740#define STMT_161 \ 1741 "SELECT local_relpath, properties FROM target_prop_cache " \ 1742 "ORDER BY local_relpath " \ 1743 "" 1744 1745#define STMT_DROP_TARGET_PROP_CACHE 162 1746#define STMT_162_INFO {"STMT_DROP_TARGET_PROP_CACHE", NULL} 1747#define STMT_162 \ 1748 "DROP TABLE target_prop_cache; " \ 1749 "" 1750 1751#define STMT_CREATE_REVERT_LIST 163 1752#define STMT_163_INFO {"STMT_CREATE_REVERT_LIST", NULL} 1753#define STMT_163 \ 1754 "DROP TABLE IF EXISTS revert_list; " \ 1755 "CREATE TEMPORARY TABLE revert_list ( " \ 1756 " local_relpath TEXT NOT NULL, " \ 1757 " actual INTEGER NOT NULL, " \ 1758 " conflict_data BLOB, " \ 1759 " notify INTEGER, " \ 1760 " op_depth INTEGER, " \ 1761 " repos_id INTEGER, " \ 1762 " kind TEXT, " \ 1763 " PRIMARY KEY (local_relpath, actual) " \ 1764 " ); " \ 1765 "DROP TRIGGER IF EXISTS trigger_revert_list_nodes; " \ 1766 "CREATE TEMPORARY TRIGGER trigger_revert_list_nodes " \ 1767 "BEFORE DELETE ON nodes " \ 1768 "BEGIN " \ 1769 " INSERT OR REPLACE INTO revert_list(local_relpath, actual, op_depth, " \ 1770 " repos_id, kind) " \ 1771 " SELECT OLD.local_relpath, 0, OLD.op_depth, OLD.repos_id, OLD.kind; " \ 1772 "END; " \ 1773 "DROP TRIGGER IF EXISTS trigger_revert_list_actual_delete; " \ 1774 "CREATE TEMPORARY TRIGGER trigger_revert_list_actual_delete " \ 1775 "BEFORE DELETE ON actual_node " \ 1776 "BEGIN " \ 1777 " INSERT OR REPLACE INTO revert_list(local_relpath, actual, conflict_data, " \ 1778 " notify) " \ 1779 " SELECT OLD.local_relpath, 1, OLD.conflict_data, " \ 1780 " CASE " \ 1781 " WHEN OLD.properties IS NOT NULL " \ 1782 " THEN 1 " \ 1783 " WHEN NOT EXISTS(SELECT 1 FROM NODES n " \ 1784 " WHERE n.wc_id = OLD.wc_id " \ 1785 " AND n.local_relpath = OLD.local_relpath) " \ 1786 " THEN 1 " \ 1787 " END notify " \ 1788 " WHERE OLD.conflict_data IS NOT NULL " \ 1789 " OR notify IS NOT NULL; " \ 1790 "END; " \ 1791 "DROP TRIGGER IF EXISTS trigger_revert_list_actual_update; " \ 1792 "CREATE TEMPORARY TRIGGER trigger_revert_list_actual_update " \ 1793 "BEFORE UPDATE ON actual_node " \ 1794 "BEGIN " \ 1795 " INSERT OR REPLACE INTO revert_list(local_relpath, actual, conflict_data, " \ 1796 " notify) " \ 1797 " SELECT OLD.local_relpath, 1, OLD.conflict_data, " \ 1798 " CASE " \ 1799 " WHEN OLD.properties IS NOT NULL " \ 1800 " THEN 1 " \ 1801 " WHEN NOT EXISTS(SELECT 1 FROM NODES n " \ 1802 " WHERE n.wc_id = OLD.wc_id " \ 1803 " AND n.local_relpath = OLD.local_relpath) " \ 1804 " THEN 1 " \ 1805 " END notify " \ 1806 " WHERE OLD.conflict_data IS NOT NULL " \ 1807 " OR notify IS NOT NULL; " \ 1808 "END " \ 1809 "" 1810 1811#define STMT_DROP_REVERT_LIST_TRIGGERS 164 1812#define STMT_164_INFO {"STMT_DROP_REVERT_LIST_TRIGGERS", NULL} 1813#define STMT_164 \ 1814 "DROP TRIGGER trigger_revert_list_nodes; " \ 1815 "DROP TRIGGER trigger_revert_list_actual_delete; " \ 1816 "DROP TRIGGER trigger_revert_list_actual_update " \ 1817 "" 1818 1819#define STMT_SELECT_REVERT_LIST 165 1820#define STMT_165_INFO {"STMT_SELECT_REVERT_LIST", NULL} 1821#define STMT_165 \ 1822 "SELECT actual, notify, kind, op_depth, repos_id, conflict_data " \ 1823 "FROM revert_list " \ 1824 "WHERE local_relpath = ?1 " \ 1825 "ORDER BY actual DESC " \ 1826 "" 1827 1828#define STMT_SELECT_REVERT_LIST_COPIED_CHILDREN 166 1829#define STMT_166_INFO {"STMT_SELECT_REVERT_LIST_COPIED_CHILDREN", NULL} 1830#define STMT_166 \ 1831 "SELECT local_relpath, kind " \ 1832 "FROM revert_list " \ 1833 "WHERE (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END)) " \ 1834 " AND op_depth >= ?2 " \ 1835 " AND repos_id IS NOT NULL " \ 1836 "ORDER BY local_relpath " \ 1837 "" 1838 1839#define STMT_DELETE_REVERT_LIST 167 1840#define STMT_167_INFO {"STMT_DELETE_REVERT_LIST", NULL} 1841#define STMT_167 \ 1842 "DELETE FROM revert_list WHERE local_relpath = ?1 " \ 1843 "" 1844 1845#define STMT_SELECT_REVERT_LIST_RECURSIVE 168 1846#define STMT_168_INFO {"STMT_SELECT_REVERT_LIST_RECURSIVE", NULL} 1847#define STMT_168 \ 1848 "SELECT p.local_relpath, n.kind, a.notify, a.kind " \ 1849 "FROM (SELECT DISTINCT local_relpath " \ 1850 " FROM revert_list " \ 1851 " WHERE (local_relpath = ?1 " \ 1852 " OR (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END)))) p " \ 1853 "LEFT JOIN revert_list n ON n.local_relpath=p.local_relpath AND n.actual=0 " \ 1854 "LEFT JOIN revert_list a ON a.local_relpath=p.local_relpath AND a.actual=1 " \ 1855 "ORDER BY p.local_relpath " \ 1856 "" 1857 1858#define STMT_DELETE_REVERT_LIST_RECURSIVE 169 1859#define STMT_169_INFO {"STMT_DELETE_REVERT_LIST_RECURSIVE", NULL} 1860#define STMT_169 \ 1861 "DELETE FROM revert_list " \ 1862 "WHERE (local_relpath = ?1 " \ 1863 " OR (((local_relpath) > (CASE (?1) WHEN '' THEN '' ELSE (?1) || '/' END)) AND ((local_relpath) < CASE (?1) WHEN '' THEN X'FFFF' ELSE (?1) || '0' END))) " \ 1864 "" 1865 1866#define STMT_DROP_REVERT_LIST 170 1867#define STMT_170_INFO {"STMT_DROP_REVERT_LIST", NULL} 1868#define STMT_170 \ 1869 "DROP TABLE IF EXISTS revert_list " \ 1870 "" 1871 1872#define STMT_CREATE_DELETE_LIST 171 1873#define STMT_171_INFO {"STMT_CREATE_DELETE_LIST", NULL} 1874#define STMT_171 \ 1875 "DROP TABLE IF EXISTS delete_list; " \ 1876 "CREATE TEMPORARY TABLE delete_list ( " \ 1877 " local_relpath TEXT PRIMARY KEY NOT NULL UNIQUE " \ 1878 " ) " \ 1879 "" 1880 1881#define STMT_INSERT_DELETE_LIST 172 1882#define STMT_172_INFO {"STMT_INSERT_DELETE_LIST", NULL} 1883#define STMT_172 \ 1884 "INSERT INTO delete_list(local_relpath) " \ 1885 "SELECT ?2 " \ 1886 "UNION ALL " \ 1887 "SELECT local_relpath FROM nodes AS n " \ 1888 "WHERE wc_id = ?1 " \ 1889 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 1890 " AND op_depth >= ?3 " \ 1891 " AND op_depth = (SELECT MAX(s.op_depth) FROM nodes AS s " \ 1892 " WHERE s.wc_id = ?1 " \ 1893 " AND s.local_relpath = n.local_relpath) " \ 1894 " AND presence NOT IN ('base-deleted', 'not-present', 'excluded', 'server-excluded') " \ 1895 " AND file_external IS NULL " \ 1896 "ORDER by local_relpath " \ 1897 "" 1898 1899#define STMT_SELECT_DELETE_LIST 173 1900#define STMT_173_INFO {"STMT_SELECT_DELETE_LIST", NULL} 1901#define STMT_173 \ 1902 "SELECT local_relpath FROM delete_list " \ 1903 "ORDER BY local_relpath " \ 1904 "" 1905 1906#define STMT_FINALIZE_DELETE 174 1907#define STMT_174_INFO {"STMT_FINALIZE_DELETE", NULL} 1908#define STMT_174 \ 1909 "DROP TABLE IF EXISTS delete_list " \ 1910 "" 1911 1912#define STMT_CREATE_UPDATE_MOVE_LIST 175 1913#define STMT_175_INFO {"STMT_CREATE_UPDATE_MOVE_LIST", NULL} 1914#define STMT_175 \ 1915 "DROP TABLE IF EXISTS update_move_list; " \ 1916 "CREATE TEMPORARY TABLE update_move_list ( " \ 1917 " local_relpath TEXT PRIMARY KEY NOT NULL UNIQUE, " \ 1918 " action INTEGER NOT NULL, " \ 1919 " kind TEXT NOT NULL, " \ 1920 " content_state INTEGER NOT NULL, " \ 1921 " prop_state INTEGER NOT NULL " \ 1922 " ) " \ 1923 "" 1924 1925#define STMT_INSERT_UPDATE_MOVE_LIST 176 1926#define STMT_176_INFO {"STMT_INSERT_UPDATE_MOVE_LIST", NULL} 1927#define STMT_176 \ 1928 "INSERT INTO update_move_list(local_relpath, action, kind, content_state, " \ 1929 " prop_state) " \ 1930 "VALUES (?1, ?2, ?3, ?4, ?5) " \ 1931 "" 1932 1933#define STMT_SELECT_UPDATE_MOVE_LIST 177 1934#define STMT_177_INFO {"STMT_SELECT_UPDATE_MOVE_LIST", NULL} 1935#define STMT_177 \ 1936 "SELECT local_relpath, action, kind, content_state, prop_state " \ 1937 "FROM update_move_list " \ 1938 "ORDER BY local_relpath " \ 1939 "" 1940 1941#define STMT_FINALIZE_UPDATE_MOVE 178 1942#define STMT_178_INFO {"STMT_FINALIZE_UPDATE_MOVE", NULL} 1943#define STMT_178 \ 1944 "DROP TABLE IF EXISTS update_move_list " \ 1945 "" 1946 1947#define STMT_MOVE_NOTIFY_TO_REVERT 179 1948#define STMT_179_INFO {"STMT_MOVE_NOTIFY_TO_REVERT", NULL} 1949#define STMT_179 \ 1950 "INSERT INTO revert_list (local_relpath, notify, kind, actual) " \ 1951 " SELECT local_relpath, 2, kind, 1 FROM update_move_list; " \ 1952 "DROP TABLE update_move_list " \ 1953 "" 1954 1955#define STMT_SELECT_MIN_MAX_REVISIONS 180 1956#define STMT_180_INFO {"STMT_SELECT_MIN_MAX_REVISIONS", NULL} 1957#define STMT_180 \ 1958 "SELECT MIN(revision), MAX(revision), " \ 1959 " MIN(changed_revision), MAX(changed_revision) FROM nodes " \ 1960 " WHERE wc_id = ?1 " \ 1961 " AND (local_relpath = ?2 " \ 1962 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1963 " AND presence IN ('normal', 'incomplete') " \ 1964 " AND file_external IS NULL " \ 1965 " AND op_depth = 0 " \ 1966 "" 1967 1968#define STMT_HAS_SPARSE_NODES 181 1969#define STMT_181_INFO {"STMT_HAS_SPARSE_NODES", NULL} 1970#define STMT_181 \ 1971 "SELECT 1 FROM nodes " \ 1972 "WHERE wc_id = ?1 " \ 1973 " AND (local_relpath = ?2 " \ 1974 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1975 " AND op_depth = 0 " \ 1976 " AND (presence IN ('server-excluded', 'excluded') " \ 1977 " OR depth NOT IN ('infinity', 'unknown')) " \ 1978 " AND file_external IS NULL " \ 1979 "LIMIT 1 " \ 1980 "" 1981 1982#define STMT_SUBTREE_HAS_TREE_MODIFICATIONS 182 1983#define STMT_182_INFO {"STMT_SUBTREE_HAS_TREE_MODIFICATIONS", NULL} 1984#define STMT_182 \ 1985 "SELECT 1 FROM nodes " \ 1986 "WHERE wc_id = ?1 " \ 1987 " AND (local_relpath = ?2 " \ 1988 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 1989 " AND op_depth > 0 " \ 1990 "LIMIT 1 " \ 1991 "" 1992 1993#define STMT_SUBTREE_HAS_PROP_MODIFICATIONS 183 1994#define STMT_183_INFO {"STMT_SUBTREE_HAS_PROP_MODIFICATIONS", NULL} 1995#define STMT_183 \ 1996 "SELECT 1 FROM actual_node " \ 1997 "WHERE wc_id = ?1 " \ 1998 " AND (local_relpath = ?2 " \ 1999 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 2000 " AND properties IS NOT NULL " \ 2001 "LIMIT 1 " \ 2002 "" 2003 2004#define STMT_HAS_SWITCHED 184 2005#define STMT_184_INFO {"STMT_HAS_SWITCHED", NULL} 2006#define STMT_184 \ 2007 "SELECT 1 " \ 2008 "FROM nodes " \ 2009 "WHERE wc_id = ?1 " \ 2010 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2011 " AND op_depth = 0 " \ 2012 " AND file_external IS NULL " \ 2013 " AND presence IN ('normal', 'incomplete') " \ 2014 " AND repos_path IS NOT (CASE WHEN (?2) = '' THEN (CASE WHEN (?3) = '' THEN (local_relpath) WHEN (local_relpath) = '' THEN (?3) ELSE (?3) || '/' || (local_relpath) END) WHEN (?3) = '' 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 (?3) WHEN SUBSTR((local_relpath), LENGTH(?2)+1, 1) = '/' THEN (?3) || SUBSTR((local_relpath), LENGTH(?2)+1) END END) " \ 2015 "LIMIT 1 " \ 2016 "" 2017 2018#define STMT_SELECT_MOVED_FROM_RELPATH 185 2019#define STMT_185_INFO {"STMT_SELECT_MOVED_FROM_RELPATH", NULL} 2020#define STMT_185 \ 2021 "SELECT local_relpath, op_depth FROM nodes " \ 2022 "WHERE wc_id = ?1 AND moved_to = ?2 AND op_depth > 0 " \ 2023 "" 2024 2025#define STMT_UPDATE_MOVED_TO_RELPATH 186 2026#define STMT_186_INFO {"STMT_UPDATE_MOVED_TO_RELPATH", NULL} 2027#define STMT_186 \ 2028 "UPDATE nodes SET moved_to = ?4 " \ 2029 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 2030 "" 2031 2032#define STMT_CLEAR_MOVED_TO_RELPATH 187 2033#define STMT_187_INFO {"STMT_CLEAR_MOVED_TO_RELPATH", NULL} 2034#define STMT_187 \ 2035 "UPDATE nodes SET moved_to = NULL " \ 2036 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth = ?3 " \ 2037 "" 2038 2039#define STMT_CLEAR_MOVED_HERE_RECURSIVE 188 2040#define STMT_188_INFO {"STMT_CLEAR_MOVED_HERE_RECURSIVE", NULL} 2041#define STMT_188 \ 2042 "UPDATE nodes SET moved_here = NULL " \ 2043 "WHERE wc_id = ?1 " \ 2044 " 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))) " \ 2045 " AND op_depth = ?3 " \ 2046 "" 2047 2048#define STMT_SELECT_MOVED_HERE_CHILDREN 189 2049#define STMT_189_INFO {"STMT_SELECT_MOVED_HERE_CHILDREN", NULL} 2050#define STMT_189 \ 2051 "SELECT moved_to, local_relpath FROM nodes " \ 2052 "WHERE wc_id = ?1 AND op_depth > 0 " \ 2053 " AND (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2054 "" 2055 2056#define STMT_SELECT_MOVED_FOR_DELETE 190 2057#define STMT_190_INFO {"STMT_SELECT_MOVED_FOR_DELETE", NULL} 2058#define STMT_190 \ 2059 "SELECT local_relpath, moved_to, op_depth, " \ 2060 " (SELECT CASE WHEN r.moved_here THEN r.op_depth END FROM nodes r " \ 2061 " WHERE r.wc_id = ?1 " \ 2062 " AND r.local_relpath = n.local_relpath " \ 2063 " AND r.op_depth < n.op_depth " \ 2064 " ORDER BY r.op_depth DESC LIMIT 1) AS moved_here_op_depth " \ 2065 " FROM nodes n " \ 2066 "WHERE wc_id = ?1 " \ 2067 " 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))) " \ 2068 " AND moved_to IS NOT NULL " \ 2069 " AND op_depth >= ?3 " \ 2070 "" 2071 2072#define STMT_SELECT_MOVED_FROM_FOR_DELETE 191 2073#define STMT_191_INFO {"STMT_SELECT_MOVED_FROM_FOR_DELETE", NULL} 2074#define STMT_191 \ 2075 "SELECT local_relpath, op_depth, " \ 2076 " (SELECT CASE WHEN r.moved_here THEN r.op_depth END FROM nodes r " \ 2077 " WHERE r.wc_id = ?1 " \ 2078 " AND r.local_relpath = n.local_relpath " \ 2079 " AND r.op_depth < n.op_depth " \ 2080 " ORDER BY r.op_depth DESC LIMIT 1) AS moved_here_op_depth " \ 2081 " FROM nodes n " \ 2082 "WHERE wc_id = ?1 AND moved_to = ?2 AND op_depth > 0 " \ 2083 "" 2084 2085#define STMT_UPDATE_MOVED_TO_DESCENDANTS 192 2086#define STMT_192_INFO {"STMT_UPDATE_MOVED_TO_DESCENDANTS", NULL} 2087#define STMT_192 \ 2088 "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) " \ 2089 " WHERE wc_id = ?1 " \ 2090 " AND (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2091 "" 2092 2093#define STMT_CLEAR_MOVED_TO_DESCENDANTS 193 2094#define STMT_193_INFO {"STMT_CLEAR_MOVED_TO_DESCENDANTS", NULL} 2095#define STMT_193 \ 2096 "UPDATE nodes SET moved_to = NULL " \ 2097 " WHERE wc_id = ?1 " \ 2098 " AND (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2099 "" 2100 2101#define STMT_SELECT_MOVED_PAIR3 194 2102#define STMT_194_INFO {"STMT_SELECT_MOVED_PAIR3", NULL} 2103#define STMT_194 \ 2104 "SELECT n.local_relpath, d.moved_to, d.op_depth, n.kind " \ 2105 "FROM nodes n " \ 2106 "JOIN nodes d ON d.wc_id = ?1 AND d.local_relpath = n.local_relpath " \ 2107 " AND d.op_depth = (SELECT MIN(dd.op_depth) " \ 2108 " FROM nodes dd " \ 2109 " WHERE dd.wc_id = ?1 " \ 2110 " AND dd.local_relpath = d.local_relpath " \ 2111 " AND dd.op_depth > ?3) " \ 2112 "WHERE n.wc_id = ?1 AND n.local_relpath = ?2 AND n.op_depth = ?3 " \ 2113 " AND d.moved_to IS NOT NULL " \ 2114 "UNION ALL " \ 2115 "SELECT n.local_relpath, d.moved_to, d.op_depth, n.kind " \ 2116 "FROM nodes n " \ 2117 "JOIN nodes d ON d.wc_id = ?1 AND d.local_relpath = n.local_relpath " \ 2118 " AND d.op_depth = (SELECT MIN(dd.op_depth) " \ 2119 " FROM nodes dd " \ 2120 " WHERE dd.wc_id = ?1 " \ 2121 " AND dd.local_relpath = d.local_relpath " \ 2122 " AND dd.op_depth > ?3) " \ 2123 "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)) " \ 2124 " AND n.op_depth = ?3 " \ 2125 " AND d.moved_to IS NOT NULL " \ 2126 "ORDER BY n.local_relpath " \ 2127 "" 2128 2129#define STMT_SELECT_MOVED_OUTSIDE 195 2130#define STMT_195_INFO {"STMT_SELECT_MOVED_OUTSIDE", NULL} 2131#define STMT_195 \ 2132 "SELECT local_relpath, moved_to, op_depth FROM nodes " \ 2133 "WHERE wc_id = ?1 " \ 2134 " 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))) " \ 2135 " AND op_depth >= ?3 " \ 2136 " AND moved_to IS NOT NULL " \ 2137 " AND NOT (((moved_to) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((moved_to) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2138 "" 2139 2140#define STMT_SELECT_MOVED_DESCENDANTS_SRC 196 2141#define STMT_196_INFO {"STMT_SELECT_MOVED_DESCENDANTS_SRC", NULL} 2142#define STMT_196 \ 2143 "SELECT s.op_depth, n.local_relpath, n.kind, n.repos_path, s.moved_to " \ 2144 "FROM nodes n " \ 2145 "JOIN nodes s ON s.wc_id = n.wc_id AND s.local_relpath = n.local_relpath " \ 2146 " AND s.op_depth = (SELECT MIN(d.op_depth) " \ 2147 " FROM nodes d " \ 2148 " WHERE d.wc_id = ?1 " \ 2149 " AND d.local_relpath = s.local_relpath " \ 2150 " AND d.op_depth > ?3) " \ 2151 "WHERE n.wc_id = ?1 AND n.op_depth = ?3 " \ 2152 " 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))) " \ 2153 " AND s.moved_to IS NOT NULL " \ 2154 "" 2155 2156#define STMT_COMMIT_UPDATE_ORIGIN 197 2157#define STMT_197_INFO {"STMT_COMMIT_UPDATE_ORIGIN", NULL} 2158#define STMT_197 \ 2159 "UPDATE nodes SET repos_id = ?4, " \ 2160 " 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), " \ 2161 " revision = ?6 " \ 2162 "WHERE wc_id = ?1 " \ 2163 " AND (local_relpath = ?2 " \ 2164 " OR (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END))) " \ 2165 " AND op_depth = ?3 " \ 2166 "" 2167 2168#define STMT_HAS_LAYER_BETWEEN 198 2169#define STMT_198_INFO {"STMT_HAS_LAYER_BETWEEN", NULL} 2170#define STMT_198 \ 2171 "SELECT 1 FROM NODES " \ 2172 "WHERE wc_id = ?1 AND local_relpath = ?2 AND op_depth > ?3 AND op_depth < ?4 " \ 2173 "" 2174 2175#define STMT_SELECT_REPOS_PATH_REVISION 199 2176#define STMT_199_INFO {"STMT_SELECT_REPOS_PATH_REVISION", NULL} 2177#define STMT_199 \ 2178 "SELECT local_relpath, repos_path, revision FROM nodes " \ 2179 "WHERE wc_id = ?1 " \ 2180 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2181 " AND op_depth = 0 " \ 2182 "ORDER BY local_relpath " \ 2183 "" 2184 2185#define STMT_SELECT_HAS_NON_FILE_CHILDREN 200 2186#define STMT_200_INFO {"STMT_SELECT_HAS_NON_FILE_CHILDREN", NULL} 2187#define STMT_200 \ 2188 "SELECT 1 FROM nodes " \ 2189 "WHERE wc_id = ?1 AND parent_relpath = ?2 AND op_depth = ?3 AND kind != 'file' " \ 2190 "LIMIT 1 " \ 2191 "" 2192 2193#define STMT_SELECT_HAS_GRANDCHILDREN 201 2194#define STMT_201_INFO {"STMT_SELECT_HAS_GRANDCHILDREN", NULL} 2195#define STMT_201 \ 2196 "SELECT 1 FROM nodes " \ 2197 "WHERE wc_id = ?1 " \ 2198 " AND (((parent_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((parent_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2199 " AND op_depth = ?3 " \ 2200 " AND file_external IS NULL " \ 2201 "LIMIT 1 " \ 2202 "" 2203 2204#define STMT_SELECT_ALL_NODES 202 2205#define STMT_202_INFO {"STMT_SELECT_ALL_NODES", NULL} 2206#define STMT_202 \ 2207 "SELECT op_depth, local_relpath, parent_relpath, file_external FROM nodes " \ 2208 "WHERE wc_id = ?1 " \ 2209 "" 2210 2211#define STMT_UPDATE_IPROP 203 2212#define STMT_203_INFO {"STMT_UPDATE_IPROP", NULL} 2213#define STMT_203 \ 2214 "UPDATE nodes " \ 2215 "SET inherited_props = ?3 " \ 2216 "WHERE (wc_id = ?1 AND local_relpath = ?2 AND op_depth = 0) " \ 2217 "" 2218 2219#define STMT_SELECT_IPROPS_NODE 204 2220#define STMT_204_INFO {"STMT_SELECT_IPROPS_NODE", NULL} 2221#define STMT_204 \ 2222 "SELECT local_relpath, repos_path FROM nodes " \ 2223 "WHERE wc_id = ?1 " \ 2224 " AND local_relpath = ?2 " \ 2225 " AND op_depth = 0 " \ 2226 " AND (inherited_props not null) " \ 2227 "" 2228 2229#define STMT_SELECT_IPROPS_RECURSIVE 205 2230#define STMT_205_INFO {"STMT_SELECT_IPROPS_RECURSIVE", NULL} 2231#define STMT_205 \ 2232 "SELECT local_relpath, repos_path FROM nodes " \ 2233 "WHERE wc_id = ?1 " \ 2234 " AND (((local_relpath) > (CASE (?2) WHEN '' THEN '' ELSE (?2) || '/' END)) AND ((local_relpath) < CASE (?2) WHEN '' THEN X'FFFF' ELSE (?2) || '0' END)) " \ 2235 " AND op_depth = 0 " \ 2236 " AND (inherited_props not null) " \ 2237 "" 2238 2239#define STMT_SELECT_IPROPS_CHILDREN 206 2240#define STMT_206_INFO {"STMT_SELECT_IPROPS_CHILDREN", NULL} 2241#define STMT_206 \ 2242 "SELECT local_relpath, repos_path FROM nodes " \ 2243 "WHERE wc_id = ?1 " \ 2244 " AND parent_relpath = ?2 " \ 2245 " AND op_depth = 0 " \ 2246 " AND (inherited_props not null) " \ 2247 "" 2248 2249#define STMT_HAVE_STAT1_TABLE 207 2250#define STMT_207_INFO {"STMT_HAVE_STAT1_TABLE", NULL} 2251#define STMT_207 \ 2252 "SELECT 1 FROM sqlite_master WHERE name='sqlite_stat1' AND type='table' " \ 2253 "LIMIT 1 " \ 2254 "" 2255 2256#define STMT_SELECT_COPIES_OF_REPOS_RELPATH 208 2257#define STMT_208_INFO {"STMT_SELECT_COPIES_OF_REPOS_RELPATH", NULL} 2258#define STMT_208 \ 2259 "SELECT local_relpath " \ 2260 "FROM nodes n " \ 2261 "WHERE wc_id = ?1 AND repos_path = ?2 AND kind = ?3 " \ 2262 " AND presence = 'normal' " \ 2263 " AND op_depth = (SELECT MAX(op_depth) " \ 2264 " FROM NODES w " \ 2265 " WHERE w.wc_id = ?1 " \ 2266 " AND w.local_relpath = n.local_relpath) " \ 2267 "ORDER BY local_relpath ASC " \ 2268 "" 2269 2270#define STMT_CREATE_SCHEMA 209 2271#define STMT_209_INFO {"STMT_CREATE_SCHEMA", NULL} 2272#define STMT_209 \ 2273 "CREATE TABLE REPOSITORY ( " \ 2274 " id INTEGER PRIMARY KEY AUTOINCREMENT, " \ 2275 " root TEXT UNIQUE NOT NULL, " \ 2276 " uuid TEXT NOT NULL " \ 2277 " ); " \ 2278 "CREATE INDEX I_UUID ON REPOSITORY (uuid); " \ 2279 "CREATE INDEX I_ROOT ON REPOSITORY (root); " \ 2280 "CREATE TABLE WCROOT ( " \ 2281 " id INTEGER PRIMARY KEY AUTOINCREMENT, " \ 2282 " local_abspath TEXT UNIQUE " \ 2283 " ); " \ 2284 "CREATE UNIQUE INDEX I_LOCAL_ABSPATH ON WCROOT (local_abspath); " \ 2285 "CREATE TABLE PRISTINE ( " \ 2286 " checksum TEXT NOT NULL PRIMARY KEY, " \ 2287 " compression INTEGER, " \ 2288 " size INTEGER NOT NULL, " \ 2289 " refcount INTEGER NOT NULL, " \ 2290 " md5_checksum TEXT NOT NULL " \ 2291 " ); " \ 2292 "CREATE INDEX I_PRISTINE_MD5 ON PRISTINE (md5_checksum); " \ 2293 "CREATE TABLE ACTUAL_NODE ( " \ 2294 " wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \ 2295 " local_relpath TEXT NOT NULL, " \ 2296 " parent_relpath TEXT, " \ 2297 " properties BLOB, " \ 2298 " conflict_old TEXT, " \ 2299 " conflict_new TEXT, " \ 2300 " conflict_working TEXT, " \ 2301 " prop_reject TEXT, " \ 2302 " changelist TEXT, " \ 2303 " text_mod TEXT, " \ 2304 " tree_conflict_data TEXT, " \ 2305 " conflict_data BLOB, " \ 2306 " older_checksum TEXT REFERENCES PRISTINE (checksum), " \ 2307 " left_checksum TEXT REFERENCES PRISTINE (checksum), " \ 2308 " right_checksum TEXT REFERENCES PRISTINE (checksum), " \ 2309 " PRIMARY KEY (wc_id, local_relpath) " \ 2310 " ); " \ 2311 "CREATE UNIQUE INDEX I_ACTUAL_PARENT ON ACTUAL_NODE (wc_id, parent_relpath, " \ 2312 " local_relpath); " \ 2313 "CREATE TABLE LOCK ( " \ 2314 " repos_id INTEGER NOT NULL REFERENCES REPOSITORY (id), " \ 2315 " repos_relpath TEXT NOT NULL, " \ 2316 " lock_token TEXT NOT NULL, " \ 2317 " lock_owner TEXT, " \ 2318 " lock_comment TEXT, " \ 2319 " lock_date INTEGER, " \ 2320 " PRIMARY KEY (repos_id, repos_relpath) " \ 2321 " ); " \ 2322 "CREATE TABLE WORK_QUEUE ( " \ 2323 " id INTEGER PRIMARY KEY AUTOINCREMENT, " \ 2324 " work BLOB NOT NULL " \ 2325 " ); " \ 2326 "CREATE TABLE WC_LOCK ( " \ 2327 " wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \ 2328 " local_dir_relpath TEXT NOT NULL, " \ 2329 " locked_levels INTEGER NOT NULL DEFAULT -1, " \ 2330 " PRIMARY KEY (wc_id, local_dir_relpath) " \ 2331 " ); " \ 2332 "CREATE TABLE NODES ( " \ 2333 " wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \ 2334 " local_relpath TEXT NOT NULL, " \ 2335 " op_depth INTEGER NOT NULL, " \ 2336 " parent_relpath TEXT, " \ 2337 " repos_id INTEGER REFERENCES REPOSITORY (id), " \ 2338 " repos_path TEXT, " \ 2339 " revision INTEGER, " \ 2340 " presence TEXT NOT NULL, " \ 2341 " moved_here INTEGER, " \ 2342 " moved_to TEXT, " \ 2343 " kind TEXT NOT NULL, " \ 2344 " properties BLOB, " \ 2345 " depth TEXT, " \ 2346 " checksum TEXT REFERENCES PRISTINE (checksum), " \ 2347 " symlink_target TEXT, " \ 2348 " changed_revision INTEGER, " \ 2349 " changed_date INTEGER, " \ 2350 " changed_author TEXT, " \ 2351 " translated_size INTEGER, " \ 2352 " last_mod_time INTEGER, " \ 2353 " dav_cache BLOB, " \ 2354 " file_external INTEGER, " \ 2355 " inherited_props BLOB, " \ 2356 " PRIMARY KEY (wc_id, local_relpath, op_depth) " \ 2357 " ); " \ 2358 "CREATE UNIQUE INDEX I_NODES_PARENT ON NODES (wc_id, parent_relpath, " \ 2359 " local_relpath, op_depth); " \ 2360 "CREATE UNIQUE INDEX I_NODES_MOVED ON NODES (wc_id, moved_to, op_depth); " \ 2361 "CREATE VIEW NODES_CURRENT AS " \ 2362 " SELECT * FROM nodes AS n " \ 2363 " WHERE op_depth = (SELECT MAX(op_depth) FROM nodes AS n2 " \ 2364 " WHERE n2.wc_id = n.wc_id " \ 2365 " AND n2.local_relpath = n.local_relpath); " \ 2366 "CREATE VIEW NODES_BASE AS " \ 2367 " SELECT * FROM nodes " \ 2368 " WHERE op_depth = 0; " \ 2369 "CREATE TRIGGER nodes_insert_trigger " \ 2370 "AFTER INSERT ON nodes " \ 2371 "WHEN NEW.checksum IS NOT NULL " \ 2372 "BEGIN " \ 2373 " UPDATE pristine SET refcount = refcount + 1 " \ 2374 " WHERE checksum = NEW.checksum; " \ 2375 "END; " \ 2376 "CREATE TRIGGER nodes_delete_trigger " \ 2377 "AFTER DELETE ON nodes " \ 2378 "WHEN OLD.checksum IS NOT NULL " \ 2379 "BEGIN " \ 2380 " UPDATE pristine SET refcount = refcount - 1 " \ 2381 " WHERE checksum = OLD.checksum; " \ 2382 "END; " \ 2383 "CREATE TRIGGER nodes_update_checksum_trigger " \ 2384 "AFTER UPDATE OF checksum ON nodes " \ 2385 "WHEN NEW.checksum IS NOT OLD.checksum " \ 2386 "BEGIN " \ 2387 " UPDATE pristine SET refcount = refcount + 1 " \ 2388 " WHERE checksum = NEW.checksum; " \ 2389 " UPDATE pristine SET refcount = refcount - 1 " \ 2390 " WHERE checksum = OLD.checksum; " \ 2391 "END; " \ 2392 "CREATE TABLE EXTERNALS ( " \ 2393 " wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \ 2394 " local_relpath TEXT NOT NULL, " \ 2395 " parent_relpath TEXT NOT NULL, " \ 2396 " repos_id INTEGER NOT NULL REFERENCES REPOSITORY (id), " \ 2397 " presence TEXT NOT NULL, " \ 2398 " kind TEXT NOT NULL, " \ 2399 " def_local_relpath TEXT NOT NULL, " \ 2400 " def_repos_relpath TEXT NOT NULL, " \ 2401 " def_operational_revision TEXT, " \ 2402 " def_revision TEXT, " \ 2403 " PRIMARY KEY (wc_id, local_relpath) " \ 2404 "); " \ 2405 "CREATE UNIQUE INDEX I_EXTERNALS_DEFINED ON EXTERNALS (wc_id, " \ 2406 " def_local_relpath, " \ 2407 " local_relpath); " \ 2408 "PRAGMA user_version = " \ 2409 APR_STRINGIFY(SVN_WC__VERSION) \ 2410 "; " \ 2411 "" 2412 2413#define STMT_INSTALL_SCHEMA_STATISTICS 210 2414#define STMT_210_INFO {"STMT_INSTALL_SCHEMA_STATISTICS", NULL} 2415#define STMT_210 \ 2416 "ANALYZE sqlite_master; " \ 2417 "DELETE FROM sqlite_stat1 " \ 2418 "WHERE tbl in ('NODES', 'ACTUAL_NODE', 'LOCK', 'WC_LOCK', 'EXTERNALS'); " \ 2419 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2420 " ('NODES', 'sqlite_autoindex_NODES_1', '8000 8000 2 1'); " \ 2421 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2422 " ('NODES', 'I_NODES_PARENT', '8000 8000 10 2 1'); " \ 2423 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2424 " ('NODES', 'I_NODES_MOVED', '8000 8000 1 1'); " \ 2425 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2426 " ('ACTUAL_NODE', 'sqlite_autoindex_ACTUAL_NODE_1', '8000 8000 1'); " \ 2427 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2428 " ('ACTUAL_NODE', 'I_ACTUAL_PARENT', '8000 8000 10 1'); " \ 2429 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2430 " ('LOCK', 'sqlite_autoindex_LOCK_1', '100 100 1'); " \ 2431 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2432 " ('WC_LOCK', 'sqlite_autoindex_WC_LOCK_1', '100 100 1'); " \ 2433 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2434 " ('EXTERNALS','sqlite_autoindex_EXTERNALS_1', '100 100 1'); " \ 2435 "INSERT INTO sqlite_stat1(tbl, idx, stat) VALUES " \ 2436 " ('EXTERNALS','I_EXTERNALS_DEFINED', '100 100 3 1'); " \ 2437 "ANALYZE sqlite_master; " \ 2438 "" 2439 2440#define STMT_UPGRADE_TO_30 211 2441#define STMT_211_INFO {"STMT_UPGRADE_TO_30", NULL} 2442#define STMT_211 \ 2443 "CREATE UNIQUE INDEX IF NOT EXISTS I_NODES_MOVED " \ 2444 "ON NODES (wc_id, moved_to, op_depth); " \ 2445 "CREATE INDEX IF NOT EXISTS I_PRISTINE_MD5 ON PRISTINE (md5_checksum); " \ 2446 "UPDATE nodes SET presence = 'server-excluded' WHERE presence = 'absent'; " \ 2447 "UPDATE nodes SET file_external=1 WHERE file_external IS NOT NULL; " \ 2448 "" 2449 2450#define STMT_UPGRADE_30_SELECT_CONFLICT_SEPARATE 212 2451#define STMT_212_INFO {"STMT_UPGRADE_30_SELECT_CONFLICT_SEPARATE", NULL} 2452#define STMT_212 \ 2453 "SELECT wc_id, local_relpath, " \ 2454 " conflict_old, conflict_working, conflict_new, prop_reject, tree_conflict_data " \ 2455 "FROM actual_node " \ 2456 "WHERE conflict_old IS NOT NULL " \ 2457 " OR conflict_working IS NOT NULL " \ 2458 " OR conflict_new IS NOT NULL " \ 2459 " OR prop_reject IS NOT NULL " \ 2460 " OR tree_conflict_data IS NOT NULL " \ 2461 "ORDER by wc_id, local_relpath " \ 2462 "" 2463 2464#define STMT_UPGRADE_30_SET_CONFLICT 213 2465#define STMT_213_INFO {"STMT_UPGRADE_30_SET_CONFLICT", NULL} 2466#define STMT_213 \ 2467 "UPDATE actual_node SET conflict_data = ?3, conflict_old = NULL, " \ 2468 " conflict_working = NULL, conflict_new = NULL, prop_reject = NULL, " \ 2469 " tree_conflict_data = NULL " \ 2470 "WHERE wc_id = ?1 and local_relpath = ?2 " \ 2471 "" 2472 2473#define STMT_UPGRADE_TO_31 214 2474#define STMT_214_INFO {"STMT_UPGRADE_TO_31", NULL} 2475#define STMT_214 \ 2476 "ALTER TABLE NODES ADD COLUMN inherited_props BLOB; " \ 2477 "DROP INDEX IF EXISTS I_ACTUAL_CHANGELIST; " \ 2478 "DROP INDEX IF EXISTS I_EXTERNALS_PARENT; " \ 2479 "DROP INDEX I_NODES_PARENT; " \ 2480 "CREATE UNIQUE INDEX I_NODES_PARENT ON NODES (wc_id, parent_relpath, " \ 2481 " local_relpath, op_depth); " \ 2482 "DROP INDEX I_ACTUAL_PARENT; " \ 2483 "CREATE UNIQUE INDEX I_ACTUAL_PARENT ON ACTUAL_NODE (wc_id, parent_relpath, " \ 2484 " local_relpath); " \ 2485 "PRAGMA user_version = 31; " \ 2486 "" 2487 2488#define STMT_UPGRADE_31_SELECT_WCROOT_NODES 215 2489#define STMT_215_INFO {"STMT_UPGRADE_31_SELECT_WCROOT_NODES", NULL} 2490#define STMT_215 \ 2491 "SELECT l.wc_id, l.local_relpath FROM nodes as l " \ 2492 "LEFT OUTER JOIN nodes as r " \ 2493 "ON l.wc_id = r.wc_id " \ 2494 " AND r.local_relpath = l.parent_relpath " \ 2495 " AND r.op_depth = 0 " \ 2496 "WHERE l.op_depth = 0 " \ 2497 " AND l.repos_path != '' " \ 2498 " AND ((l.repos_id IS NOT r.repos_id) " \ 2499 " 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))) " \ 2500 "" 2501 2502#define WC_QUERIES_SQL_99 \ 2503 "CREATE TABLE ACTUAL_NODE_BACKUP ( " \ 2504 " wc_id INTEGER NOT NULL, " \ 2505 " local_relpath TEXT NOT NULL, " \ 2506 " parent_relpath TEXT, " \ 2507 " properties BLOB, " \ 2508 " conflict_old TEXT, " \ 2509 " conflict_new TEXT, " \ 2510 " conflict_working TEXT, " \ 2511 " prop_reject TEXT, " \ 2512 " changelist TEXT, " \ 2513 " text_mod TEXT " \ 2514 " ); " \ 2515 "INSERT INTO ACTUAL_NODE_BACKUP SELECT " \ 2516 " wc_id, local_relpath, parent_relpath, properties, conflict_old, " \ 2517 " conflict_new, conflict_working, prop_reject, changelist, text_mod " \ 2518 "FROM ACTUAL_NODE; " \ 2519 "DROP TABLE ACTUAL_NODE; " \ 2520 "CREATE TABLE ACTUAL_NODE ( " \ 2521 " wc_id INTEGER NOT NULL REFERENCES WCROOT (id), " \ 2522 " local_relpath TEXT NOT NULL, " \ 2523 " parent_relpath TEXT, " \ 2524 " properties BLOB, " \ 2525 " conflict_old TEXT, " \ 2526 " conflict_new TEXT, " \ 2527 " conflict_working TEXT, " \ 2528 " prop_reject TEXT, " \ 2529 " changelist TEXT, " \ 2530 " text_mod TEXT, " \ 2531 " PRIMARY KEY (wc_id, local_relpath) " \ 2532 " ); " \ 2533 "CREATE UNIQUE INDEX I_ACTUAL_PARENT ON ACTUAL_NODE (wc_id, parent_relpath, " \ 2534 " local_relpath); " \ 2535 "INSERT INTO ACTUAL_NODE SELECT " \ 2536 " wc_id, local_relpath, parent_relpath, properties, conflict_old, " \ 2537 " conflict_new, conflict_working, prop_reject, changelist, text_mod " \ 2538 "FROM ACTUAL_NODE_BACKUP; " \ 2539 "DROP TABLE ACTUAL_NODE_BACKUP; " \ 2540 "" 2541 2542#define STMT_VERIFICATION_TRIGGERS 216 2543#define STMT_216_INFO {"STMT_VERIFICATION_TRIGGERS", NULL} 2544#define STMT_216 \ 2545 "CREATE TEMPORARY TRIGGER no_repository_updates BEFORE UPDATE ON repository " \ 2546 "BEGIN " \ 2547 " SELECT RAISE(FAIL, 'Updates to REPOSITORY are not allowed.'); " \ 2548 "END; " \ 2549 "CREATE TEMPORARY TRIGGER validation_01 BEFORE INSERT ON nodes " \ 2550 "WHEN NOT ((new.local_relpath = '' AND new.parent_relpath IS NULL) " \ 2551 " OR (relpath_depth(new.local_relpath) " \ 2552 " = relpath_depth(new.parent_relpath) + 1)) " \ 2553 "BEGIN " \ 2554 " SELECT RAISE(FAIL, 'WC DB validity check 01 failed'); " \ 2555 "END; " \ 2556 "CREATE TEMPORARY TRIGGER validation_02 BEFORE INSERT ON nodes " \ 2557 "WHEN NOT new.op_depth <= relpath_depth(new.local_relpath) " \ 2558 "BEGIN " \ 2559 " SELECT RAISE(FAIL, 'WC DB validity check 02 failed'); " \ 2560 "END; " \ 2561 "CREATE TEMPORARY TRIGGER validation_03 BEFORE INSERT ON nodes " \ 2562 "WHEN NOT ( " \ 2563 " (new.op_depth = relpath_depth(new.local_relpath)) " \ 2564 " OR " \ 2565 " (EXISTS (SELECT 1 FROM nodes " \ 2566 " WHERE wc_id = new.wc_id AND op_depth = new.op_depth " \ 2567 " AND local_relpath = new.parent_relpath)) " \ 2568 " ) " \ 2569 " AND NOT (new.file_external IS NOT NULL AND new.op_depth = 0) " \ 2570 "BEGIN " \ 2571 " SELECT RAISE(FAIL, 'WC DB validity check 03 failed'); " \ 2572 "END; " \ 2573 "CREATE TEMPORARY TRIGGER validation_04 BEFORE INSERT ON actual_node " \ 2574 "WHEN NOT (new.local_relpath = '' " \ 2575 " OR EXISTS (SELECT 1 FROM nodes " \ 2576 " WHERE wc_id = new.wc_id " \ 2577 " AND local_relpath = new.parent_relpath)) " \ 2578 "BEGIN " \ 2579 " SELECT RAISE(FAIL, 'WC DB validity check 04 failed'); " \ 2580 "END; " \ 2581 "" 2582 2583#define STMT_STATIC_VERIFY 217 2584#define STMT_217_INFO {"STMT_STATIC_VERIFY", NULL} 2585#define STMT_217 \ 2586 "SELECT local_relpath, op_depth, 1, 'Invalid parent relpath set in NODES' " \ 2587 "FROM nodes n WHERE local_relpath != '' " \ 2588 " AND (parent_relpath IS NULL " \ 2589 " 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)) " \ 2590 " OR relpath_depth(local_relpath) != relpath_depth(parent_relpath)+1) " \ 2591 "UNION ALL " \ 2592 "SELECT local_relpath, -1, 2, 'Invalid parent relpath set in ACTUAL' " \ 2593 "FROM actual_node a WHERE local_relpath != '' " \ 2594 " AND (parent_relpath IS NULL " \ 2595 " 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)) " \ 2596 " OR relpath_depth(local_relpath) != relpath_depth(parent_relpath)+1) " \ 2597 "UNION ALL " \ 2598 "SELECT local_relpath, -1, 10, 'No ancestor in ACTUAL' " \ 2599 "FROM actual_node a WHERE local_relpath != '' " \ 2600 " AND NOT EXISTS(SELECT 1 from nodes i " \ 2601 " WHERE i.wc_id=a.wc_id " \ 2602 " AND i.local_relpath=a.parent_relpath) " \ 2603 " AND NOT EXISTS(SELECT 1 from nodes i " \ 2604 " WHERE i.wc_id=a.wc_id " \ 2605 " AND i.local_relpath=a.local_relpath) " \ 2606 "UNION ALL " \ 2607 "SELECT a.local_relpath, -1, 11, 'Bad or Unneeded actual data' " \ 2608 "FROM actual_node a " \ 2609 "LEFT JOIN nodes n on n.wc_id = a.wc_id AND n.local_relpath = a.local_relpath " \ 2610 " AND n.op_depth = (SELECT MAX(op_depth) from nodes i " \ 2611 " WHERE i.wc_id=a.wc_id AND i.local_relpath=a.local_relpath) " \ 2612 "WHERE (a.properties IS NOT NULL " \ 2613 " AND (n.presence IS NULL " \ 2614 " OR n.presence NOT IN ('normal', 'incomplete'))) " \ 2615 " OR (a.changelist IS NOT NULL AND (n.kind IS NOT NULL AND n.kind != 'file')) " \ 2616 " OR (a.conflict_data IS NULL AND a.properties IS NULL AND a.changelist IS NULL) " \ 2617 " AND NOT EXISTS(SELECT 1 from nodes i " \ 2618 " WHERE i.wc_id=a.wc_id " \ 2619 " AND i.local_relpath=a.parent_relpath) " \ 2620 "UNION ALL " \ 2621 "SELECT local_relpath, op_depth, 20, 'No ancestor in NODES' " \ 2622 "FROM nodes n WHERE local_relpath != '' " \ 2623 " AND file_external IS NULL " \ 2624 " AND NOT EXISTS(SELECT 1 from nodes i " \ 2625 " WHERE i.wc_id=n.wc_id " \ 2626 " AND i.local_relpath=n.parent_relpath " \ 2627 " AND i.op_depth <= n.op_depth) " \ 2628 "UNION ALL " \ 2629 "SELECT local_relpath, op_depth, 21, 'Unneeded node data' " \ 2630 "FROM nodes " \ 2631 "WHERE presence NOT IN ('normal', 'incomplete') " \ 2632 "AND (properties IS NOT NULL " \ 2633 " OR checksum IS NOT NULL " \ 2634 " OR depth IS NOT NULL " \ 2635 " OR symlink_target IS NOT NULL " \ 2636 " OR changed_revision IS NOT NULL " \ 2637 " OR (changed_date IS NOT NULL AND changed_date != 0) " \ 2638 " OR changed_author IS NOT NULL " \ 2639 " OR translated_size IS NOT NULL " \ 2640 " OR last_mod_time IS NOT NULL " \ 2641 " OR dav_cache IS NOT NULL " \ 2642 " OR file_external IS NOT NULL " \ 2643 " OR inherited_props IS NOT NULL) " \ 2644 "UNION ALL " \ 2645 "SELECT local_relpath, op_depth, 22, 'Unneeded base-deleted node data' " \ 2646 "FROM nodes " \ 2647 "WHERE presence IN ('base-deleted') " \ 2648 "AND (repos_id IS NOT NULL " \ 2649 " OR repos_path IS NOT NULL " \ 2650 " OR revision IS NOT NULL) " \ 2651 "UNION ALL " \ 2652 "SELECT local_relpath, op_depth, 23, 'Kind specific data invalid on normal' " \ 2653 "FROM nodes " \ 2654 "WHERE presence IN ('normal', 'incomplete') " \ 2655 "AND (kind IS NULL " \ 2656 " OR (repos_path IS NULL " \ 2657 " AND (properties IS NOT NULL " \ 2658 " OR changed_revision IS NOT NULL " \ 2659 " OR changed_author IS NOT NULL " \ 2660 " OR (changed_date IS NOT NULL AND changed_date != 0))) " \ 2661 " OR (CASE WHEN kind = 'file' AND repos_path IS NOT NULL " \ 2662 " THEN checksum IS NULL " \ 2663 " ELSE checksum IS NOT NULL END) " \ 2664 " OR (CASE WHEN kind = 'dir' THEN depth IS NULL " \ 2665 " ELSE depth IS NOT NULL END) " \ 2666 " OR (CASE WHEN kind = 'symlink' THEN symlink_target IS NULL " \ 2667 " ELSE symlink_target IS NOT NULL END)) " \ 2668 "UNION ALL " \ 2669 "SELECT local_relpath, op_depth, 24, 'Invalid op-depth for local add' " \ 2670 "FROM nodes " \ 2671 "WHERE presence IN ('normal', 'incomplete') " \ 2672 " AND repos_path IS NULL " \ 2673 " AND op_depth != relpath_depth(local_relpath) " \ 2674 "UNION ALL " \ 2675 "SELECT local_relpath, op_depth, 25, 'Node missing op-depth ancestor' " \ 2676 "FROM nodes n " \ 2677 "WHERE op_depth < relpath_depth(local_relpath) " \ 2678 " AND file_external IS NULL " \ 2679 " AND NOT EXISTS(SELECT 1 FROM nodes p " \ 2680 " WHERE p.wc_id=n.wc_id AND p.local_relpath=n.parent_relpath " \ 2681 " AND p.op_depth=n.op_depth " \ 2682 " AND (p.presence IN ('normal', 'incomplete') " \ 2683 " OR (p.presence IN ('base-deleted', 'not-present') " \ 2684 " AND n.presence = 'base-deleted'))) " \ 2685 "UNION ALL " \ 2686 "SELECT n.local_relpath, n.op_depth, 26, 'Copied descendant mismatch' " \ 2687 "FROM nodes n " \ 2688 "JOIN nodes p " \ 2689 " ON p.wc_id=n.wc_id AND p.local_relpath=n.parent_relpath " \ 2690 " AND n.op_depth=p.op_depth " \ 2691 "WHERE n.op_depth > 0 AND n.presence IN ('normal', 'incomplete') " \ 2692 " AND (n.repos_id != p.repos_id " \ 2693 " OR n.repos_path != " \ 2694 " (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) " \ 2695 " OR n.revision != p.revision " \ 2696 " OR p.kind != 'dir' " \ 2697 " OR n.moved_here IS NOT p.moved_here) " \ 2698 "UNION ALL " \ 2699 "SELECT n.local_relpath, n.op_depth, 27, 'Invalid op-root presence' " \ 2700 "FROM nodes n " \ 2701 "WHERE n.op_depth = relpath_depth(local_relpath) " \ 2702 " AND presence NOT IN ('normal', 'incomplete', 'base-deleted') " \ 2703 "UNION ALL " \ 2704 "SELECT n.local_relpath, s.op_depth, 28, 'Incomplete shadowing' " \ 2705 "FROM nodes n " \ 2706 "JOIN nodes s ON s.wc_id=n.wc_id AND s.local_relpath=n.local_relpath " \ 2707 " AND s.op_depth = relpath_depth(s.local_relpath) " \ 2708 " AND s.op_depth = (SELECT MIN(op_depth) FROM nodes d " \ 2709 " WHERE d.wc_id=s.wc_id AND d.local_relpath=s.local_relpath " \ 2710 " AND d.op_depth > n.op_depth) " \ 2711 "WHERE n.presence IN ('normal', 'incomplete') " \ 2712 " AND EXISTS(SELECT 1 " \ 2713 " FROM nodes dn " \ 2714 " WHERE dn.wc_id=n.wc_id AND dn.op_depth=n.op_depth " \ 2715 " AND dn.presence IN ('normal', 'incomplete') " \ 2716 " 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)) " \ 2717 " AND dn.file_external IS NULL " \ 2718 " AND NOT EXISTS(SELECT 1 " \ 2719 " FROM nodes ds " \ 2720 " WHERE ds.wc_id=n.wc_id AND ds.op_depth=s.op_depth " \ 2721 " AND ds.local_relpath=dn.local_relpath)) " \ 2722 "UNION ALL " \ 2723 "SELECT s.local_relpath, s.op_depth, 29, 'Invalid base-delete' " \ 2724 "FROM nodes s " \ 2725 "LEFT JOIN nodes n ON n.wc_id=s.wc_id AND n.local_relpath=s.local_relpath " \ 2726 " AND n.op_depth = (SELECT MAX(op_depth) FROM nodes d " \ 2727 " WHERE d.wc_id=s.wc_id AND d.local_relpath=s.local_relpath " \ 2728 " AND d.op_depth < s.op_depth) " \ 2729 "WHERE s.presence = 'base-deleted' " \ 2730 " AND (n.presence IS NULL " \ 2731 " OR n.presence NOT IN ('normal', 'incomplete') " \ 2732 " ) " \ 2733 "UNION ALL " \ 2734 "SELECT n.local_relpath, n.op_depth, 30, 'Invalid data for BASE' " \ 2735 "FROM nodes n " \ 2736 "WHERE n.op_depth = 0 " \ 2737 " AND (n.moved_to IS NOT NULL " \ 2738 " OR n.moved_here IS NOT NULL) " \ 2739 "UNION ALL " \ 2740 "SELECT d.local_relpath, d.op_depth, 60, 'Moved here without origin' " \ 2741 "FROM nodes d " \ 2742 "WHERE d.op_depth = relpath_depth(d.local_relpath) " \ 2743 " AND d.moved_here IS NOT NULL " \ 2744 " AND NOT EXISTS(SELECT 1 FROM nodes s " \ 2745 " WHERE s.wc_id = d.wc_id AND s.moved_to = d.local_relpath) " \ 2746 "UNION ALL " \ 2747 "SELECT s.local_relpath, s.op_depth, 61, 'Moved to without target' " \ 2748 "FROM nodes s " \ 2749 "WHERE s.moved_to IS NOT NULL " \ 2750 " AND NOT EXISTS(SELECT 1 FROM nodes d " \ 2751 " WHERE d.wc_id = s.wc_id AND d.local_relpath = s.moved_to " \ 2752 " AND d.op_depth = relpath_depth(d.local_relpath) " \ 2753 " AND d.moved_here =1 AND d.repos_path IS NOT NULL) " \ 2754 "" 2755 2756#define WC_QUERIES_SQL_DECLARE_STATEMENTS(varname) \ 2757 static const char * const varname[] = { \ 2758 STMT_0, \ 2759 STMT_1, \ 2760 STMT_2, \ 2761 STMT_3, \ 2762 STMT_4, \ 2763 STMT_5, \ 2764 STMT_6, \ 2765 STMT_7, \ 2766 STMT_8, \ 2767 STMT_9, \ 2768 STMT_10, \ 2769 STMT_11, \ 2770 STMT_12, \ 2771 STMT_13, \ 2772 STMT_14, \ 2773 STMT_15, \ 2774 STMT_16, \ 2775 STMT_17, \ 2776 STMT_18, \ 2777 STMT_19, \ 2778 STMT_20, \ 2779 STMT_21, \ 2780 STMT_22, \ 2781 STMT_23, \ 2782 STMT_24, \ 2783 STMT_25, \ 2784 STMT_26, \ 2785 STMT_27, \ 2786 STMT_28, \ 2787 STMT_29, \ 2788 STMT_30, \ 2789 STMT_31, \ 2790 STMT_32, \ 2791 STMT_33, \ 2792 STMT_34, \ 2793 STMT_35, \ 2794 STMT_36, \ 2795 STMT_37, \ 2796 STMT_38, \ 2797 STMT_39, \ 2798 STMT_40, \ 2799 STMT_41, \ 2800 STMT_42, \ 2801 STMT_43, \ 2802 STMT_44, \ 2803 STMT_45, \ 2804 STMT_46, \ 2805 STMT_47, \ 2806 STMT_48, \ 2807 STMT_49, \ 2808 STMT_50, \ 2809 STMT_51, \ 2810 STMT_52, \ 2811 STMT_53, \ 2812 STMT_54, \ 2813 STMT_55, \ 2814 STMT_56, \ 2815 STMT_57, \ 2816 STMT_58, \ 2817 STMT_59, \ 2818 STMT_60, \ 2819 STMT_61, \ 2820 STMT_62, \ 2821 STMT_63, \ 2822 STMT_64, \ 2823 STMT_65, \ 2824 STMT_66, \ 2825 STMT_67, \ 2826 STMT_68, \ 2827 STMT_69, \ 2828 STMT_70, \ 2829 STMT_71, \ 2830 STMT_72, \ 2831 STMT_73, \ 2832 STMT_74, \ 2833 STMT_75, \ 2834 STMT_76, \ 2835 STMT_77, \ 2836 STMT_78, \ 2837 STMT_79, \ 2838 STMT_80, \ 2839 STMT_81, \ 2840 STMT_82, \ 2841 STMT_83, \ 2842 STMT_84, \ 2843 STMT_85, \ 2844 STMT_86, \ 2845 STMT_87, \ 2846 STMT_88, \ 2847 STMT_89, \ 2848 STMT_90, \ 2849 STMT_91, \ 2850 STMT_92, \ 2851 STMT_93, \ 2852 STMT_94, \ 2853 STMT_95, \ 2854 STMT_96, \ 2855 STMT_97, \ 2856 STMT_98, \ 2857 STMT_99, \ 2858 STMT_100, \ 2859 STMT_101, \ 2860 STMT_102, \ 2861 STMT_103, \ 2862 STMT_104, \ 2863 STMT_105, \ 2864 STMT_106, \ 2865 STMT_107, \ 2866 STMT_108, \ 2867 STMT_109, \ 2868 STMT_110, \ 2869 STMT_111, \ 2870 STMT_112, \ 2871 STMT_113, \ 2872 STMT_114, \ 2873 STMT_115, \ 2874 STMT_116, \ 2875 STMT_117, \ 2876 STMT_118, \ 2877 STMT_119, \ 2878 STMT_120, \ 2879 STMT_121, \ 2880 STMT_122, \ 2881 STMT_123, \ 2882 STMT_124, \ 2883 STMT_125, \ 2884 STMT_126, \ 2885 STMT_127, \ 2886 STMT_128, \ 2887 STMT_129, \ 2888 STMT_130, \ 2889 STMT_131, \ 2890 STMT_132, \ 2891 STMT_133, \ 2892 STMT_134, \ 2893 STMT_135, \ 2894 STMT_136, \ 2895 STMT_137, \ 2896 STMT_138, \ 2897 STMT_139, \ 2898 STMT_140, \ 2899 STMT_141, \ 2900 STMT_142, \ 2901 STMT_143, \ 2902 STMT_144, \ 2903 STMT_145, \ 2904 STMT_146, \ 2905 STMT_147, \ 2906 STMT_148, \ 2907 STMT_149, \ 2908 STMT_150, \ 2909 STMT_151, \ 2910 STMT_152, \ 2911 STMT_153, \ 2912 STMT_154, \ 2913 STMT_155, \ 2914 STMT_156, \ 2915 STMT_157, \ 2916 STMT_158, \ 2917 STMT_159, \ 2918 STMT_160, \ 2919 STMT_161, \ 2920 STMT_162, \ 2921 STMT_163, \ 2922 STMT_164, \ 2923 STMT_165, \ 2924 STMT_166, \ 2925 STMT_167, \ 2926 STMT_168, \ 2927 STMT_169, \ 2928 STMT_170, \ 2929 STMT_171, \ 2930 STMT_172, \ 2931 STMT_173, \ 2932 STMT_174, \ 2933 STMT_175, \ 2934 STMT_176, \ 2935 STMT_177, \ 2936 STMT_178, \ 2937 STMT_179, \ 2938 STMT_180, \ 2939 STMT_181, \ 2940 STMT_182, \ 2941 STMT_183, \ 2942 STMT_184, \ 2943 STMT_185, \ 2944 STMT_186, \ 2945 STMT_187, \ 2946 STMT_188, \ 2947 STMT_189, \ 2948 STMT_190, \ 2949 STMT_191, \ 2950 STMT_192, \ 2951 STMT_193, \ 2952 STMT_194, \ 2953 STMT_195, \ 2954 STMT_196, \ 2955 STMT_197, \ 2956 STMT_198, \ 2957 STMT_199, \ 2958 STMT_200, \ 2959 STMT_201, \ 2960 STMT_202, \ 2961 STMT_203, \ 2962 STMT_204, \ 2963 STMT_205, \ 2964 STMT_206, \ 2965 STMT_207, \ 2966 STMT_208, \ 2967 STMT_209, \ 2968 STMT_210, \ 2969 STMT_211, \ 2970 STMT_212, \ 2971 STMT_213, \ 2972 STMT_214, \ 2973 STMT_215, \ 2974 STMT_216, \ 2975 STMT_217, \ 2976 NULL \ 2977 } 2978 2979#define WC_QUERIES_SQL_DECLARE_STATEMENT_INFO(varname) \ 2980 static const char * const varname[][2] = { \ 2981 STMT_0_INFO, \ 2982 STMT_1_INFO, \ 2983 STMT_2_INFO, \ 2984 STMT_3_INFO, \ 2985 STMT_4_INFO, \ 2986 STMT_5_INFO, \ 2987 STMT_6_INFO, \ 2988 STMT_7_INFO, \ 2989 STMT_8_INFO, \ 2990 STMT_9_INFO, \ 2991 STMT_10_INFO, \ 2992 STMT_11_INFO, \ 2993 STMT_12_INFO, \ 2994 STMT_13_INFO, \ 2995 STMT_14_INFO, \ 2996 STMT_15_INFO, \ 2997 STMT_16_INFO, \ 2998 STMT_17_INFO, \ 2999 STMT_18_INFO, \ 3000 STMT_19_INFO, \ 3001 STMT_20_INFO, \ 3002 STMT_21_INFO, \ 3003 STMT_22_INFO, \ 3004 STMT_23_INFO, \ 3005 STMT_24_INFO, \ 3006 STMT_25_INFO, \ 3007 STMT_26_INFO, \ 3008 STMT_27_INFO, \ 3009 STMT_28_INFO, \ 3010 STMT_29_INFO, \ 3011 STMT_30_INFO, \ 3012 STMT_31_INFO, \ 3013 STMT_32_INFO, \ 3014 STMT_33_INFO, \ 3015 STMT_34_INFO, \ 3016 STMT_35_INFO, \ 3017 STMT_36_INFO, \ 3018 STMT_37_INFO, \ 3019 STMT_38_INFO, \ 3020 STMT_39_INFO, \ 3021 STMT_40_INFO, \ 3022 STMT_41_INFO, \ 3023 STMT_42_INFO, \ 3024 STMT_43_INFO, \ 3025 STMT_44_INFO, \ 3026 STMT_45_INFO, \ 3027 STMT_46_INFO, \ 3028 STMT_47_INFO, \ 3029 STMT_48_INFO, \ 3030 STMT_49_INFO, \ 3031 STMT_50_INFO, \ 3032 STMT_51_INFO, \ 3033 STMT_52_INFO, \ 3034 STMT_53_INFO, \ 3035 STMT_54_INFO, \ 3036 STMT_55_INFO, \ 3037 STMT_56_INFO, \ 3038 STMT_57_INFO, \ 3039 STMT_58_INFO, \ 3040 STMT_59_INFO, \ 3041 STMT_60_INFO, \ 3042 STMT_61_INFO, \ 3043 STMT_62_INFO, \ 3044 STMT_63_INFO, \ 3045 STMT_64_INFO, \ 3046 STMT_65_INFO, \ 3047 STMT_66_INFO, \ 3048 STMT_67_INFO, \ 3049 STMT_68_INFO, \ 3050 STMT_69_INFO, \ 3051 STMT_70_INFO, \ 3052 STMT_71_INFO, \ 3053 STMT_72_INFO, \ 3054 STMT_73_INFO, \ 3055 STMT_74_INFO, \ 3056 STMT_75_INFO, \ 3057 STMT_76_INFO, \ 3058 STMT_77_INFO, \ 3059 STMT_78_INFO, \ 3060 STMT_79_INFO, \ 3061 STMT_80_INFO, \ 3062 STMT_81_INFO, \ 3063 STMT_82_INFO, \ 3064 STMT_83_INFO, \ 3065 STMT_84_INFO, \ 3066 STMT_85_INFO, \ 3067 STMT_86_INFO, \ 3068 STMT_87_INFO, \ 3069 STMT_88_INFO, \ 3070 STMT_89_INFO, \ 3071 STMT_90_INFO, \ 3072 STMT_91_INFO, \ 3073 STMT_92_INFO, \ 3074 STMT_93_INFO, \ 3075 STMT_94_INFO, \ 3076 STMT_95_INFO, \ 3077 STMT_96_INFO, \ 3078 STMT_97_INFO, \ 3079 STMT_98_INFO, \ 3080 STMT_99_INFO, \ 3081 STMT_100_INFO, \ 3082 STMT_101_INFO, \ 3083 STMT_102_INFO, \ 3084 STMT_103_INFO, \ 3085 STMT_104_INFO, \ 3086 STMT_105_INFO, \ 3087 STMT_106_INFO, \ 3088 STMT_107_INFO, \ 3089 STMT_108_INFO, \ 3090 STMT_109_INFO, \ 3091 STMT_110_INFO, \ 3092 STMT_111_INFO, \ 3093 STMT_112_INFO, \ 3094 STMT_113_INFO, \ 3095 STMT_114_INFO, \ 3096 STMT_115_INFO, \ 3097 STMT_116_INFO, \ 3098 STMT_117_INFO, \ 3099 STMT_118_INFO, \ 3100 STMT_119_INFO, \ 3101 STMT_120_INFO, \ 3102 STMT_121_INFO, \ 3103 STMT_122_INFO, \ 3104 STMT_123_INFO, \ 3105 STMT_124_INFO, \ 3106 STMT_125_INFO, \ 3107 STMT_126_INFO, \ 3108 STMT_127_INFO, \ 3109 STMT_128_INFO, \ 3110 STMT_129_INFO, \ 3111 STMT_130_INFO, \ 3112 STMT_131_INFO, \ 3113 STMT_132_INFO, \ 3114 STMT_133_INFO, \ 3115 STMT_134_INFO, \ 3116 STMT_135_INFO, \ 3117 STMT_136_INFO, \ 3118 STMT_137_INFO, \ 3119 STMT_138_INFO, \ 3120 STMT_139_INFO, \ 3121 STMT_140_INFO, \ 3122 STMT_141_INFO, \ 3123 STMT_142_INFO, \ 3124 STMT_143_INFO, \ 3125 STMT_144_INFO, \ 3126 STMT_145_INFO, \ 3127 STMT_146_INFO, \ 3128 STMT_147_INFO, \ 3129 STMT_148_INFO, \ 3130 STMT_149_INFO, \ 3131 STMT_150_INFO, \ 3132 STMT_151_INFO, \ 3133 STMT_152_INFO, \ 3134 STMT_153_INFO, \ 3135 STMT_154_INFO, \ 3136 STMT_155_INFO, \ 3137 STMT_156_INFO, \ 3138 STMT_157_INFO, \ 3139 STMT_158_INFO, \ 3140 STMT_159_INFO, \ 3141 STMT_160_INFO, \ 3142 STMT_161_INFO, \ 3143 STMT_162_INFO, \ 3144 STMT_163_INFO, \ 3145 STMT_164_INFO, \ 3146 STMT_165_INFO, \ 3147 STMT_166_INFO, \ 3148 STMT_167_INFO, \ 3149 STMT_168_INFO, \ 3150 STMT_169_INFO, \ 3151 STMT_170_INFO, \ 3152 STMT_171_INFO, \ 3153 STMT_172_INFO, \ 3154 STMT_173_INFO, \ 3155 STMT_174_INFO, \ 3156 STMT_175_INFO, \ 3157 STMT_176_INFO, \ 3158 STMT_177_INFO, \ 3159 STMT_178_INFO, \ 3160 STMT_179_INFO, \ 3161 STMT_180_INFO, \ 3162 STMT_181_INFO, \ 3163 STMT_182_INFO, \ 3164 STMT_183_INFO, \ 3165 STMT_184_INFO, \ 3166 STMT_185_INFO, \ 3167 STMT_186_INFO, \ 3168 STMT_187_INFO, \ 3169 STMT_188_INFO, \ 3170 STMT_189_INFO, \ 3171 STMT_190_INFO, \ 3172 STMT_191_INFO, \ 3173 STMT_192_INFO, \ 3174 STMT_193_INFO, \ 3175 STMT_194_INFO, \ 3176 STMT_195_INFO, \ 3177 STMT_196_INFO, \ 3178 STMT_197_INFO, \ 3179 STMT_198_INFO, \ 3180 STMT_199_INFO, \ 3181 STMT_200_INFO, \ 3182 STMT_201_INFO, \ 3183 STMT_202_INFO, \ 3184 STMT_203_INFO, \ 3185 STMT_204_INFO, \ 3186 STMT_205_INFO, \ 3187 STMT_206_INFO, \ 3188 STMT_207_INFO, \ 3189 STMT_208_INFO, \ 3190 STMT_209_INFO, \ 3191 STMT_210_INFO, \ 3192 STMT_211_INFO, \ 3193 STMT_212_INFO, \ 3194 STMT_213_INFO, \ 3195 STMT_214_INFO, \ 3196 STMT_215_INFO, \ 3197 STMT_216_INFO, \ 3198 STMT_217_INFO, \ 3199 {NULL, NULL} \ 3200 } 3201