1996-07-24 15:01:52 -03:00
|
|
|
#include <string.h>
|
1995-10-26 12:21:56 -02:00
|
|
|
|
|
|
|
#include "luadebug.h"
|
1995-10-04 11:20:26 -03:00
|
|
|
#include "table.h"
|
1997-03-31 11:19:01 -03:00
|
|
|
#include "luamem.h"
|
1995-10-04 11:20:26 -03:00
|
|
|
#include "func.h"
|
1995-10-26 12:21:56 -02:00
|
|
|
#include "opcode.h"
|
1997-06-19 14:46:12 -03:00
|
|
|
#include "inout.h"
|
1995-10-04 11:20:26 -03:00
|
|
|
|
1996-02-07 16:10:27 -02:00
|
|
|
|
1995-10-04 11:20:26 -03:00
|
|
|
static TFunc *function_root = NULL;
|
|
|
|
|
|
|
|
|
1996-02-07 16:10:27 -02:00
|
|
|
/*
|
|
|
|
** Initialize TFunc struct
|
|
|
|
*/
|
|
|
|
void luaI_initTFunc (TFunc *f)
|
|
|
|
{
|
1996-02-26 14:06:39 -03:00
|
|
|
f->next = NULL;
|
|
|
|
f->marked = 0;
|
1996-02-07 16:10:27 -02:00
|
|
|
f->code = NULL;
|
|
|
|
f->lineDefined = 0;
|
1997-06-19 14:46:12 -03:00
|
|
|
f->fileName = lua_parsedfile;
|
1996-02-07 16:10:27 -02:00
|
|
|
f->locvars = NULL;
|
|
|
|
}
|
|
|
|
|
1995-10-04 11:20:26 -03:00
|
|
|
/*
|
|
|
|
** Insert function in list for GC
|
|
|
|
*/
|
|
|
|
void luaI_insertfunction (TFunc *f)
|
|
|
|
{
|
|
|
|
lua_pack();
|
|
|
|
f->next = function_root;
|
|
|
|
function_root = f;
|
|
|
|
f->marked = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Free function
|
|
|
|
*/
|
1996-03-14 12:54:20 -03:00
|
|
|
void luaI_freefunc (TFunc *f)
|
1995-10-04 11:20:26 -03:00
|
|
|
{
|
|
|
|
luaI_free (f->code);
|
1996-02-22 17:34:33 -03:00
|
|
|
luaI_free (f->locvars);
|
1995-10-04 11:20:26 -03:00
|
|
|
luaI_free (f);
|
|
|
|
}
|
|
|
|
|
1997-05-14 15:38:29 -03:00
|
|
|
|
|
|
|
void luaI_funcfree (TFunc *l)
|
|
|
|
{
|
|
|
|
while (l) {
|
|
|
|
TFunc *next = l->next;
|
|
|
|
luaI_freefunc(l);
|
|
|
|
l = next;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1995-10-04 11:20:26 -03:00
|
|
|
/*
|
|
|
|
** Garbage collection function.
|
|
|
|
*/
|
1997-05-14 15:38:29 -03:00
|
|
|
TFunc *luaI_funccollector (long *acum)
|
1995-10-04 11:20:26 -03:00
|
|
|
{
|
|
|
|
TFunc *curr = function_root;
|
|
|
|
TFunc *prev = NULL;
|
1997-05-14 15:38:29 -03:00
|
|
|
TFunc *frees = NULL;
|
|
|
|
long counter = 0;
|
|
|
|
while (curr) {
|
1995-10-04 11:20:26 -03:00
|
|
|
TFunc *next = curr->next;
|
1997-05-14 15:38:29 -03:00
|
|
|
if (!curr->marked) {
|
1995-10-04 11:20:26 -03:00
|
|
|
if (prev == NULL)
|
|
|
|
function_root = next;
|
|
|
|
else
|
|
|
|
prev->next = next;
|
1997-05-14 15:38:29 -03:00
|
|
|
curr->next = frees;
|
|
|
|
frees = curr;
|
1995-10-04 11:20:26 -03:00
|
|
|
++counter;
|
|
|
|
}
|
1997-05-14 15:38:29 -03:00
|
|
|
else {
|
1995-10-04 11:20:26 -03:00
|
|
|
curr->marked = 0;
|
|
|
|
prev = curr;
|
|
|
|
}
|
|
|
|
curr = next;
|
|
|
|
}
|
1997-05-14 15:38:29 -03:00
|
|
|
*acum += counter;
|
|
|
|
return frees;
|
1995-10-04 11:20:26 -03:00
|
|
|
}
|
1995-10-26 12:21:56 -02:00
|
|
|
|
|
|
|
|
|
|
|
void lua_funcinfo (lua_Object func, char **filename, int *linedefined)
|
|
|
|
{
|
1997-03-31 11:02:58 -03:00
|
|
|
TObject *f = luaI_Address(func);
|
1997-03-11 15:44:28 -03:00
|
|
|
if (f->ttype == LUA_T_MARK || f->ttype == LUA_T_FUNCTION)
|
1995-10-26 12:21:56 -02:00
|
|
|
{
|
|
|
|
*filename = f->value.tf->fileName;
|
|
|
|
*linedefined = f->value.tf->lineDefined;
|
|
|
|
}
|
1997-03-11 15:44:28 -03:00
|
|
|
else if (f->ttype == LUA_T_CMARK || f->ttype == LUA_T_CFUNCTION)
|
1995-10-26 12:21:56 -02:00
|
|
|
{
|
|
|
|
*filename = "(C)";
|
|
|
|
*linedefined = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1996-02-07 16:10:27 -02:00
|
|
|
|
|
|
|
/*
|
|
|
|
** Look for n-esim local variable at line "line" in function "func".
|
|
|
|
** Returns NULL if not found.
|
|
|
|
*/
|
|
|
|
char *luaI_getlocalname (TFunc *func, int local_number, int line)
|
|
|
|
{
|
|
|
|
int count = 0;
|
|
|
|
char *varname = NULL;
|
|
|
|
LocVar *lv = func->locvars;
|
|
|
|
if (lv == NULL)
|
|
|
|
return NULL;
|
|
|
|
for (; lv->line != -1 && lv->line < line; lv++)
|
|
|
|
{
|
|
|
|
if (lv->varname) /* register */
|
|
|
|
{
|
|
|
|
if (++count == local_number)
|
1996-02-12 15:32:40 -03:00
|
|
|
varname = lv->varname->str;
|
1996-02-07 16:10:27 -02:00
|
|
|
}
|
|
|
|
else /* unregister */
|
|
|
|
if (--count < local_number)
|
|
|
|
varname = NULL;
|
|
|
|
}
|
|
|
|
return varname;
|
|
|
|
}
|
|
|
|
|