From 0a8d538d2549c4d25b6fc3ef610e69a734a513be Mon Sep 17 00:00:00 2001 From: David Nolen Date: Fri, 23 Feb 2024 09:25:37 -0500 Subject: [PATCH] CLJS-3290: implement IHash for js Symbol (#225) * implement IHash for js Symbol * add test cases --- src/main/cljs/cljs/core.cljs | 5 +++++ src/test/cljs/cljs/hashing_test.cljs | 9 +++++++++ 2 files changed, 14 insertions(+) diff --git a/src/main/cljs/cljs/core.cljs b/src/main/cljs/cljs/core.cljs index 8ccc05d19..46600b323 100644 --- a/src/main/cljs/cljs/core.cljs +++ b/src/main/cljs/cljs/core.cljs @@ -1458,6 +1458,11 @@ (-hash [o] (goog/getUid o))) +(extend-type symbol + IHash + (-hash [o] + (hash (.toString o)))) + ;;this is primitive because & emits call to array-seq (defn inc "Returns a number one greater than num." diff --git a/src/test/cljs/cljs/hashing_test.cljs b/src/test/cljs/cljs/hashing_test.cljs index 2a2ffcf18..7bad7169e 100644 --- a/src/test/cljs/cljs/hashing_test.cljs +++ b/src/test/cljs/cljs/hashing_test.cljs @@ -102,3 +102,12 @@ (is (= (hash 0.5) (hash 0.5))) (is (= (hash -0.32553251) (hash -0.32553251))) (is (= (hash -0.0000032553251) (hash -0.0000032553251))))) + +(deftest test-cljs-3290 + (testing "JS Symbol hash" + (let [s (.for js/Symbol "foo")] + (is (number? (hash s))) + (is (== (hash s) (hash s))) + (is (not (== (hash s) (hash (.for js/Symbol "bar"))))) + (let [m {s 2}] + (is (== 2 (get m s)))))))