add-cache.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. "use strict";
  2. module.exports = addCache;
  3. function addCache(repo, cache) {
  4. var loadAs = repo.loadAs;
  5. if (loadAs) repo.loadAs = loadAsCached;
  6. var saveAs = repo.saveAs;
  7. if (saveAs) repo.saveAs = saveAsCached;
  8. var createTree = repo.createTree;
  9. if (createTree) repo.createTree = createTreeCached;
  10. function loadAsCached(type, hash, callback) {
  11. // Next check in disk cache...
  12. cache.loadAs(type, hash, onCacheLoad);
  13. function onCacheLoad(err, value) {
  14. if (err) return callback(err);
  15. // ...and return if it's there.
  16. if (value !== undefined) {
  17. return callback(null, value, hash);
  18. }
  19. // Otherwise load from real data source...
  20. loadAs.call(repo, type, hash, onLoad);
  21. }
  22. function onLoad(err, value) {
  23. if (value === undefined) return callback(err);
  24. // Store it on disk too...
  25. // Force the hash to prevent mismatches.
  26. cache.saveAs(type, value, onSave, hash);
  27. function onSave(err) {
  28. if (err) return callback(err);
  29. // Finally return the value to caller.
  30. callback(null, value, hash);
  31. }
  32. }
  33. }
  34. function saveAsCached(type, value, callback) {
  35. saveAs.call(repo, type, value, onSave);
  36. function onSave(err, hash) {
  37. if (err) return callback(err);
  38. // Store in disk, forcing hash to match.
  39. cache.saveAs(type, value, callback, hash);
  40. }
  41. }
  42. function createTreeCached(entries, callback) {
  43. createTree.call(repo, entries, onTree);
  44. function onTree(err, hash, tree) {
  45. if (err) return callback(err);
  46. cache.saveAs("tree", tree, callback, hash);
  47. }
  48. }
  49. }