24#if !defined(LUA_PROMPT)
25#define LUA_PROMPT "> "
26#define LUA_PROMPT2 ">> "
29#if !defined(LUA_PROGNAME)
30#define LUA_PROGNAME "lua"
33#if !defined(LUA_MAXINPUT)
34#define LUA_MAXINPUT 512
37#if !defined(LUA_INIT_VAR)
38#define LUA_INIT_VAR "LUA_INIT"
41#define LUA_INITVARVERSION LUA_INIT_VAR LUA_VERSUFFIX
48#if !defined(lua_stdin_is_tty)
50#if defined(LUA_USE_POSIX)
53#define lua_stdin_is_tty() isatty(0)
55#elif defined(LUA_USE_WINDOWS)
60#define lua_stdin_is_tty() _isatty(_fileno(stdin))
65#define lua_stdin_is_tty() 1
78#if !defined(lua_readline)
80#if defined(LUA_USE_READLINE)
82#include <readline/readline.h>
83#include <readline/history.h>
84#define lua_readline(L,b,p) ((void)L, ((b)=readline(p)) != NULL)
85#define lua_saveline(L,line) ((void)L, add_history(line))
86#define lua_freeline(L,b) ((void)L, free(b))
90#define lua_readline(L,b,p) \
91 ((void)L, fputs(p, stdout), fflush(stdout), \
92 fgets(b, LUA_MAXINPUT, stdin) != NULL)
93#define lua_saveline(L,line) { (void)L; (void)line; }
94#define lua_freeline(L,b) { (void)L; (void)b; }
132 if (badoption[1] ==
'e' || badoption[1] ==
'l')
137 "usage: %s [options] [script [args]]\n"
138 "Available options are:\n"
139 " -e stat execute string 'stat'\n"
140 " -i enter interactive mode after executing 'script'\n"
141 " -l name require library 'name' into global 'name'\n"
142 " -v show version information\n"
143 " -E ignore environment variables\n"
144 " -- stop handling options\n"
145 " - stop handling options and execute stdin\n"
155static void l_message (
const char *pname,
const char *msg) {
206 signal(SIGINT, SIG_DFL);
228 if (script == argc) script = 0;
229 narg = argc - (script + 1);
231 for (i = 0; i < argc; i++) {
282#define EOFMARK "<eof>"
283#define marklen (sizeof(EOFMARK)/sizeof(char) - 1)
317 if (l > 0 && b[l-1] ==
'\n')
319 if (firstline && b[0] ==
'=')
409 while ((status =
loadline(L)) != -1) {
430 for (i = 1; i <= n; i++)
439 const char *fname = argv[0];
440 if (strcmp(fname,
"-") == 0 && strcmp(argv[-1],
"--") != 0)
468 for (i = 1; argv[i] !=
NULL; i++) {
470 if (argv[i][0] !=
'-')
472 switch (argv[i][1]) {
474 if (argv[i][2] !=
'\0')
481 if (argv[i][2] !=
'\0')
488 if (argv[i][2] !=
'\0')
495 if (argv[i][2] ==
'\0') {
497 if (argv[i] ==
NULL || argv[i][0] ==
'-')
516 for (i = 1; i < n; i++) {
517 int option = argv[i][1];
519 if (option ==
'e' || option ==
'l') {
521 const char *extra = argv[i] + 2;
522 if (*extra ==
'\0') extra = argv[++i];
524 status = (option ==
'e')
525 ?
dostring(L, extra,
"=(command line)")
527 if (status !=
LUA_OK)
return 0;
537 const char *init = getenv(
name + 1);
540 init = getenv(
name + 1);
543 else if (init[0] ==
'@')
560 if (argv[0] && argv[0][0])
progname = argv[0];
573 if (!(args &
has_E)) {
584 else if (script == argc && !(args & (
has_e |
has_v))) {
596int main (
int argc,
char **argv) {
600 l_message(argv[0],
"cannot create state: not enough memory");
610 return (result && status ==
LUA_OK) ? EXIT_SUCCESS : EXIT_FAILURE;
LUA_API void lua_pushstring(lua_State *L, const char *s)
LUA_API void lua_concat(lua_State *L, int n)
LUA_API const char * lua_pushfstring(lua_State *L, const char *fmt,...)
LUA_API void lua_setfield(lua_State *L, int idx, const char *k)
LUA_API int lua_toboolean(lua_State *L, int idx)
LUA_API void lua_pushboolean(lua_State *L, int b)
LUA_API const char * lua_tolstring(lua_State *L, int idx, size_t *len)
LUA_API int lua_type(lua_State *L, int idx)
LUA_API void lua_createtable(lua_State *L, int narray, int nrec)
LUA_API void lua_pushlightuserdata(lua_State *L, void *p)
LUA_API void lua_rawseti(lua_State *L, int idx, int n)
LUA_API void * lua_touserdata(lua_State *L, int idx)
LUA_API void lua_pushlstring(lua_State *L, const char *s, size_t len)
LUA_API void lua_settop(lua_State *L, int idx)
LUA_API void lua_pushinteger(lua_State *L, lua_Integer n)
LUA_API void lua_rawgeti(lua_State *L, int idx, int n)
LUA_API int lua_gettop(lua_State *L)
LUALIB_API void luaL_checkstack(lua_State *L, int space, const char *mes)
LUALIB_API int luaL_error(lua_State *L, const char *fmt,...)
LUALIB_API lua_State * luaL_newstate(void)
LUALIB_API int luaL_callmeta(lua_State *L, int obj, const char *event)
#define luaL_typename(L, i)
LUA_API int lua_sethook(lua_State *L, lua_Hook func, int mask, int count)
LUALIB_API void luaL_openlibs(lua_State *L)
LUA_API void lua_close(lua_State *L)
static void print_usage(void)
#define lua_pushcfunction(L, f)
#define LUA_REGISTRYINDEX
#define lua_pushliteral(L, s)
#define lua_setglobal(L, s)
#define lua_getglobal(L, s)
#define lua_tostring(L, i)
LUALIB_API void luaL_traceback(lua_State *L, lua_State *L1, const char *msg, int level)
LUALIB_API int luaL_len(lua_State *L, int idx)
#define luaL_loadfile(L, f)
#define luaL_checkversion(L)
#define luaL_loadbuffer(L, s, sz, n)
#define lua_tointeger(L, i)
#define lua_pcall(L, n, r, f)
#define lua_writestringerror(s, p)
#define lua_writestring(s, l)
static const char * get_prompt(lua_State *L, int firstline)
static int report(lua_State *L, int status)
static int pushargs(lua_State *L)
static int collectargs(char **argv, int *first)
#define LUA_INITVARVERSION
static void print_version(void)
static int docall(lua_State *L, int narg, int nres)
#define lua_freeline(L, b)
static int handle_script(lua_State *L, char **argv)
static int handle_luainit(lua_State *L)
static void lstop(lua_State *L, lua_Debug *ar)
static int pushline(lua_State *L, int firstline)
static int dochunk(lua_State *L, int status)
static void doREPL(lua_State *L)
static int runargs(lua_State *L, char **argv, int n)
static int dofile(lua_State *L, const char *name)
static int pmain(lua_State *L)
static void l_print(lua_State *L)
static int msghandler(lua_State *L)
#define lua_saveline(L, line)
static int addreturn(lua_State *L)
#define lua_stdin_is_tty()
static void laction(int i)
static void l_message(const char *pname, const char *msg)
static int dolibrary(lua_State *L, const char *name)
static const char * progname
static int loadline(lua_State *L)
static int dostring(lua_State *L, const char *s, const char *name)
static void createargtable(lua_State *L, char **argv, int argc, int script)
static lua_State * globalL
static int incomplete(lua_State *L, int status)
#define lua_readline(L, b, p)
static int multiline(lua_State *L)
#define lua_insert(L, idx)
#define lua_remove(L, idx)
CURL_EXTERN CURLMcode curl_socket_t s