Lua中文语言编程源码-第七节,更改lstrlib.c 标准字符串操作与模式匹配库函数, 使Lua加载中文库关键词(标准字符串操作与模式匹配库相关)

源码已经更新在CSDN的码库里:

git clone https://gitcode.com/funsion/CLua.git

在src文件夹下的lstrlib.c 标准字符串操作与模式匹配库函数,表明这个C源文件实现了Lua的标准字符串操作与模式匹配库,即提供了与字符串操作相关的API和功能实现。

增加中文版stringmetamethods 元方法列表,保留英文版stringmetamethods元方法列表。

原始的代码为:
static const luaL_Reg stringmetamethods[] = {
  {"__add", arith_add},
  {"__sub", arith_sub},
  {"__mul", arith_mul},
  {"__mod", arith_mod},
  {"__pow", arith_pow},
  {"__div", arith_div},
  {"__idiv", arith_idiv},
  {"__unm", arith_unm},
  {"__index", NULL},  /* placeholder */
  {NULL, NULL}
};
更改成以下代码:
/* 定义字符串的元方法列表 */
static const luaL_Reg stringmetamethods[] = {
  {"__add", arith_add},
  {"__加",arith_add},
  {"__sub", arith_sub},
  {"__减",arith_sub},
  {"__mul", arith_mul},
  {"__乘",arith_mul},
  {"__mod", arith_mod},
  {"__取模",arith_mod},
  {"__pow", arith_pow},
  {"__乘方",arith_pow},
  {"__div", arith_div},
  {"__整除",arith_div},
  {"__idiv", arith_idiv},
  {"__向下整除", arith_idiv},
  {"__unm", arith_unm},
  {"__负号", NULL},
  {"__index", NULL}, 
  {"__索引", NULL} ,/* 占位符 */
  {NULL, NULL}
};
原始的代码为:
static const luaL_Reg strlib[] = {
  {"byte", str_byte},
  {"char", str_char},
  {"dump", str_dump},
  {"find", str_find},
  {"format", str_format},
  {"gmatch", gmatch},
  {"gsub", str_gsub},
  {"len", str_len},
  {"lower", str_lower},
  {"match", str_match},
  {"rep", str_rep},
  {"reverse", str_reverse},
  {"sub", str_sub},
  {"upper", str_upper},
  {"pack", str_pack},
  {"packsize", str_packsize},
  {"unpack", str_unpack},
  {NULL, NULL}
};

更改成以下代码:

/* strlib 结构体定义了字符串库中所有函数的映射关系 */
static const luaL_Reg strlib[] = {
  {"byte", str_byte}, /* byte函数用于提取字符串中的一个或多个字节 */
  {"char", str_char}, /* char函数根据给定的数值创建一个字符串 */
  {"dump", str_dump}, /* dump函数将函数转换为二进制字符串 */
  {"find", str_find}, /* find函数在字符串中查找子字符串 */
  {"format", str_format}, /* format函数根据指定的格式创建一个字符串 */
  {"gmatch", gmatch}, /* gmatch函数返回一个迭代器,用于在字符串中进行全局正则表达式匹配 */
  {"gsub", str_gsub}, /* gsub函数在字符串中替换所有匹配的子串 */
  {"len", str_len}, /* len函数返回字符串的长度 */
  {"lower", str_lower}, /* lower函数将字符串中的大写字母转换为小写字母 */
  {"match", str_match}, /* match函数在字符串中进行模式匹配 */
  {"rep", str_rep}, /* rep函数重复字符串一定次数 */
  {"reverse", str_reverse}, /* reverse函数反转字符串 */
  {"sub", str_sub}, /* sub函数提取字符串的子串 */
  {"upper", str_upper}, /* upper函数将字符串中的小写字母转换为大写字母 */
  {"pack", str_pack}, /* pack函数将数据打包成二进制格式 */
  {"packsize", str_packsize}, /* packsize函数返回给定格式数据打包后的大小 */
  {"unpack", str_unpack}, /* unpack函数从二进制字符串中解包数据 */
/* 中文注释部分为对应的中文函数名,便于中文用户理解 */
  {"字节", str_byte},
  {"字符", str_char},
  {"转储", str_dump},
  {"查找", str_find},
  {"格式", str_format},
  {"匹配", gmatch},
  {"替换", str_gsub},
  {"长度", str_len},
  {"小写", str_lower},
  {"配对", str_match},
  {"重复", str_rep},
  {"倒序", str_reverse},
  {"子串", str_sub},
  {"大写", str_upper},
  {"打包", str_pack},
  {"包尺寸", str_packsize},
  {"拆包", str_unpack},
  {NULL, NULL} /* 结束标志 */
};

为了保证中英文 函数都可以加载,以便你可以复制英文原码来进行更改。所以保留了英文版 函数名列表,这样就能使用两种文的函数。

{"byte", str_byte}, // 字节

{"字节", str_byte}, // 和byte相同,但是使用中文名称

其实它们都是加载同样的库名,算是加载了2次,以Lua内部算法,应该只会加载一次。

更改完之后,同样需要重新编译Lua的源码,实现以上列出的关键词的中文化。

注意,在Window系统下编译Lua, 最好将所有Lua的源码,重新保存成ANSI格式的文件,刚下载的默认的源码会是UTF-8格式的。

这个事情说三遍,

1,不然就会出现,Window下的UTF-8源码可编译,但Shell里的中文输出会乱码。

2,要不然就是Window的ANSI源码不可编译(假如你没做以上步骤),

3,如果是用ANSI格式的源码编译的Lua.exe,对应的,你在Window下写的Lua程序也是需要保存成ANSI格式的。这样就可以在Shell里输出正确的中文显示。

相关推荐
@东辰6 分钟前
【golang-技巧】-自定义k8s-operator-by kubebuilder
开发语言·golang·kubernetes
乐悠小码12 分钟前
数据结构------队列(Java语言描述)
java·开发语言·数据结构·链表·队列
史努比.14 分钟前
Pod控制器
java·开发语言
敲敲敲-敲代码23 分钟前
游戏设计:推箱子【easyx图形界面/c语言】
c语言·开发语言·游戏
ROC_bird..32 分钟前
STL - vector的使用和模拟实现
开发语言·c++
MavenTalk37 分钟前
Move开发语言在区块链的开发与应用
开发语言·python·rust·区块链·solidity·move
simple_ssn1 小时前
【C语言刷力扣】1502.判断能否形成等差数列
c语言·算法·leetcode
ahadee1 小时前
蓝桥杯每日真题 - 第10天
c语言·vscode·算法·蓝桥杯
XiaoLeisj1 小时前
【JavaEE初阶 — 多线程】生产消费模型 & 阻塞队列
java·开发语言·java-ee
2401_840192271 小时前
python基础大杂烩
linux·开发语言·python