the_hash_algo->init_fn(&c);
        the_hash_algo->update_fn(&c, hdr, hdrlen);
        the_hash_algo->update_fn(&c, dat->buf, dat->len);
-       the_hash_algo->final_fn(oid.hash, &c);
+       the_hash_algo->final_oid_fn(&oid, &c);
        if (oidout)
                oidcpy(oidout, &oid);
 
                }
        }
        git_deflate_end(&s);
-       the_hash_algo->final_fn(oid.hash, &c);
+       the_hash_algo->final_oid_fn(&oid, &c);
 
        if (oidout)
                oidcpy(oidout, &oid);
 
                bad_object(offset, _("inflate returned %d"), status);
        git_inflate_end(&stream);
        if (oid)
-               the_hash_algo->final_fn(oid->hash, &c);
+               the_hash_algo->final_oid_fn(oid, &c);
        return buf == fixed_buf ? NULL : buf;
 }
 
 
        the_hash_algo->init_fn(&ctx);
        unpack_all();
        the_hash_algo->update_fn(&ctx, buffer, offset);
-       the_hash_algo->final_fn(oid.hash, &ctx);
+       the_hash_algo->final_oid_fn(&oid, &ctx);
        if (strict) {
                write_rest();
                if (fsck_finish(&fsck_options))
 
                if (lseek(fd, seekback, SEEK_SET) == (off_t) -1)
                        return error("cannot seek back");
        }
-       the_hash_algo->final_fn(result_oid->hash, &ctx);
+       the_hash_algo->final_oid_fn(result_oid, &ctx);
        if (!idx)
                return 0;
 
 
        }
 
        if (!stable)
-               the_hash_algo->final_fn(oid->hash, &ctx);
+               the_hash_algo->final_oid_fn(oid, &ctx);
 
        return 0;
 }
 
        }
 
        git_inflate_end(&freq->stream);
-       the_hash_algo->final_fn(freq->real_oid.hash, &freq->c);
+       the_hash_algo->final_oid_fn(&freq->real_oid, &freq->c);
        if (freq->zret != Z_STREAM_END) {
                unlink_or_warn(freq->tmpfile.buf);
                return -1;
 
                        break;
                r->hash_algo->update_fn(&c, buf, readlen);
        }
-       r->hash_algo->final_fn(real_oid.hash, &c);
+       r->hash_algo->final_oid_fn(&real_oid, &c);
        close_istream(st);
        return !oideq(oid, &real_oid) ? -1 : 0;
 }
        algo->init_fn(&c);
        algo->update_fn(&c, hdr, *hdrlen);
        algo->update_fn(&c, buf, len);
-       algo->final_fn(oid->hash, &c);
+       algo->final_oid_fn(oid, &c);
 }
 
 /*
        if (ret != Z_OK)
                die(_("deflateEnd on object %s failed (%d)"), oid_to_hex(oid),
                    ret);
-       the_hash_algo->final_fn(parano_oid.hash, &c);
+       the_hash_algo->final_oid_fn(¶no_oid, &c);
        if (!oideq(oid, ¶no_oid))
                die(_("confused by unstable object source data for %s"),
                    oid_to_hex(oid));
                return -1;
        }
 
-       the_hash_algo->final_fn(real_oid.hash, &c);
+       the_hash_algo->final_oid_fn(&real_oid, &c);
        if (!oideq(expected_oid, &real_oid)) {
                error(_("hash mismatch for %s (expected %s)"), path,
                      oid_to_hex(expected_oid));