# HG changeset patch # User Kim Alvefur # Date 1563753537 -7200 # Node ID 48f7cda4174d363f507d4f15709771e6617061e8 # Parent a17f47d5e1191e44c510581aa71d590ddd084d49 util.bitops: Library to find appropriate bitwise library (closes #1395) diff -r a17f47d5e119 -r 48f7cda4174d net/websocket/frames.lua --- a/net/websocket/frames.lua Sat Sep 07 19:00:37 2019 +0200 +++ b/net/websocket/frames.lua Mon Jul 22 01:58:57 2019 +0200 @@ -9,8 +9,7 @@ local softreq = require "util.dependencies".softreq; local random_bytes = require "util.random".bytes; -local bit = assert(softreq"bit32" or softreq"bit", - "No bit module found. See https://prosody.im/doc/depends#bitop"); +local bit = require "util.bitcompat"; local band = bit.band; local bor = bit.bor; local bxor = bit.bxor; diff -r a17f47d5e119 -r 48f7cda4174d util/bit53.lua --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/util/bit53.lua Mon Jul 22 01:58:57 2019 +0200 @@ -0,0 +1,7 @@ +-- Only the operators needed by net.websocket.frames are provided at this point +return { + band = function (a, b) return a & b end; + bor = function (a, b) return a | b end; + bxor = function (a, b) return a ~ b end; +}; + diff -r a17f47d5e119 -r 48f7cda4174d util/bitcompat.lua --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/util/bitcompat.lua Mon Jul 22 01:58:57 2019 +0200 @@ -0,0 +1,32 @@ +-- Compatibility layer for bitwise operations + +-- First try the bit32 lib +-- Lua 5.3 has it with compat enabled +-- Lua 5.2 has it by default +if _G.bit32 then + return _G.bit32; +else + -- Lua 5.1 may have it as a standalone module that can be installed + local ok, bitop = pcall(require, "bit32") + if ok then + return bitop; + end +end + +do + -- Lua 5.3 and 5.4 would be able to use native infix operators + local ok, bitop = pcall(require, "util.bit53") + if ok then + return bitop; + end +end + +do + -- Lastly, try the LuaJIT bitop library + local ok, bitop = pcall(require, "bit") + if ok then + return bitop; + end +end + +error "No bit module found. See https://prosody.im/doc/depends#bitop";