X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=localdb.cc;h=17337f01b028d02776df674717f19d0bb1a0190a;hb=722040937d7709a7b976bf57b045dac6d703c893;hp=98b2b099de8e1e231aa543b29d91c6b7a96b57a6;hpb=0347920b621a8feaf16d5f48f33bbe1b238fc896;p=cumulus.git diff --git a/localdb.cc b/localdb.cc index 98b2b09..17337f0 100644 --- a/localdb.cc +++ b/localdb.cc @@ -46,7 +46,7 @@ void LocalDb::ReportError(int rc) } void LocalDb::Open(const char *path, const char *snapshot_name, - const char *snapshot_scheme) + const char *snapshot_scheme, double intent) { int rc; @@ -69,8 +69,8 @@ void LocalDb::Open(const char *path, const char *snapshot_name, /* Insert this snapshot into the database, and determine the integer key * which will be used to identify it. */ sqlite3_stmt *stmt = Prepare("insert into " - "snapshots(name, scheme, timestamp) " - "values (?, ?, julianday('now'))"); + "snapshots(name, scheme, timestamp, intent) " + "values (?, ?, julianday('now'), ?)"); sqlite3_bind_text(stmt, 1, snapshot_name, strlen(snapshot_name), SQLITE_TRANSIENT); if (snapshot_scheme == NULL) @@ -78,6 +78,7 @@ void LocalDb::Open(const char *path, const char *snapshot_name, else sqlite3_bind_text(stmt, 2, snapshot_scheme, strlen(snapshot_scheme), SQLITE_TRANSIENT); + sqlite3_bind_double(stmt, 3, intent); rc = sqlite3_step(stmt); if (rc != SQLITE_DONE) { @@ -257,6 +258,7 @@ ObjectReference LocalDb::FindObject(const string &checksum, int64_t size) } else if (rc == SQLITE_ROW) { ref = ObjectReference(IdToSegment(sqlite3_column_int64(stmt, 0)), (const char *)sqlite3_column_text(stmt, 1)); + ref.set_range(0, size); } else { fprintf(stderr, "Could not execute SELECT statement!\n"); ReportError(rc); @@ -304,6 +306,11 @@ bool LocalDb::IsAvailable(const ObjectReference &ref) sqlite3_stmt *stmt; bool found = false; + // Special objects (such as the zero object) aren't stored in segments, and + // so are always available. + if (!ref.is_normal()) + return true; + stmt = Prepare("select count(*) from block_index " "where segmentid = ? and object = ? and expired is null"); sqlite3_bind_int64(stmt, 1, SegmentToId(ref.get_segment())); @@ -331,26 +338,14 @@ void LocalDb::UseObject(const ObjectReference& ref) int rc; sqlite3_stmt *stmt; - stmt = Prepare("insert or ignore into snapshot_contents " - "select blockid, ? as snapshotid from block_index " - "where segmentid = ? and object = ?"); - sqlite3_bind_int64(stmt, 1, snapshotid); - sqlite3_bind_int64(stmt, 2, SegmentToId(ref.get_segment())); - string obj = ref.get_sequence(); - sqlite3_bind_text(stmt, 3, obj.c_str(), obj.size(), SQLITE_TRANSIENT); - - rc = sqlite3_step(stmt); - if (rc != SQLITE_DONE) { - fprintf(stderr, "Could not execute INSERT statement!\n"); - ReportError(rc); - } - - sqlite3_finalize(stmt); + if (!ref.is_normal()) + return; stmt = Prepare("insert or ignore into snapshot_refs " "select segmentid, object, size from block_index " "where segmentid = ? and object = ?"); sqlite3_bind_int64(stmt, 1, SegmentToId(ref.get_segment())); + string obj = ref.get_sequence(); sqlite3_bind_text(stmt, 2, obj.c_str(), obj.size(), SQLITE_TRANSIENT); rc = sqlite3_step(stmt);