X-Git-Url: http://git.vrable.net/?p=cumulus.git;a=blobdiff_plain;f=store.cc;h=f87b671e3a1e943c02376f3145c8afdf61d63bec;hp=aa69d9e8a4a7e3f4af329138027d0a78ce180623;hb=15f090d3b2f0bf3994aacd00ab07da3b1f65ea00;hpb=974240b635af9cf2b94e2f1f3c02beab662a189d diff --git a/store.cc b/store.cc index aa69d9e..f87b671 100644 --- a/store.cc +++ b/store.cc @@ -41,6 +41,7 @@ #include #include +#include "hash.h" #include "store.h" #include "ref.h" #include "util.h" @@ -172,7 +173,7 @@ void Tarfile::write_object(int id, const char *data, size_t len) sprintf(header.mode, "%07o", 0600); sprintf(header.uid, "%07o", 0); sprintf(header.gid, "%07o", 0); - sprintf(header.size, "%011o", len); + sprintf(header.size, "%011o", (int)len); sprintf(header.mtime, "%011o", (int)time(NULL)); header.typeflag = '0'; strcpy(header.magic, "ustar "); @@ -281,7 +282,7 @@ void TarSegmentStore::dump_stats() for (map >::iterator i = group_sizes.begin(); i != group_sizes.end(); ++i) { printf(" %s: %lld (%lld compressed)\n", i->first.c_str(), - i->second.first, i->second.second); + (long long)i->second.first, (long long)i->second.second); } } @@ -338,7 +339,8 @@ void LbsObject::checksum() { assert(written); - SHA1Checksum hash; - hash.process(data, data_len); - ref.set_checksum(hash.checksum_str()); + Hash *hash = Hash::New(); + hash->update(data, data_len); + ref.set_checksum(hash->digest_str()); + delete hash; }