aboutsummaryrefslogtreecommitdiffstats
path: root/lua
diff options
context:
space:
mode:
authorAsbjørn Sloth Tønnesen <ast@2e8.dk>2019-07-13 22:24:47 +0000
committerAsbjørn Sloth Tønnesen <ast@2e8.dk>2019-07-13 22:24:47 +0000
commit23732642cb8c27de229a52ba201af2809aac6ddd (patch)
tree79a493876d3a8d7c3246acc9f045bbe9d2ade412 /lua
parent8fd0b2cbc4a6fa969b3882bdb1704d9c3ff5ff7a (diff)
downloadlua-inet-23732642cb8c27de229a52ba201af2809aac6ddd.tar.gz
lua-inet-23732642cb8c27de229a52ba201af2809aac6ddd.tar.xz
lua-inet-23732642cb8c27de229a52ba201af2809aac6ddd.zip
add type check and family funcitons
Signed-off-by: Asbjørn Sloth Tønnesen <ast@2e8.dk>
Diffstat (limited to 'lua')
-rw-r--r--lua/inet/init.lua59
1 files changed, 49 insertions, 10 deletions
diff --git a/lua/inet/init.lua b/lua/inet/init.lua
index 72677f9..3186d30 100644
--- a/lua/inet/init.lua
+++ b/lua/inet/init.lua
@@ -5,9 +5,39 @@ local bit32 = require 'bit32'
local inet, inet4, inet6
+local mt2fam = {}
+
inet = {}
inet.__index = inet
+inet4 = setmetatable({}, inet)
+inet4.__index = inet4
+mt2fam[inet4] = 4
+
+inet6 = setmetatable({}, inet)
+inet6.__index = inet6
+mt2fam[inet6] = 6
+
+local function get_mt(t)
+ if type(t) ~= 'table' then return nil end
+ return getmetatable(t)
+end
+
+local function is_inet4(t)
+ local mt = get_mt(t)
+ return mt == inet4
+end
+
+local function is_inet6(t)
+ local mt = get_mt(t)
+ return mt == inet6
+end
+
+local function is_inet(t)
+ local mt = get_mt(t)
+ return mt == inet4 or mt == inet6
+end
+
function inet.new(ip, mask)
local ipv6 = string.find(ip, ':', 1, true)
if ipv6 then
@@ -22,6 +52,13 @@ function inet:__len()
if mask == nil then return 0 end -- make metatable inspectable
return mask
end
+inet4.__len = inet.__len
+inet6.__len = inet.__len
+
+function inet:family()
+ local mt = assert(getmetatable(self))
+ return assert(mt2fam[mt])
+end
local lshift = bit32.lshift
local rshift = bit32.rshift
@@ -29,10 +66,6 @@ local band = bit32.band
local replace = bit32.replace
local bxor = bit32.bxor
-inet4 = {}
-inet4.__index = inet4
-inet4.__len = inet.__len
-
local ipv4_parser
local ipv6_parser
do
@@ -231,10 +264,6 @@ local function parse6(ipstr)
return pcs, netmask
end
-inet6 = setmetatable({}, inet)
-inet6.__index = inet6
-inet6.__len = inet.__len
-
function inet6.new(ip, netmask)
local pcs, err
if type(ip) == 'string' then
@@ -488,8 +517,18 @@ function inet6:__mul(n)
end
pcs[p] = pcs[p] + low_shift
new:balance()
- -- print(mask % 8)
return new
end
-return inet.new
+local M = {}
+local mt = {}
+
+function mt.__call(_, ...)
+ return new_inet(...)
+end
+
+M.is4 = is_inet4
+M.is6 = is_inet6
+M.is = is_inet
+
+return setmetatable(M, mt)