aboutsummaryrefslogtreecommitdiffstats
path: root/lua/inet/core.lua
diff options
context:
space:
mode:
authorAsbjørn Sloth Tønnesen <ast@2e8.dk>2020-02-17 18:24:58 +0000
committerAsbjørn Sloth Tønnesen <ast@2e8.dk>2020-02-17 18:24:58 +0000
commit46676a465037c20b761b02d716fe30fdfd0a3f14 (patch)
tree91579169dc0d9be0d45fdacc4af07b1ecf083ea7 /lua/inet/core.lua
parenta1ba1999ff0b6b9b1b2c756d678e18e9b405dec5 (diff)
downloadlua-inet-46676a465037c20b761b02d716fe30fdfd0a3f14.tar.gz
lua-inet-46676a465037c20b761b02d716fe30fdfd0a3f14.tar.xz
lua-inet-46676a465037c20b761b02d716fe30fdfd0a3f14.zip
fix cross-family sorting
Signed-off-by: Asbjørn Sloth Tønnesen <ast@2e8.dk>
Diffstat (limited to 'lua/inet/core.lua')
-rw-r--r--lua/inet/core.lua26
1 files changed, 26 insertions, 0 deletions
diff --git a/lua/inet/core.lua b/lua/inet/core.lua
index 7037885..5008da9 100644
--- a/lua/inet/core.lua
+++ b/lua/inet/core.lua
@@ -360,6 +360,7 @@ function inet4:clone()
end
function inet4:contains(other)
+ if is_inet6(other) then return false end
if self.mask >= other.mask then
return false
end
@@ -370,6 +371,12 @@ function inet4:contains(other)
end
function inet4:__lt(other)
+ if not is_inet4(other) then
+ if is_inet6(other) then
+ return true
+ end
+ return nil
+ end
if self.bip == other.bip then
return self.mask < other.mask
end
@@ -377,6 +384,12 @@ function inet4:__lt(other)
end
function inet4:__le(other)
+ if not is_inet4(other) then
+ if is_inet6(other) then
+ return true
+ end
+ return nil
+ end
if self.mask < other.mask then
return false
end
@@ -391,6 +404,7 @@ function inet4:__le(other)
end
function inet4:__eq(other)
+ if getmetatable(other) ~= inet4 then return false end
return self.bip == other.bip and self.mask == other.mask
end
@@ -603,6 +617,12 @@ function inet6:contains(other)
end
function inet6:__lt(other)
+ if not is_inet6(other) then
+ if is_inet4(other) then
+ return false
+ end
+ return nil
+ end
-- self < other
local spcs = self.pcs
local opcs = other.pcs
@@ -620,6 +640,12 @@ function inet6:__lt(other)
end
function inet6:__le(other)
+ if not is_inet6(other) then
+ if is_inet4(other) then
+ return false
+ end
+ return nil
+ end
-- self <= other
local spcs = self.pcs
local opcs = other.pcs