Skip to content

Commit

Permalink
Revert "Add disk cache store (#949)"
Browse files Browse the repository at this point in the history
This reverts commit f86a376.
  • Loading branch information
afcapel committed Nov 13, 2023
1 parent 2655842 commit 4cd1af1
Show file tree
Hide file tree
Showing 11 changed files with 61 additions and 286 deletions.
15 changes: 1 addition & 14 deletions src/core/cache.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
import { setMetaContent } from "../util"
import { SnapshotCache } from "./drive/snapshot_cache"

export class Cache {
clear() {
this.store.clear()
this.session.clearCache()
}

resetCacheControl() {
Expand All @@ -18,18 +17,6 @@ export class Cache {
this.#setCacheControl("no-preview")
}

set store(store) {
if (typeof store === "string") {
SnapshotCache.setStore(store)
} else {
SnapshotCache.currentStore = store
}
}

get store() {
return SnapshotCache.currentStore
}

#setCacheControl(value) {
setMetaContent("turbo-cache-control", value)
}
Expand Down
64 changes: 0 additions & 64 deletions src/core/drive/cache_stores/disk_store.js

This file was deleted.

56 changes: 0 additions & 56 deletions src/core/drive/cache_stores/memory_store.js

This file was deleted.

4 changes: 0 additions & 4 deletions src/core/drive/page_snapshot.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,10 +45,6 @@ export class PageSnapshot extends Snapshot {
return this.documentElement.getAttribute("lang")
}

get html() {
return `${this.headElement.outerHTML}\n\n${this.element.outerHTML}`
}

get headElement() {
return this.headSnapshot.element
}
Expand Down
6 changes: 1 addition & 5 deletions src/core/drive/page_view.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { PageSnapshot } from "./page_snapshot"
import { SnapshotCache } from "./snapshot_cache"

export class PageView extends View {
snapshotCache = new SnapshotCache()
snapshotCache = new SnapshotCache(10)
lastRenderedLocation = new URL(location.href)
forceReloaded = false

Expand All @@ -32,10 +32,6 @@ export class PageView extends View {
return this.render(renderer)
}

setCacheStore(cacheName) {
SnapshotCache.setStore(cacheName)
}

clearSnapshotCache() {
this.snapshotCache.clear()
}
Expand Down
4 changes: 3 additions & 1 deletion src/core/drive/preloader.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,9 @@ export class Preloader {
async preloadURL(link) {
const location = new URL(link.href)

if (await this.snapshotCache.has(location)) return
if (this.snapshotCache.has(location)) {
return
}

try {
const response = await fetch(location.toString(), { headers: { "Sec-Purpose": "prefetch", Accept: "text/html" } })
Expand Down
59 changes: 40 additions & 19 deletions src/core/drive/snapshot_cache.js
Original file line number Diff line number Diff line change
@@ -1,35 +1,56 @@
import { DiskStore } from "./cache_stores/disk_store"
import { MemoryStore } from "./cache_stores/memory_store"
import { toCacheKey } from "../url"

export class SnapshotCache {
static currentStore = new MemoryStore(10)

static setStore(storeName) {
switch (storeName) {
case "memory":
SnapshotCache.currentStore = new MemoryStore(10)
break
case "disk":
SnapshotCache.currentStore = new DiskStore()
break
default:
throw new Error(`Invalid store name: ${storeName}`)
}
keys = []
snapshots = {}

constructor(size) {
this.size = size
}

has(location) {
return SnapshotCache.currentStore.has(location)
return toCacheKey(location) in this.snapshots
}

get(location) {
return SnapshotCache.currentStore.get(location)
if (this.has(location)) {
const snapshot = this.read(location)
this.touch(location)
return snapshot
}
}

put(location, snapshot) {
return SnapshotCache.currentStore.put(location, snapshot)
this.write(location, snapshot)
this.touch(location)
return snapshot
}

clear() {
return SnapshotCache.currentStore.clear()
this.snapshots = {}
}

// Private

read(location) {
return this.snapshots[toCacheKey(location)]
}

write(location, snapshot) {
this.snapshots[toCacheKey(location)] = snapshot
}

touch(location) {
const key = toCacheKey(location)
const index = this.keys.indexOf(key)
if (index > -1) this.keys.splice(index, 1)
this.keys.unshift(key)
this.trim()
}

trim() {
for (const key of this.keys.splice(this.size)) {
delete this.snapshots[key]
}
}
}
8 changes: 4 additions & 4 deletions src/core/drive/visit.js
Original file line number Diff line number Diff line change
Expand Up @@ -215,8 +215,8 @@ export class Visit {
}
}

async getCachedSnapshot() {
const snapshot = (await this.view.getCachedSnapshotForLocation(this.location)) || this.getPreloadedSnapshot()
getCachedSnapshot() {
const snapshot = this.view.getCachedSnapshotForLocation(this.location) || this.getPreloadedSnapshot()

if (snapshot && (!getAnchor(this.location) || snapshot.hasAnchor(getAnchor(this.location)))) {
if (this.action == "restore" || snapshot.isPreviewable) {
Expand All @@ -235,8 +235,8 @@ export class Visit {
return this.getCachedSnapshot() != null
}

async loadCachedSnapshot() {
const snapshot = await this.getCachedSnapshot()
loadCachedSnapshot() {
const snapshot = this.getCachedSnapshot()
if (snapshot) {
const isPreview = this.shouldIssueRequest()
this.render(async () => {
Expand Down
49 changes: 0 additions & 49 deletions src/tests/fixtures/disk_cache.html

This file was deleted.

Loading

0 comments on commit 4cd1af1

Please sign in to comment.