Path: blob/main/sys/contrib/openzfs/module/lua/lstring.h
48383 views
// SPDX-License-Identifier: MIT1/*2** $Id: lstring.h,v 1.49.1.1 2013/04/12 18:48:47 roberto Exp $3** String table (keep all strings handled by Lua)4** See Copyright Notice in lua.h5*/67#ifndef lstring_h8#define lstring_h910#include "lgc.h"11#include "lobject.h"12#include "lstate.h"131415#define sizestring(s) (sizeof(struct TString)+((s)->len+1)*sizeof(char))1617#define sizeudata(u) (sizeof(union Udata)+(u)->len)1819#define luaS_newliteral(L, s) (luaS_newlstr(L, "" s, \20(sizeof(s)/sizeof(char))-1))2122#define luaS_fix(s) l_setbit((s)->tsv.marked, FIXEDBIT)232425/*26** test whether a string is a reserved word27*/28#define isreserved(s) ((s)->tsv.tt == LUA_TSHRSTR && (s)->tsv.extra > 0)293031/*32** equality for short strings, which are always internalized33*/34#define eqshrstr(a,b) check_exp((a)->tsv.tt == LUA_TSHRSTR, (a) == (b))353637LUAI_FUNC unsigned int luaS_hash (const char *str, size_t l, unsigned int seed);38LUAI_FUNC int luaS_eqlngstr (TString *a, TString *b);39LUAI_FUNC int luaS_eqstr (TString *a, TString *b);40LUAI_FUNC void luaS_resize (lua_State *L, int newsize);41LUAI_FUNC Udata *luaS_newudata (lua_State *L, size_t s, Table *e);42LUAI_FUNC TString *luaS_newlstr (lua_State *L, const char *str, size_t l);43LUAI_FUNC TString *luaS_new (lua_State *L, const char *str);444546#endif474849