X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/d0ffc37686edcc803601f76ab51fdfed5fc2f241..af8dbc965fd8a420205d29aa50867ecbd0e45d33:/src/bindings/lua/lua_task.c diff --git a/src/bindings/lua/lua_task.c b/src/bindings/lua/lua_task.c index 8e8e1932be..e11aa326db 100644 --- a/src/bindings/lua/lua_task.c +++ b/src/bindings/lua/lua_task.c @@ -1,4 +1,4 @@ -/* Copyright (c) 2010, 2012. The SimGrid Team. +/* Copyright (c) 2010, 2012-2015. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -61,8 +61,8 @@ static int l_task_new(lua_State* L) { XBT_DEBUG("Task new"); const char* name = luaL_checkstring(L, 1); - int comp_size = luaL_checkint(L, 2); - int msg_size = luaL_checkint(L, 3); + int comp_size = (int) luaL_checkinteger(L, 2); + int msg_size = (int) luaL_checkinteger(L, 3); /* name comp comm */ lua_settop(L, 0); /* -- */ @@ -112,7 +112,7 @@ static int l_task_get_name(lua_State* L) static int l_task_get_computation_duration(lua_State* L) { msg_task_t task = sglua_check_task(L, 1); - lua_pushnumber(L, MSG_task_get_compute_duration(task)); + lua_pushnumber(L, MSG_task_get_flops_amount(task)); return 1; } @@ -390,7 +390,7 @@ static int l_task_irecv(lua_State* L) return 1; } -static const luaL_reg task_functions[] = { +static const luaL_Reg task_functions[] = { {"new", l_task_new}, {"get_name", l_task_get_name}, {"get_computation_duration", l_task_get_computation_duration}, @@ -440,7 +440,7 @@ static int l_task_tostring(lua_State* L) /** * \brief Metamethods of both a task table and the userdata inside it. */ -static const luaL_reg task_meta[] = { +static const luaL_Reg task_meta[] = { {"__gc", l_task_gc}, /* will be called only for userdata */ {"__tostring", l_task_tostring}, {NULL, NULL} @@ -456,25 +456,26 @@ static const luaL_reg task_meta[] = { void sglua_register_task_functions(lua_State* L) { /* create a table simgrid.task and fill it with task functions */ - luaL_openlib(L, TASK_MODULE_NAME, task_functions, 0); - /* simgrid.task */ + lua_getglobal(L, "simgrid"); /* simgrid */ + luaL_newlib(L, task_functions); /* simgrid simgrid.task */ + lua_setfield(L, -2, "task"); /* simgrid */ + lua_getfield(L, -1, "task"); /* simgrid simgrid.task */ /* create the metatable for tasks, add it to the Lua registry */ - luaL_newmetatable(L, TASK_MODULE_NAME); - /* simgrid.task mt */ + luaL_newmetatable(L, TASK_MODULE_NAME); /* simgrid simgrid.task mt */ + /* fill the metatable */ - luaL_openlib(L, NULL, task_meta, 0); - /* simgrid.task mt */ - lua_pushvalue(L, -2); - /* simgrid.task mt simgrid.task */ + luaL_setfuncs(L, task_meta, 0); /* simgrid simgrid.task mt */ + lua_getfield(L, -3, "task"); /* simgrid simgrid.task mt simgrid.task */ + /* metatable.__index = simgrid.task * we put the task functions inside the task itself: * this allows to write my_task:method(args) for * simgrid.task.method(my_task, args) */ - lua_setfield(L, -2, "__index"); - /* simgrid.task mt */ - lua_pop(L, 2); - /* -- */ + lua_setfield(L, -2, "__index"); /* simgrid simgrid.task mt */ + + lua_setmetatable(L, -2); /* simgrid simgrid.task */ + lua_pop(L, 2); /* -- */ /* set up MSG to copy Lua tasks between states */ MSG_task_set_copy_callback(task_copy_callback);