(未完成,待修改)
一、Lua5.1相关资源
下载见:
http://luabinaries.sourceforge.net/download.html
在线版:
http://www.lua.org/source/5.1/
关于它的代码有一个阅读顺序,可以参考这篇文章:
http://www.reddit.com/comments/63hth/ask_reddit_which_oss_codebases_out_there_are_so/c02pxbp
Lua语言的Wiki条目
http://en.wikipedia.org/wiki/Lua_(programming_language)
二、lua.c概述
lua.c实现Lua独立解析器。
它在官网中被分类为Interpreter。
http://www.lua.org/source/5.1/lua.c.html
总行数391行。
三、lua.c头文件
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "lua.h"
#include "lauxlib.h"
#include "lualib.h"
四、lua.c宏
1. #define lua_c
lua_c是lua.c的缩写,用于打开luaconf.c第222-293行的独立程序宏配置。
由于VC的宏展开问题,luaconf.c的那些宏可能无法直接用右键查找。
2. #define notail(x) {if ((x)[2] != '\0') return -1;}
在静态方法collectargs中检查控制台命令行的单个字符串参数在结尾没有多余字符。
用于诊断x的字符串长度为1,否则直接退出命令行解析。
五、静态全局变量
1. static lua_State *globalL = NULL;
独立解析器的全局Lua状态机。
它允许laction方法可以直接读取状态数据。
它被laction读取,被pmain修改。
全局的Lua虚拟机指针
由于是在signal指定的句柄函数laction中使用,所以需要这样处理。
2. static const char *progname = LUA_PROGNAME;
当前的程序名(短名,默认为lua),注意它的指针值可以被改变(但字符串是常量)。
它被dotty和pmain修改,被print_usage、report和dotty读取。
六、静态全局方法
1. static void lstop (lua_State *L, lua_Debug *ar) {
在出现signal中断时进行出错处理的lua钩子。
只是简单地输出字符串"interrupted!"
2. static void laction (int i) {
signal中断的处理句柄。
它在docall中被注册。
确保如果在lstop之前出现其他SIGINT,就直接结束进程(默认动作)
然后用lua_sethook挂钩子lstop。
3. static void print_usage (void) {
在stderr控制台输出中输出lua解析器的用法。
4. static void l_message (const char *pname, const char *msg) {
公共的信息输出函数。
5. static int report (lua_State *L, int status) {
运行完pmain后取出栈顶的出错信息然后用l_message输出。
6. static int traceback (lua_State *L) {
出错处理的C函数,间接调用Lua标准库里的debug.traceback函数
首先判断栈顶是不是出错信息的字符串message。
然后调用debug.traceback(message, 2)输出当前Lua状态机的堆栈回溯。
7. static int docall (lua_State *L, int narg, int clear) {
Lua保护模式运行VM(已经载入脚本后)
先确保在出错时Lua状态机调用traceback这个C函数。
然后用lua_pcall启动虚拟机。
8. static void print_version (void) {
用l_message输出版本信息
9. static int getargs (lua_State *L, char **argv, int n) {
把argv字符串数组压入L栈中,变成一个Lua表。
10. static int dofile (lua_State *L, const char *name) {
执行Lua脚本文件。
首先用luaL_loadfile加载(编译)文件,然后用docall执行。
最后用report报告返回的状态值。
11. static int dostring (lua_State *L, const char *s, const char *name) {
执行Lua脚本字符串。
类似dofile,不过用luaL_loadbuffer代替luaL_loadfile。
12. static int dolibrary (lua_State *L, const char *name) {
用Lua标准库的require函数加载脚本。
13. static const char *get_prompt (lua_State *L, int firstline) {
从Lua全局变量_PROMPT和_PROMPT2获取首行或次行的命令行提示符,
如果没有定义,默认是
#define LUA_PROMPT "> "
#define LUA_PROMPT2 ">> "
它们定义在luaconf.h中的#if defined(lua_c) || defined(luaall_c)内。
14. static int incomplete (lua_State *L, int status) {
在状态机出现语法出错后判断是否遇到<eof>。
用于交互模式输入时的多行预测(有可能当前还没有输入完)。
15. static int pushline (lua_State *L, int firstline) {
交互模式,读取stdin的一行,无循环。
16. static int loadline (lua_State *L) {
交互模式,读入stdin的一行,然后循环读取余下未输入完的内容。
17. static void dotty (lua_State *L) {
进入交互模式。
18. static int handle_script (lua_State *L, char **argv, int n) {
注入Lua全局变量arg,然后执行脚本或执行stdin的输入内容。
19. static int collectargs (char **argv, int *pi, int *pv, int *pe) {
第一次命令行扫描,获取大部分选项。
20. static int runargs (lua_State *L, char **argv, int n) {
第二次命令行扫描,用Lua虚拟机执行-e(字符串)或-l(文件)的内容
21. static int handle_luainit (lua_State *L) {
读取环境变量LUA_INIT指定的脚本(@开头)或命令
22. static int pmain (lua_State *L) {
把主入口实现为Lua的C函数,在Lua虚拟机上注册运行。
它依次执行以下操作,
并且把返回值保存到其userdata参数(类型为Smain)的status域中:
* 取出第一个参数(即lua_cpcall的第三参数)。
* 把L保存到全局变量globalL。
* 设置progname。
* 关闭GC。
* 打开所有标准库(可能使用标准库里的debug和require)。
* 执行GC。
* 执行初始化操作和命令行选项提取:handle_luainit、collectargs、print_version、runargs。
* 根据获取的选项选择执行handle_script(执行脚本)、dotty(交互模式)、执行stdin内容。
七、全局结构体
1. struct Smain {
int argc;
char **argv;
int status;
};
在main和pmain中使用。
它是pmain的C函数参数。
它在pmain中作为userdata被读出。
在main中,它是一个结构体局部变量的类型,其地址传给lua_cpcall的第三参数。
argc域和argv域是命令行参数(避免全局读)。
status域是最近一次lua库函数的返回值,非0表示有错误。
八、公共全局方法
1. int main (int argc, char **argv) {
解析器入口。argc是参数个数,argv是字符串数组,长度为argc。
作为C函数的入口被控制台程序执行。
wmain.c把__argc和__argv传递给这个函数,模拟控制台参数。
它的作用是:
* 创建Lua状态,程序唯一的数据交互中心。
* 创建Smain结构体对象,保存argc和argv。
* 用lua_cpcall执行pmain这个C函数,然后报告结果和关闭状态机。
* 根据lua_cpcall的返回值和Smain结构体对象的状态值退出程序
九、值得观察的关键代码
1. docall
观察Lua脚本文件或字符串执行前后的状态变化。
2. pmain
观察两次命令行扫描后的变化。
分享到:
相关推荐
碳交易机制下考虑需求响应的综合能源系统优化运行模型及有效性分析,碳交易机制下需求响应的综合能源系统优化运行策略探索:低碳减排的实践路径,碳交易机制下考虑需求响应的综合能源系统优化运行 综合能源系统是实现“双碳”目标的有效途径,为进一步挖掘其需求侧可调节潜力对碳减排的作用,提出了一种碳交易机制下考虑需求响应的综合能源系统优化运行模型。 首先,根据负荷响应特性将需求响应分为价格型和替代型 2 类,分别建立了基于价格弹性矩阵的价格型需求响应模型,及考虑用能侧电能和热能相互转的替代型需求响应模型; 其次,采用基准线法为系统无偿分配碳排放配额,并考虑燃气轮机和燃气锅炉的实际碳排放量,构建一种面向综合能源系统的碳交易机制; 最后,以购能成本、碳交易成本及运维成本之和最小为目标函数,建立综合能源系统低碳优化运行模型,并通过 4 类典型场景对所提模型的有效性进行了验证。 通过对需求响应灵敏度、燃气轮机热分配比例和不同碳交易价格下系统的运行状态分析发现,合理分配价格型和替代型需求响应及燃气轮机产热比例有利于提高系统运行经济性,制定合理的碳交易价格可以实现系统经济性和低碳性协同。 关键词: 碳交易机制;
MATLAB演示程序:涡旋拉盖尔-高斯光束的横模特性与拓扑荷数及径向指数的影响分析,涡旋拉盖尔高斯光束MATLAB演示程序,涡旋拉盖尔高斯光束横模MATLAB演示程序 拓扑荷数l : 决定了光束的轨道角动量。 具有不同拓扑荷数的涡旋拉盖尔 - 高斯光束携带不同大小的轨道角动量。 影响光束的相位分布。 当l≠0时,光束具有螺旋相位结构,即相位随着角向坐标以的周期变化。 可以通过光学方法进行调控和测量,在量子信息处理、光学镊子等领域有重要应用。 径向指数p : 表示径向方向上的节点数。 p值越大,光束在径向方向上的能量分布变化越复杂,会出现更多的节点和暗区。 与拓扑荷数一起决定了光束的整体形状和强度分布。 ,涡旋拉盖尔-高斯光束; 拓扑荷数l; 径向指数p; MATLAB演示程序; 螺旋相位结构; 角向坐标变化; 轨道角动量。,MATLAB演示涡旋拉盖尔-高斯光束横模:拓扑荷数与径向指数的影响
PFC5.0算例代码解析:含矿物岩石材料,PFC5.0代码解析:探究由三种矿物构成的岩石与类岩石材料在GBM条件下的单轴压缩2D模拟算例,助力学习与技能提升,PFC5.0代码,含三种矿物组成的岩石或者类岩石材料,GBM,单轴压缩2d,算例代码仅供学习以及提升 ,关键词:PFC5.0代码;三种矿物组成;岩石或类岩石材料;GBM;单轴压缩2d;算例代码;学习;提升; 关键词:PFC5.0; 矿物组成; 岩石/类岩石; GBM; 单轴压缩; 算例学习; 提升;,PFC5.0模拟:含三种矿物岩石材料单轴压缩算例
Matlab三维A*算法详解:Astar三维路径规划及自定义地图、障碍物与代函数设定指南,Matlab三维A星算法路径规划工具箱,matlab三维A*算法 Astar三维路径规划 超详细注释 可自定义地图 自定义障碍物栅格数量和颜色 路径颜色 修改代价函数 预设5种常见评价指标 可 ,matlab; A*算法; 三维路径规划; 详细注释; 自定义地图; 自定义障碍物; 栅格数量和颜色; 路径颜色; 代价函数; 评价指标。,Matlab三维A*算法:超详细注释,自定义地图与障碍物路径规划
win32汇编环境,对话框中使用树形视图示例三
**基于SVPWM与死区补偿的PMSM dq轴电感离线辨识方法:高频注入法与电流极性分析**,SVPWM死区补偿技术下的PMSM电感离线辨识方法研究——基于电流极性与高频注入法的高效识别策略,SVPWM+死区补偿(基于电流极性)+高频注入法辨识PMSM的dq轴电感(离线辨识) 1.模型的中的电机,为采用自建的电机模型 2.适用于spmsm和ipmsm, 3.基于两相静止坐标轴电压注入,可通过设置合理的电压幅值和频率,在静止状态下准确辨识电感(更电机后,由于电机额定电压与转速的不同,可能需要调整原有的高频注入参数以获取满意的辨识效果)(不适用在线辨识) 4.死区补偿,是基于电流矢量极性判断 5.可进行有、无死区补偿下的辨识效果对比(资料中包含多个模型,为笔者当初在有无死区补偿,不同设置条件下的进行参数辨识效果对比,以及模型中包含的一些注释,或可供参考) 6.如果模型运行提示Ts未定义,可在命令行窗口输入Ts=0.0001,以解决该报错 7.模型与参考的期刊lunwen一一对应,可互相印证,其建模方式和思想,适合小白入门学习(不建议初学者无参考lunwen的模型) ,SVPWM; 死区补偿
关于电容电流反馈在有源阻尼谐振抑制及SVPWM策略中的运用及其结合单电流环与中点电位平衡控制的综合研究(参考《某领域文献》《另一些领域的研究》等),电容电流反馈SVPWM控制,电容电流反馈有源阻尼谐振抑制+SVPWM 含: [1]有源阻尼谐振抑制+SVPWM [2]单电流环控制 [3]中点电位平衡控制 提供相关参考文献 ,有源阻尼谐振抑制; SVPPM; 电容电流反馈; 谐振抑制; 中点电位平衡控制; 文献暂无。,电容电流反馈结合SVPWM与有源阻尼谐振抑制的研究与实现
易福门RFID:高效控制标准块,多重调用易管理,轻松修改编号与硬件标识符,RFID控制标准块多重调用便捷设,易福门RFID控制标准块,可以多重调用,只需要更改编号和硬件标识符。 ,易福门RFID;控制标准块;多重调用;编号;硬件标识符,易福门RFID标准控制块:多调高效,只需更改编号和硬件标识
TypeScript 基础语法,本人亲自整理的资料
基于博途西门子PLC的多种液体混合控制系统设计与实现:一份包含全流程的电子程序资料,基于博途西门子PLC的多种液体混合控制系统设计与实现:一份包含全流程的电子程序资料,基于plc多种液体混合控制系统设计 博途 西门子plc 本为电子程序资料 一、包含内容: ①西门子PLC程序+HMI仿真工程 (博途V14或以上) 一份; ②配套有IO点表+PLC接线图+主电路图+控制流程图 (CAD源文件可编辑); ,基于plc多种液体混合控制系统设计; 博途V14; 西门子plc; 混合控制; 控制系统设计; 程序仿真; IO点表; PLC接线图; 主电路图; 控制流程图。,基于博途V14的西门子PLC多种液体混合控制系统设计资料
寻找热泵最佳压力的优化算法 输入Cop和高压值,以找到最大化Cop的最佳高压 Optimization algorithm to find optimal pressure of heat pump Inputs of Cop and high pressure values to find optimal high pressure that maxes out COP
三相变压器空载合闸励磁涌流仿真研究:特点分析与观察,变压器空载合闸:三相励磁涌流仿真研究及特性分析,【1】变压器空载合闸时励磁涌流的仿真 仿真目的:分析三相变压器空载合闸过程中,观察励磁涌流的特点 仿真结果:励磁涌流的特点和分析过程可详细咨询。 ,励磁涌流;变压器空载合闸;仿真目的;分析特点;仿真结果。,变压器空载合闸仿真:励磁涌流分析
孪生模型环境安装及其训练方法
更多毕业设计https://cv2022.blog.csdn.net/article/details/124463185
315MHz与433MHz无线遥控接收解码Keil源程序及AD格式电路图详解,315MHz和433MHz无线遥控接收解码源程序,附带Keil源程序和AD格式电路图,315 433MHZ无线遥控接收解码源程序 Keil源程序 含AD格式电路图 ,315MHz无线遥控接收; 433MHz无线解码源程序; Keil源程序; AD格式电路图,基于Keil的315/433MHz无线遥控解码源程序解析及AD格式电路图详解
MATLAB滚动轴承故障诊断程序:采用西楚凯斯大学数据,基于变分模态分解(VMD)算法与包络谱分析的故障诊断比较实现,MATLAB滚动轴承故障诊断程序:采用西楚凯斯大学数据,基于变分模态分解(VMD)算法与包络谱分析的故障诊断比较实现,MATLAB滚动轴承故障诊断程序:采用西楚凯斯大学数据,首先通过变分模态分解(VMD)算法处理,而后分别通过包络谱分析实现故障诊断 ps.通过尖峰对应的频率与计算出的故障频率比较,实现故障诊断 ,核心关键词:MATLAB; 滚动轴承故障诊断; 西楚凯斯大学数据; 变分模态分解(VMD)算法; 包络谱分析; 故障频率比较。,MATLAB基于VMD算法的滚动轴承故障诊断程序:西楚凯斯大学数据包络谱分析
个人ii c的一个说明的资料
更多毕业设计https://cv2022.blog.csdn.net/article/details/124463185
python语言,窗口形式 单机的形式,CS模式 mysql 1.重点是算法比较 各个算法参数 产生的图和数据足够了 做影评参照 2.自适应svm 既然加了自适应 那它比svm的优势在哪,自适应也是逐步完善的算法 拿新的和旧的比较一下 3.分析结果显示 调图标库即可,条状图 饼状图之类的 不是网站
广西壮族自治区信息中心广西人工智能产业发展白皮书2024年37页.pdf