From 891050cb3d84f0592f8fc4c4345a86613fc12673 Mon Sep 17 00:00:00 2001 From: zhangjun <2281979437@qq.com> Date: Thu, 11 Aug 2016 18:53:30 +0800 Subject: [PATCH] =?UTF-8?q?=E5=9C=A8msh=E5=92=8Cfnish=E4=B8=AD=E5=9D=87?= =?UTF-8?q?=E5=8F=AF=E8=B0=83=E7=94=A8lua=EF=BC=8C=E5=8F=AF=E5=B0=86lua?= =?UTF-8?q?=E8=84=9A=E6=9C=AC=E4=BD=9C=E4=B8=BA=E5=8F=82=E6=95=B0=E4=BC=A0?= =?UTF-8?q?=E5=85=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../external/lua/applications/lua_in_finsh.c | 38 +++++++++++++++---- 1 file changed, 30 insertions(+), 8 deletions(-) diff --git a/components/external/lua/applications/lua_in_finsh.c b/components/external/lua/applications/lua_in_finsh.c index 9fe38b098..ecf9700d3 100644 --- a/components/external/lua/applications/lua_in_finsh.c +++ b/components/external/lua/applications/lua_in_finsh.c @@ -21,7 +21,7 @@ rt_err_t lua_rx_ind(rt_device_t dev, rt_size_t size) return RT_EOK; } -void finsh_lua(void *parameter) +void finsh_lua(int argc, char **argv) { rt_err_t (*rx_indicate)(rt_device_t dev, rt_size_t size); @@ -34,9 +34,6 @@ void finsh_lua(void *parameter) rt_device_set_rx_indicate(dev4lua.device, lua_rx_ind); { - int argc = 1; - char *argv[] = {"lua", NULL}; - /* run lua interpreter */ lua_main(argc, argv); } @@ -45,9 +42,8 @@ void finsh_lua(void *parameter) rt_device_set_rx_indicate(dev4lua.device, rx_indicate); } -static void lua(void) +static void lua(void *parameters) { - rt_thread_t lua_thread; const char* device_name = finsh_get_device(); rt_device_t device = rt_device_find(device_name); if (device == RT_NULL) @@ -56,6 +52,7 @@ static void lua(void) return; } dev4lua.device = device; + char *argv[] = {"lua", parameters, NULL}; #if 0 /* Run lua interpreter in separate thread */ @@ -71,10 +68,35 @@ static void lua(void) } #else /* Directly run lua interpreter in finsh */ - finsh_lua(0); + finsh_lua(2, argv); #endif } -FINSH_FUNCTION_EXPORT(lua, lua interpreter) +FINSH_FUNCTION_EXPORT(lua, lua interpreter); + +static void lua_msh(int argc, char **argv) +{ + const char* device_name = finsh_get_device(); + rt_device_t device = rt_device_find(device_name); + if (device == RT_NULL) + { + rt_kprintf("%s not find\n", device_name); + return; + } + dev4lua.device = device; + + /*prepare parameters*/ + int i; + char **arg = rt_malloc((argc+1)*sizeof(char*)); + for (i=0; i