lua-uuid is a lightweight, native library for Lua (5.1 and newer) to deal with Universally Unique Id (UUID).
- On Linux and BSD, it uses
libuuid
to generate UUIDs; - On Windows, it uses the WINAPI
rpcrt4
library; - On macOS / iOS, it uses the
CoreFoundation
framework.
Note
lua-uuid
is implemented in pure ANSI C, and also compiles as C++.
Important
On Linux and BSD, lua-uuid
depends on libuuid
:
-
On Debian-based (e.g: Ubuntu) distributions:
sudo apt install -y uuid-dev
-
On RedHat-based (e.g: Fedora) distributions:
sudo dnf install libuuid-devel
-
On BSD-based (e.g: FreeBSD) distributions:
pkg install e2fsprogs-libuuid
Assuming that LuaRocks is properly installed and configured on your system, execute the following command:
luarocks install lua-uuid
-
Generate GUIDs / UUIDs and print them
-- load the library local uuid = require("lua-uuid") -- generate UUIDs local id1 = uuid.new() local id2 = uuid.new() -- print each UUID print(id1) print(id2)
-
Generate GUIDs / UUIDs and get their string representations
-- load the library local uuid = require("lua-uuid") -- generate UUIDs local id1 = uuid.new() local id2 = uuid.new() -- get their string representations local s1 = tostring(id1) local s2 = tostring(id2) assert(type(s1) == 'string') assert(type(s2) == 'string') -- print each string print(s1) print(s2)
-- load the library
local uuid = require("lua-uuid")
-- parse UUIDs from string
local id1 = uuid.parse("33e4a9f2-8141-4734-a638-f2d08ee7d070")
local id2 = uuid.parse("653096e0-b09f-4626-b65e-07d4e21c70c6")
-- print each UUID
print(id1)
print(id2)
-- load the library
local uuid = require("lua-uuid")
-- generate UUIDs
local id1 = uuid.new()
local id2 = uuid.new()
-- print each UUID
print(id1)
print(id2)
-- prints false
print(id1 == id2)
-- prints true
print(id1 == id1)
-- prints true
print(id2 == id2)
-- load the library
local uuid = require("lua-uuid")
-- generate UUIDs
local id1 = uuid.new()
local id2 = uuid.new()
-- prints false
print(id1:isnil())
print(id2:isnil())
-- parse UUID
local id3 = uuid.parse("00000000-0000-0000-0000-000000000000")
-- prints true
print(id3:isnil())
- Description: Generates a new GUID / UUID
- Signature:
new()
- return:
(userdata)
- return:
- Usage: See here
- Description: Parses a GUID / UUID from a string value
- Signature:
parse(value)
- value (string): the string to be parsed
- return:
(userdata)
- Usage: See here
- Description: Verifies whether the GUID / UUID is considered null or not.
Note
a GUID / UUID is considered null when its string representation is equal to 00000000-0000-0000-0000-000000000000
.
- Signature:
instance:isnil()
- instance (userdata): the GUID / UUID instance to check for nullity
- return:
(boolean)
- Usage: See here
- Description: Compares two GUIDs / UUIDs for equality
- Signature:
left == right
- left (any): the left-side element
- right (any): the right-side element
- return:
(boolean)
- Usage: See here
- Description: Converts the GUID / UUID to string
- Signature:
tostring(value)
- value (userdata): the GUID / UUID to perform the conversion
- return:
(string)
- Usage: See here
- v0.0.6:
Important
This is a bug-fix release that fixed a buffer overflow in the binding of libuuid
. Users running older versions must upgrade as soon as possible to avoid potential exploits.
- v0.0.5:
- Adhering to C89;
- Added CI job to make sure that this library conforms to C89;
- Added another CI job to assert that this library builds fine as C++ code;
- Linting rockspecs on CI;
- Minor changes on the makefile for macOS / iOS;
- The naming format for the published rockspecs changed from
vX.Y.Z-0
tovX.Y.Z-1
.
- v0.0.4:
- Added support for BSD (e.g: FreeBSD, NetBSD, OpenBSD and DragonFly);
- Moved
#include <lua.h>
andLUA_UUID_EXPORT
macro definition to outside of__cplusplus
declarations onlua-uuid.h
.
- v0.0.3:
- Changed to throw error when
lua_newuserdata
returnsNULL
; - Added macro
LUA_UUID_BUILD_SHARED
toCFLAGS_EXTRA
on macos; - Changed
luajit-master
toluajit
on CI when testing forLuaJIT
; - Added print statements on tostring.lua sample;
- Removed build / testing from CI for x86 packages on MSYS2;
- Added documentation for static, instance and metamethods to the README.
- Changed to throw error when
- v0.0.2:
- Fixed syntax issue in the rockspec lua-uuid-0.0.1-0.rockspec
- Add CMake as build system