-
Notifications
You must be signed in to change notification settings - Fork 27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: memo
separate key for reading and writing cached values
#333
base: main
Are you sure you want to change the base?
Conversation
memo
cache read keys from set keysmemo
separate key for reading and writing cached values
memo
separate key for reading and writing cached values memo
separate key for reading and writing cached values
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Hey, thanks for the PR. 🎉 Not sure about this one. Seems very niche at first glance. Especially considering the +87% size increase, we'll need to justify the feature using real world use cases (feel free to list some). Another option would be to come up with another function built purposely for this need. |
The size increase is mostly because of the import of |
Hey @hugo082, good to hear from you! Allow me to clarify what I'm asking for. A “use case” is a practical scenario where a function solves a specific problem or fulfills a need. It emphasizes why and when the function is used, rather than delving into the technical details of how it works. For instance, the use case for a
|
Use Case:In some scenarios, caching results across multiple call signatures is critical for performance and consistency, especially when working with shared datasets or computations. For instance:
Are these scenarios frequent enough?These scenarios appear in data-heavy applications, libraries dealing with API integrations, or anywhere complex computations are shared between layers. In modern development, especially with functional programming patterns and increasing API reliance. Comparison with Other Libraries:The concept of separating getKeys and setKeys aligns with strategies used in some caching libraries or frameworks in other ecosystems:
Code example
import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
public class CustomKey {
private final String part1;
private final String part2;
public CustomKey(String part1, String part2) {
this.part1 = part1;
this.part2 = part2;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
CustomKey that = (CustomKey) o;
return part1.equals(that.part1) && part2.equals(that.part2);
}
@Override
public int hashCode() {
return Objects.hash(part1, part2);
}
}
// Usage
Cache<CustomKey, String> cache = CacheBuilder.newBuilder().build();
CustomKey key = new CustomKey("value1", "value2");
cache.put(key, "cachedData"); Proposal:If this functionality feels too niche for the main memoize function, perhaps introducing a complementary createSharedMemoCache utility that supports shared cache use cases would be a middle ground. This way, the core function remains lean while allowing power users to achieve their goals. |
Summary
You can optionally use a separate key for reading and writing cached values by providing a
setKey
function.This allows for more flexible cache management and sharing of cached values between different function calls.
For any code change,
Does this PR introduce a breaking change?
No
Bundle impact
src/curry/memo.ts
Footnotes
Function size includes the
import
dependencies of the function. ↩