jazz-tools 0.8.15 → 0.8.16

Sign up to get free protection for your applications and to get access to all the features.
Files changed (93) hide show
  1. package/CHANGELOG.md +276 -269
  2. package/dist/native/coValues/account.js +3 -6
  3. package/dist/native/coValues/account.js.map +1 -1
  4. package/dist/native/coValues/coList.js +3 -7
  5. package/dist/native/coValues/coList.js.map +1 -1
  6. package/dist/native/coValues/coMap.js +8 -14
  7. package/dist/native/coValues/coMap.js.map +1 -1
  8. package/dist/native/coValues/coStream.js +7 -12
  9. package/dist/native/coValues/coStream.js.map +1 -1
  10. package/dist/native/coValues/deepLoading.js +6 -3
  11. package/dist/native/coValues/deepLoading.js.map +1 -1
  12. package/dist/native/coValues/extensions/imageDef.js.map +1 -1
  13. package/dist/native/coValues/group.js +3 -6
  14. package/dist/native/coValues/group.js.map +1 -1
  15. package/dist/native/coValues/interfaces.js +4 -3
  16. package/dist/native/coValues/interfaces.js.map +1 -1
  17. package/dist/native/exports.js +3 -9
  18. package/dist/native/exports.js.map +1 -1
  19. package/dist/native/implementation/createContext.js +1 -2
  20. package/dist/native/implementation/createContext.js.map +1 -1
  21. package/dist/native/implementation/devtoolsFormatters.js +5 -25
  22. package/dist/native/implementation/devtoolsFormatters.js.map +1 -1
  23. package/dist/native/implementation/refs.js +1 -2
  24. package/dist/native/implementation/refs.js.map +1 -1
  25. package/dist/native/implementation/schema.js +1 -1
  26. package/dist/native/implementation/schema.js.map +1 -1
  27. package/dist/native/implementation/subscriptionScope.js +2 -4
  28. package/dist/native/implementation/subscriptionScope.js.map +1 -1
  29. package/dist/native/index.native.js +1 -1
  30. package/dist/native/index.native.js.map +1 -1
  31. package/dist/native/lib/cache.js.map +1 -1
  32. package/dist/native/lib/cache.test.js +1 -1
  33. package/dist/native/lib/cache.test.js.map +1 -1
  34. package/dist/web/coValues/account.js +3 -6
  35. package/dist/web/coValues/account.js.map +1 -1
  36. package/dist/web/coValues/coList.js +3 -7
  37. package/dist/web/coValues/coList.js.map +1 -1
  38. package/dist/web/coValues/coMap.js +8 -14
  39. package/dist/web/coValues/coMap.js.map +1 -1
  40. package/dist/web/coValues/coStream.js +7 -12
  41. package/dist/web/coValues/coStream.js.map +1 -1
  42. package/dist/web/coValues/deepLoading.js +6 -3
  43. package/dist/web/coValues/deepLoading.js.map +1 -1
  44. package/dist/web/coValues/extensions/imageDef.js.map +1 -1
  45. package/dist/web/coValues/group.js +3 -6
  46. package/dist/web/coValues/group.js.map +1 -1
  47. package/dist/web/coValues/interfaces.js +4 -3
  48. package/dist/web/coValues/interfaces.js.map +1 -1
  49. package/dist/web/exports.js +3 -9
  50. package/dist/web/exports.js.map +1 -1
  51. package/dist/web/implementation/createContext.js +1 -2
  52. package/dist/web/implementation/createContext.js.map +1 -1
  53. package/dist/web/implementation/devtoolsFormatters.js +5 -25
  54. package/dist/web/implementation/devtoolsFormatters.js.map +1 -1
  55. package/dist/web/implementation/refs.js +1 -2
  56. package/dist/web/implementation/refs.js.map +1 -1
  57. package/dist/web/implementation/schema.js +1 -1
  58. package/dist/web/implementation/schema.js.map +1 -1
  59. package/dist/web/implementation/subscriptionScope.js +2 -4
  60. package/dist/web/implementation/subscriptionScope.js.map +1 -1
  61. package/dist/web/lib/cache.js.map +1 -1
  62. package/dist/web/lib/cache.test.js +1 -1
  63. package/dist/web/lib/cache.test.js.map +1 -1
  64. package/package.json +5 -9
  65. package/src/coValues/account.ts +330 -339
  66. package/src/coValues/coList.ts +474 -495
  67. package/src/coValues/coMap.ts +584 -604
  68. package/src/coValues/coStream.ts +624 -650
  69. package/src/coValues/deepLoading.ts +184 -200
  70. package/src/coValues/extensions/imageDef.ts +44 -44
  71. package/src/coValues/group.ts +196 -210
  72. package/src/coValues/interfaces.ts +197 -199
  73. package/src/exports.ts +38 -26
  74. package/src/implementation/createContext.ts +206 -213
  75. package/src/implementation/devtoolsFormatters.ts +80 -100
  76. package/src/implementation/refs.ts +127 -139
  77. package/src/implementation/schema.ts +124 -128
  78. package/src/implementation/subscriptionScope.ts +111 -121
  79. package/src/index.native.ts +3 -3
  80. package/src/lib/cache.test.ts +48 -48
  81. package/src/lib/cache.ts +9 -9
  82. package/src/tests/coList.test.ts +264 -283
  83. package/src/tests/coMap.test.ts +741 -761
  84. package/src/tests/coStream.test.ts +405 -438
  85. package/src/tests/deepLoading.test.ts +251 -256
  86. package/src/tests/groupsAndAccounts.test.ts +70 -74
  87. package/src/tests/schema.test.ts +198 -198
  88. package/src/tests/subscribe.test.ts +312 -299
  89. package/tsconfig.json +2 -4
  90. package/tsconfig.native.json +4 -10
  91. package/tsconfig.web.json +4 -10
  92. package/.eslintrc.cjs +0 -24
  93. package/.prettierrc.js +0 -9
@@ -1,64 +1,64 @@
1
- import { expect, describe, test } from "vitest";
2
- import { coValuesCache } from "./cache.js";
3
1
  import { RawCoValue } from "cojson";
2
+ import { describe, expect, test } from "vitest";
4
3
  import { CoValue } from "../internal.js";
4
+ import { coValuesCache } from "./cache.js";
5
5
 
6
6
  describe("coValuesCache", () => {
7
- test("should return computed value when not cached", () => {
8
- const mockRawValue = { type: "comap" } as RawCoValue;
9
- const mockCoValue = { id: "test" } as unknown as CoValue;
10
- let computeCalls = 0;
11
-
12
- const result = coValuesCache.get(mockRawValue, () => {
13
- computeCalls++;
14
- return mockCoValue;
15
- });
7
+ test("should return computed value when not cached", () => {
8
+ const mockRawValue = { type: "comap" } as RawCoValue;
9
+ const mockCoValue = { id: "test" } as unknown as CoValue;
10
+ let computeCalls = 0;
16
11
 
17
- expect(result).toBe(mockCoValue);
18
- expect(computeCalls).toBe(1);
12
+ const result = coValuesCache.get(mockRawValue, () => {
13
+ computeCalls++;
14
+ return mockCoValue;
19
15
  });
20
16
 
21
- test("should return cached value on subsequent calls", () => {
22
- const mockRawValue = { type: "comap" } as RawCoValue;
23
- const mockCoValue = { id: "test" } as unknown as CoValue;
24
- let computeCalls = 0;
17
+ expect(result).toBe(mockCoValue);
18
+ expect(computeCalls).toBe(1);
19
+ });
25
20
 
26
- // First call
27
- const result1 = coValuesCache.get(mockRawValue, () => {
28
- computeCalls++;
29
- return mockCoValue;
30
- });
21
+ test("should return cached value on subsequent calls", () => {
22
+ const mockRawValue = { type: "comap" } as RawCoValue;
23
+ const mockCoValue = { id: "test" } as unknown as CoValue;
24
+ let computeCalls = 0;
31
25
 
32
- // Second call with same raw value
33
- const result2 = coValuesCache.get(mockRawValue, () => {
34
- computeCalls++;
35
- return mockCoValue;
36
- });
26
+ // First call
27
+ const result1 = coValuesCache.get(mockRawValue, () => {
28
+ computeCalls++;
29
+ return mockCoValue;
30
+ });
37
31
 
38
- expect(result1).toBe(mockCoValue);
39
- expect(result2).toBe(mockCoValue);
40
- expect(computeCalls).toBe(1); // Compute should only be called once
32
+ // Second call with same raw value
33
+ const result2 = coValuesCache.get(mockRawValue, () => {
34
+ computeCalls++;
35
+ return mockCoValue;
41
36
  });
42
37
 
43
- test("should cache different values for different raw values", () => {
44
- const mockRawValue1 = { type: "comap" } as RawCoValue;
45
- const mockRawValue2 = { type: "colist" } as RawCoValue;
46
- const mockCoValue1 = { id: "test1" } as unknown as CoValue;
47
- const mockCoValue2 = { id: "test2" } as unknown as CoValue;
48
- let computeCalls = 0;
38
+ expect(result1).toBe(mockCoValue);
39
+ expect(result2).toBe(mockCoValue);
40
+ expect(computeCalls).toBe(1); // Compute should only be called once
41
+ });
49
42
 
50
- const result1 = coValuesCache.get(mockRawValue1, () => {
51
- computeCalls++;
52
- return mockCoValue1;
53
- });
43
+ test("should cache different values for different raw values", () => {
44
+ const mockRawValue1 = { type: "comap" } as RawCoValue;
45
+ const mockRawValue2 = { type: "colist" } as RawCoValue;
46
+ const mockCoValue1 = { id: "test1" } as unknown as CoValue;
47
+ const mockCoValue2 = { id: "test2" } as unknown as CoValue;
48
+ let computeCalls = 0;
54
49
 
55
- const result2 = coValuesCache.get(mockRawValue2, () => {
56
- computeCalls++;
57
- return mockCoValue2;
58
- });
50
+ const result1 = coValuesCache.get(mockRawValue1, () => {
51
+ computeCalls++;
52
+ return mockCoValue1;
53
+ });
59
54
 
60
- expect(result1).toBe(mockCoValue1);
61
- expect(result2).toBe(mockCoValue2);
62
- expect(computeCalls).toBe(2); // Should compute once for each unique raw value
55
+ const result2 = coValuesCache.get(mockRawValue2, () => {
56
+ computeCalls++;
57
+ return mockCoValue2;
63
58
  });
64
- });
59
+
60
+ expect(result1).toBe(mockCoValue1);
61
+ expect(result2).toBe(mockCoValue2);
62
+ expect(computeCalls).toBe(2); // Should compute once for each unique raw value
63
+ });
64
+ });
package/src/lib/cache.ts CHANGED
@@ -4,13 +4,13 @@ import { CoValue } from "../internal.js";
4
4
  const weakMap = new WeakMap<RawCoValue, CoValue>();
5
5
 
6
6
  export const coValuesCache = {
7
- get: <V extends CoValue>(raw: RawCoValue, compute: () => V) => {
8
- const cached = weakMap.get(raw);
9
- if (cached) {
10
- return cached as V;
11
- }
12
- const computed = compute();
13
- weakMap.set(raw, computed);
14
- return computed;
15
- },
7
+ get: <V extends CoValue>(raw: RawCoValue, compute: () => V) => {
8
+ const cached = weakMap.get(raw);
9
+ if (cached) {
10
+ return cached as V;
11
+ }
12
+ const computed = compute();
13
+ weakMap.set(raw, computed);
14
+ return computed;
15
+ },
16
16
  };