0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-02-18 13:04:38 -05:00

Merge pull request #2409 from penpot/niwinz-hotfix

Fix compatibility issues with safari >=14 & < 16
This commit is contained in:
Alejandro 2022-10-05 09:22:11 +02:00 committed by GitHub
commit 5ad385cf93
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 43 additions and 15 deletions

View file

@ -79,6 +79,28 @@ goog.scope(function() {
}; };
})(); })();
function getBigUint64(view, byteOffset, le) {
const a = view.getUint32(byteOffset, le);
const b = view.getUint32(byteOffset + 4, le);
const leMask = Number(!!le);
const beMask = Number(!le);
return ((BigInt(a * beMask + b * leMask) << 32n) |
(BigInt(a * leMask + b * beMask)));
}
function setBigUint64(view, byteOffset, value, le) {
const hi = Number(value >> 32n);
const lo = Number(value & 0xffffffffn);
if (le) {
view.setUint32(byteOffset + 4, hi, le);
view.setUint32(byteOffset, lo, le);
}
else {
view.setUint32(byteOffset, hi, le);
view.setUint32(byteOffset + 4, lo, le);
}
}
self.v8 = (function () { self.v8 = (function () {
const buff = new ArrayBuffer(16); const buff = new ArrayBuffer(16);
const int8 = new Uint8Array(buff); const int8 = new Uint8Array(buff);
@ -104,7 +126,7 @@ goog.scope(function() {
const nextLong = () => { const nextLong = () => {
fill(tmpInt8); fill(tmpInt8);
return tmpView.getBigUint64(0, false); return getBigUint64(tmpView, 0, false);
}; };
lastRd = nextLong() & 0xffff_ffff_ffff_f0ffn; lastRd = nextLong() & 0xffff_ffff_ffff_f0ffn;
@ -118,8 +140,9 @@ goog.scope(function() {
| ((ts << 14n) & 0x3fff_ffff_ffff_c000n) | ((ts << 14n) & 0x3fff_ffff_ffff_c000n)
| lastCs); | lastCs);
view.setBigUint64(0, msb, false); setBigUint64(view, 0, msb, false);
view.setBigUint64(8, lsb, false); setBigUint64(view, 8, lsb, false);
return core.uuid(toHexString(int8)); return core.uuid(toHexString(int8));
}; };

View file

@ -19,24 +19,29 @@
;; The main broadcast channel instance, used for emit data ;; The main broadcast channel instance, used for emit data
(defonce default-channel (defonce default-channel
(js/BroadcastChannel. default-topic)) (when (exists? js/BroadcastChannel)
(js/BroadcastChannel. default-topic)))
(defonce stream (defonce stream
(->> (rx/create (fn [subs] (if (exists? js/BroadcastChannel)
(let [chan (js/BroadcastChannel. default-topic)] (->> (rx/create (fn [subs]
(unchecked-set chan "onmessage" #(rx/push! subs (unchecked-get % "data"))) (let [chan (js/BroadcastChannel. default-topic)]
(fn [] (.close ^js chan))))) (unchecked-set chan "onmessage" #(rx/push! subs (unchecked-get % "data")))
(rx/map t/decode-str) (fn [] (.close ^js chan)))))
(rx/map map->BroadcastMessage) (rx/map t/decode-str)
(rx/share))) (rx/map map->BroadcastMessage)
(rx/share))
(rx/subject)))
(defn emit! (defn emit!
([type data] ([type data]
(.postMessage ^js default-channel (t/encode-str {:id nil :type type :data data})) (when default-channel
nil) (.postMessage ^js default-channel (t/encode-str {:id nil :type type :data data}))
nil))
([id type data] ([id type data]
(.postMessage ^js default-channel (t/encode-str {:id id :type type :data data})) (when default-channel
nil)) (.postMessage ^js default-channel (t/encode-str {:id id :type type :data data}))
nil)))
(defn type? (defn type?
([type] ([type]