Skip to content
This repository has been archived by the owner on Feb 19, 2022. It is now read-only.

Consider non-global cache strategies #37

Open
divmain opened this issue Feb 15, 2017 · 2 comments
Open

Consider non-global cache strategies #37

divmain opened this issue Feb 15, 2017 · 2 comments

Comments

@divmain
Copy link
Contributor

divmain commented Feb 15, 2017

Capturing an out-of-band conversation with @ryan-roemer:

Using a global singleton for the cache strategy is potentially undesirable. Or, inversely, it might be desirable to use different caching solutions for different components / pages in the context of a single Node.js process.

If the traversal functions in src/render/traverse.js were made to be class methods of a new Traverser class, a cacher object with methods get and set could be attached to the instance to simplify access to the custom cacher.

This could be provided as a replacement to setCacheStrategy or as a complement. If a complement, setCacheStrategy would set the global cache strategy. This value would be overrideable by passing a Cacher to the Renderer constructor.

This is probably a better design, but also a nice-to-have, since a global caching strategy is probably adequate for the vast majority of use cases.

See also: #36 (comment)

@divmain divmain changed the title Consider Traverser class with attached Cacher Consider non-global cache strategies Feb 15, 2017
@divmain
Copy link
Contributor Author

divmain commented Mar 15, 2017

This should be relatively straightforward now that the Renderer is easily exposed to its Sequence.

@clifton
Copy link

clifton commented Mar 21, 2017

👍 , in a more naive caching library (that I shelved as this one is a better design), I implemented cache settings as a decorator to components that exposed settings such as in-memory caching (e.g. elements with few rendered permutations) but would use memcached otherwise.

# for free to subscribe to this conversation on GitHub. Already have an account? #.
Projects
None yet
Development

No branches or pull requests

2 participants