use rlua::prelude::*;use std::net::Ipv6Addr;use crate::bindings::net::ipv4::LuaIpv4;pub struct LuaIpv6(pub Ipv6Addr);impl LuaUserData for LuaIpv6 {    fn add_methods<'lua, M: LuaUserDataMethods<'lua, Self>>(methods: &mut M) {        methods.add_method("segments", |_, this: &LuaIpv6, _: ()| {            Ok(this.0.octets().to_vec())        });        methods.add_method("is_unspecified", |_, this: &LuaIpv6, _: ()| {            Ok(this.0.is_unspecified())        });        methods.add_method("is_loopback", |_, this: &LuaIpv6, _: ()| {            Ok(this.0.is_loopback())        });        methods.add_method("is_multicast", |_, this: &LuaIpv6, _: ()| {            Ok(this.0.is_multicast())        });        methods.add_method("octets", |_, this: &LuaIpv6, _: ()| {            Ok(this.0.octets().to_vec())        });        methods.add_method("to_ipv4", |_, this: &LuaIpv6, _: ()| {            Ok(this.0.to_ipv4().map(LuaIpv4))        });        methods.add_meta_method(LuaMetaMethod::ToString, |_, this, _: ()| {            Ok(this.0.to_string())        });    }}pub fn init(lua: &Lua) -> crate::Result<()> {    let module = lua.create_table()?;    module.set("new", lua.create_function( |_, ip: String| {        ip.parse().map(LuaIpv6).map_err(LuaError::external)    })? )?;    module.set("from_table", lua.create_function( |_, ip: Vec<u16>| {        if ip.len() != 8 {            return Ok(None);        }        let (a, b, c, d, e, f, g, h) = (            ip.get(0).unwrap_or(&0),            ip.get(1).unwrap_or(&0),            ip.get(2).unwrap_or(&0),            ip.get(3).unwrap_or(&0),            ip.get(4).unwrap_or(&0),            ip.get(5).unwrap_or(&0),            ip.get(6).unwrap_or(&0),            ip.get(7).unwrap_or(&0));        Ok(Some(LuaIpv6(Ipv6Addr::new(*a, *b, *c, *d, *e, *f, *g, *h))))    })? )?;    lua.globals().set("ipv6", module)?;    Ok(())}