X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=subfile.cc;h=eee3bdf0ff05bb8ad05282323ea7c1a1e8d03234;hb=35dd99aa3d47805b661fe3126a951710fa7dee11;hp=dac7eda03da81cab3e5e47cc49c7dfa49d204141;hpb=915e73b3fa1f245541611f26268cdd574798e1e2;p=cumulus.git diff --git a/subfile.cc b/subfile.cc index dac7eda..eee3bdf 100644 --- a/subfile.cc +++ b/subfile.cc @@ -28,8 +28,8 @@ #include #include "subfile.h" -#include "chunk.h" -#include "sha1.h" +#include "third_party/chunk.h" +#include "third_party/sha1.h" using std::list; using std::map; @@ -195,6 +195,12 @@ void Subfile::store_block_signatures(ObjectReference ref, block_summary summary) free(packed); } +void Subfile::store_analyzed_signatures(ObjectReference ref) +{ + if (analyzed_len >= 16384) + store_block_signatures(ref, new_block_summary); +} + /* Compute an incremental representation of the most recent block analyzed. */ enum subfile_item_type { SUBFILE_COPY, SUBFILE_NEW }; @@ -265,8 +271,8 @@ list Subfile::create_incremental(TarSegmentStore *tss, o->write(tss); ObjectReference ref = o->get_ref(); db->StoreObject(ref, block_csum, analyzed_len, block_age); - if (analyzed_len >= 16384) - store_block_signatures(ref, new_block_summary); + store_analyzed_signatures(ref); + ref.set_range(0, analyzed_len, true); refs.push_back(ref); delete o; return refs;