X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=bluesky%2Finode.c;h=993be73eed35947d2e1716fc197005e340b5c5b2;hb=8ae6b69c5d727704d4414e370c165dd71668031c;hp=a76b4b97e8ab8a8a09baff6d17132763071670de;hpb=f2586554fd55cd3cc1be65ac33d1122d00372133;p=bluesky.git diff --git a/bluesky/inode.c b/bluesky/inode.c index a76b4b9..993be73 100644 --- a/bluesky/inode.c +++ b/bluesky/inode.c @@ -292,31 +292,11 @@ void bluesky_insert_inode(BlueSkyFS *fs, BlueSkyInode *inode) void bluesky_inode_start_sync(BlueSkyInode *inode) { GList *log_items = NULL; - BlueSkyFS *fs = inode->fs; if (inode->type == BLUESKY_REGULAR) bluesky_file_flush(inode, &log_items); - GString *buf = g_string_new(""); - bluesky_serialize_inode(buf, inode); - - char key[64]; - sprintf(key, "inode-%016"PRIx64, inode->inum); - - BlueSkyCloudLog *cloudlog = bluesky_cloudlog_new(fs); - cloudlog->type = LOGTYPE_INODE; - cloudlog->inum = inode->inum; - cloudlog->data = bluesky_string_new_from_gstring(buf); - - if (inode->type == BLUESKY_REGULAR) { - for (int i = 0; i < inode->blocks->len; i++) { - BlueSkyBlock *b = &g_array_index(inode->blocks, BlueSkyBlock, i); - if (b->type == BLUESKY_BLOCK_REF) { - BlueSkyCloudID id = b->ref->id; - g_array_append_val(cloudlog->pointers, id); - } - } - } + BlueSkyCloudLog *cloudlog = bluesky_serialize_inode(inode); bluesky_cloudlog_unref(inode->committed_item); inode->committed_item = cloudlog; @@ -324,7 +304,6 @@ void bluesky_inode_start_sync(BlueSkyInode *inode) bluesky_cloudlog_sync(cloudlog); bluesky_cloudlog_ref(cloudlog); log_items = g_list_prepend(log_items, cloudlog); - bluesky_cloudlog_insert(cloudlog); /* Wait for all log items to be committed to disk. */ bluesky_log_finish_all(log_items);