forked from github/server
Begin of massive changes to the Lua API.
Everything will live in a single eressea module now, and the global namespace will no longer be polluted by all kinds of modules and functions. Also new: Bindings will be generated by tolua from .pkg files, starting with settings, eressea (read/write/free_game) and process in this commit.
This commit is contained in:
parent
8327db65b8
commit
8b3d735e8c
22 changed files with 404 additions and 236 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -9,6 +9,7 @@ Release/
|
||||||
*.opensdf
|
*.opensdf
|
||||||
*.ipch
|
*.ipch
|
||||||
*.sh
|
*.sh
|
||||||
|
*.tmp
|
||||||
src/*.vcproj.*.user
|
src/*.vcproj.*.user
|
||||||
tags
|
tags
|
||||||
build-vs2010
|
build-vs2010
|
||||||
|
|
12
scripts/tests/attrib.lua
Normal file → Executable file
12
scripts/tests/attrib.lua
Normal file → Executable file
|
@ -11,9 +11,9 @@ end
|
||||||
|
|
||||||
function test_attrib_global()
|
function test_attrib_global()
|
||||||
a = attrib.create('global', {})
|
a = attrib.create('global', {})
|
||||||
write_game('attrib.dat')
|
eressea.write_game('attrib.dat')
|
||||||
free_game()
|
eressea.free_game()
|
||||||
read_game('attrib.dat')
|
eressea.read_game('attrib.dat')
|
||||||
end
|
end
|
||||||
|
|
||||||
function test_attrib()
|
function test_attrib()
|
||||||
|
@ -30,9 +30,9 @@ function test_attrib()
|
||||||
a = attrib.create(u, "enno")
|
a = attrib.create(u, "enno")
|
||||||
a = attrib.create(u, u2)
|
a = attrib.create(u, u2)
|
||||||
a = attrib.create(u, data)
|
a = attrib.create(u, data)
|
||||||
write_game("attrib.dat")
|
eressea.write_game("attrib.dat")
|
||||||
free_game()
|
eressea.free_game()
|
||||||
read_game("attrib.dat")
|
eressea.read_game("attrib.dat")
|
||||||
u = get_unit(uno)
|
u = get_unit(uno)
|
||||||
u2 = get_unit(u2no)
|
u2 = get_unit(u2no)
|
||||||
assert_false(has_attrib(u, 42))
|
assert_false(has_attrib(u, 42))
|
||||||
|
|
8
scripts/tests/bson.lua
Normal file → Executable file
8
scripts/tests/bson.lua
Normal file → Executable file
|
@ -3,7 +3,7 @@ require "lunit"
|
||||||
module("tests.eressea.bson", package.seeall, lunit.testcase)
|
module("tests.eressea.bson", package.seeall, lunit.testcase)
|
||||||
|
|
||||||
function setup()
|
function setup()
|
||||||
free_game()
|
eressea.free_game()
|
||||||
end
|
end
|
||||||
|
|
||||||
function test_bson_create()
|
function test_bson_create()
|
||||||
|
@ -24,12 +24,12 @@ end
|
||||||
function test_bson_readwrite()
|
function test_bson_readwrite()
|
||||||
local i, r = region.create(0, 0, "mountain")
|
local i, r = region.create(0, 0, "mountain")
|
||||||
attrib.create(r, 42)
|
attrib.create(r, 42)
|
||||||
i = write_game("test_read_write.dat")
|
i = eressea.write_game("test_read_write.dat")
|
||||||
assert_equal(0, i)
|
assert_equal(0, i)
|
||||||
free_game()
|
eressea.free_game()
|
||||||
r = get_region(0, 0)
|
r = get_region(0, 0)
|
||||||
assert_equal(nil, r)
|
assert_equal(nil, r)
|
||||||
i = read_game("test_read_write.dat")
|
i = eressea.read_game("test_read_write.dat")
|
||||||
assert_equal(0, i)
|
assert_equal(0, i)
|
||||||
r = get_region(0, 0)
|
r = get_region(0, 0)
|
||||||
assert_not_equal(nil, r)
|
assert_not_equal(nil, r)
|
||||||
|
|
50
scripts/tests/common.lua
Normal file → Executable file
50
scripts/tests/common.lua
Normal file → Executable file
|
@ -38,12 +38,12 @@ end
|
||||||
module("tests.eressea.common", package.seeall, lunit.testcase)
|
module("tests.eressea.common", package.seeall, lunit.testcase)
|
||||||
|
|
||||||
function setup()
|
function setup()
|
||||||
free_game()
|
eressea.free_game()
|
||||||
write_game("free.dat")
|
eressea.write_game("free.dat")
|
||||||
settings.set("nmr.removenewbie", "0")
|
eressea.settings.set("nmr.removenewbie", "0")
|
||||||
settings.set("nmr.timeout", "0")
|
eressea.settings.set("nmr.timeout", "0")
|
||||||
settings.set("NewbieImmunity", "0")
|
eressea.settings.set("NewbieImmunity", "0")
|
||||||
settings.set("rules.economy.food", "4")
|
eressea.settings.set("rules.economy.food", "4")
|
||||||
end
|
end
|
||||||
|
|
||||||
function DISABLE_test_eventbus_fire()
|
function DISABLE_test_eventbus_fire()
|
||||||
|
@ -112,7 +112,7 @@ function test_read_write()
|
||||||
local uno = u.id
|
local uno = u.id
|
||||||
local result = 0
|
local result = 0
|
||||||
assert_equal(r.terrain, "plain")
|
assert_equal(r.terrain, "plain")
|
||||||
result = write_game("test_read_write.dat", "binary")
|
result = eressea.write_game("test_read_write.dat")
|
||||||
assert_equal(result, 0)
|
assert_equal(result, 0)
|
||||||
assert_not_equal(get_region(0, 0), nil)
|
assert_not_equal(get_region(0, 0), nil)
|
||||||
assert_not_equal(get_faction(fno), nil)
|
assert_not_equal(get_faction(fno), nil)
|
||||||
|
@ -120,11 +120,11 @@ function test_read_write()
|
||||||
r = nil
|
r = nil
|
||||||
f = nil
|
f = nil
|
||||||
u = nil
|
u = nil
|
||||||
free_game()
|
eressea.free_game()
|
||||||
assert_equal(get_region(0, 0), nil)
|
assert_equal(get_region(0, 0), nil)
|
||||||
assert_equal(nil, get_faction(fno))
|
assert_equal(nil, get_faction(fno))
|
||||||
assert_equal(nil, get_unit(uno))
|
assert_equal(nil, get_unit(uno))
|
||||||
result = read_game("test_read_write.dat", "binary")
|
result = eressea.read_game("test_read_write.dat")
|
||||||
assert_equal(0, result)
|
assert_equal(0, result)
|
||||||
assert_not_equal(nil, get_region(0, 0))
|
assert_not_equal(nil, get_region(0, 0))
|
||||||
assert_not_equal(nil, get_faction(fno))
|
assert_not_equal(nil, get_faction(fno))
|
||||||
|
@ -388,7 +388,7 @@ function test_work()
|
||||||
end
|
end
|
||||||
|
|
||||||
function test_upkeep()
|
function test_upkeep()
|
||||||
settings.set("rules.economy.food", "0")
|
eressea.settings.set("rules.economy.food", "0")
|
||||||
local r = region.create(0, 0, "plain")
|
local r = region.create(0, 0, "plain")
|
||||||
local f = faction.create("noreply@eressea.de", "human", "de")
|
local f = faction.create("noreply@eressea.de", "human", "de")
|
||||||
local u = unit.create(f, r, 5)
|
local u = unit.create(f, r, 5)
|
||||||
|
@ -541,7 +541,7 @@ function test_store_unit()
|
||||||
assert_not_equal(store, nil)
|
assert_not_equal(store, nil)
|
||||||
store:write_unit(u)
|
store:write_unit(u)
|
||||||
store:close()
|
store:close()
|
||||||
free_game()
|
eressea.free_game()
|
||||||
-- recreate world:
|
-- recreate world:
|
||||||
r = region.create(0, 0, "plain")
|
r = region.create(0, 0, "plain")
|
||||||
f = faction.create("noreply@eressea.de", "human", "de")
|
f = faction.create("noreply@eressea.de", "human", "de")
|
||||||
|
@ -668,7 +668,7 @@ function test_food_is_consumed()
|
||||||
u:add_item("money", 100)
|
u:add_item("money", 100)
|
||||||
u:clear_orders()
|
u:clear_orders()
|
||||||
u:add_order("LERNEN Reiten") -- don't work
|
u:add_order("LERNEN Reiten") -- don't work
|
||||||
settings.set("rules.economy.food", "4")
|
eressea.settings.set("rules.economy.food", "4")
|
||||||
process_orders()
|
process_orders()
|
||||||
assert_equal(100, u:get_item("money"))
|
assert_equal(100, u:get_item("money"))
|
||||||
end
|
end
|
||||||
|
@ -680,7 +680,7 @@ function test_food_can_override()
|
||||||
u:add_item("money", 100)
|
u:add_item("money", 100)
|
||||||
u:clear_orders()
|
u:clear_orders()
|
||||||
u:add_order("LERNEN Reiten") -- don't work
|
u:add_order("LERNEN Reiten") -- don't work
|
||||||
settings.set("rules.economy.food", "0")
|
eressea.settings.set("rules.economy.food", "0")
|
||||||
process_orders()
|
process_orders()
|
||||||
assert_equal(90, u:get_item("money"))
|
assert_equal(90, u:get_item("money"))
|
||||||
end
|
end
|
||||||
|
@ -806,10 +806,10 @@ end
|
||||||
module("tests.report", package.seeall, lunit.testcase)
|
module("tests.report", package.seeall, lunit.testcase)
|
||||||
|
|
||||||
function setup()
|
function setup()
|
||||||
free_game()
|
eressea.free_game()
|
||||||
settings.set("nmr.removenewbie", "0")
|
eressea.settings.set("nmr.removenewbie", "0")
|
||||||
settings.set("nmr.timeout", "0")
|
eressea.settings.set("nmr.timeout", "0")
|
||||||
settings.set("rules.economy.food", "4")
|
eressea.settings.set("rules.economy.food", "4")
|
||||||
end
|
end
|
||||||
|
|
||||||
local function find_in_report(f, pattern, extension)
|
local function find_in_report(f, pattern, extension)
|
||||||
|
@ -894,9 +894,9 @@ end
|
||||||
module("tests.parser", package.seeall, lunit.testcase)
|
module("tests.parser", package.seeall, lunit.testcase)
|
||||||
|
|
||||||
function setup()
|
function setup()
|
||||||
free_game()
|
eressea.free_game()
|
||||||
write_game("free.dat")
|
eressea.write_game("free.dat")
|
||||||
settings.set("rules.economy.food", "4") -- FOOD_IS_FREE
|
eressea.settings.set("rules.economy.food", "4") -- FOOD_IS_FREE
|
||||||
end
|
end
|
||||||
|
|
||||||
function test_parser()
|
function test_parser()
|
||||||
|
@ -909,12 +909,12 @@ function test_parser()
|
||||||
assert_not_nil(file)
|
assert_not_nil(file)
|
||||||
file:write('ERESSEA ' .. itoa36(f.id) .. ' "' .. f.password .. '"\n')
|
file:write('ERESSEA ' .. itoa36(f.id) .. ' "' .. f.password .. '"\n')
|
||||||
file:write('EINHEIT ' .. itoa36(u.id) .. "\n")
|
file:write('EINHEIT ' .. itoa36(u.id) .. "\n")
|
||||||
file:write("LERNEN Hiebwaffen\n")
|
file:write("BENENNEN EINHEIT 'Goldene Herde'\n")
|
||||||
file:close()
|
file:close()
|
||||||
|
|
||||||
read_orders(filename)
|
read_orders(filename)
|
||||||
process_orders()
|
process_orders()
|
||||||
assert_not_equal(0, u:get_skill("melee"))
|
assert_equal("Goldene Herde", u.name)
|
||||||
end
|
end
|
||||||
|
|
||||||
function test_bug_1922()
|
function test_bug_1922()
|
||||||
|
@ -928,8 +928,8 @@ function test_bug_1922()
|
||||||
|
|
||||||
local s = _test_create_ship(r)
|
local s = _test_create_ship(r)
|
||||||
|
|
||||||
settings.set("rules.ship.drifting","0") -- ships are not drifting
|
eressea.settings.set("rules.ship.drifting","0") -- ships are not drifting
|
||||||
settings.set("rules.economy.food","4") -- does not need silver
|
eressea.settings.set("rules.economy.food","4") -- does not need silver
|
||||||
|
|
||||||
u.ship = s
|
u.ship = s
|
||||||
u:clear_orders()
|
u:clear_orders()
|
||||||
|
@ -950,7 +950,7 @@ function test_bug_1922_by_foot()
|
||||||
local f = faction.create("noreply@eressea.de", "human", "de")
|
local f = faction.create("noreply@eressea.de", "human", "de")
|
||||||
local u = unit.create(f, r, 1)
|
local u = unit.create(f, r, 1)
|
||||||
|
|
||||||
settings.set("rules.economy.food","4") -- does not need silver
|
eressea.settings.set("rules.economy.food","4") -- does not need silver
|
||||||
|
|
||||||
u:clear_orders()
|
u:clear_orders()
|
||||||
u:add_order("NACH O")
|
u:add_order("NACH O")
|
||||||
|
|
35
scripts/tests/orders.lua
Executable file
35
scripts/tests/orders.lua
Executable file
|
@ -0,0 +1,35 @@
|
||||||
|
require "lunit"
|
||||||
|
|
||||||
|
local _G = _G
|
||||||
|
local eressea = eressea
|
||||||
|
|
||||||
|
module("tests.orders", lunit.testcase)
|
||||||
|
|
||||||
|
local r, f, u
|
||||||
|
|
||||||
|
function setup()
|
||||||
|
eressea.free_game()
|
||||||
|
r = _G.region.create(0, 0, "mountain")
|
||||||
|
f = _G.faction.create("noreply@eressea.de", "human", "de")
|
||||||
|
u = _G.unit.create(f, r, 1)
|
||||||
|
u:clear_orders()
|
||||||
|
eressea.settings.set("rules.economy.food", "4")
|
||||||
|
eressea.settings.set("nmr.removenewbie", "0")
|
||||||
|
eressea.settings.set("nmr.timeout", "0")
|
||||||
|
eressea.settings.set("NewbieImmunity", "0")
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_learn()
|
||||||
|
u:add_order("LERNEN Hiebwaffen")
|
||||||
|
_G.process_orders()
|
||||||
|
assert_not_equal(0, u:get_skill("melee"))
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_give()
|
||||||
|
local u2 = _G.unit.create(f, r, 1)
|
||||||
|
u:add_item("money", 10)
|
||||||
|
u:add_order("GIB " .. u2.id .. "5 SILBER")
|
||||||
|
_G.process_orders()
|
||||||
|
assert_not_equal(5, u:get_item("money"))
|
||||||
|
assert_not_equal(5, u2:get_item("money"))
|
||||||
|
end
|
8
scripts/tests/spells.lua
Normal file → Executable file
8
scripts/tests/spells.lua
Normal file → Executable file
|
@ -5,10 +5,10 @@ module("tests.eressea.spells", package.seeall, lunit.testcase)
|
||||||
local r, f, u
|
local r, f, u
|
||||||
|
|
||||||
function setup()
|
function setup()
|
||||||
free_game()
|
eressea.free_game()
|
||||||
settings.set("magic.regeneration.enable", "0")
|
eressea.settings.set("magic.regeneration.enable", "0")
|
||||||
settings.set("magic.fumble.enable", "0")
|
eressea.settings.set("magic.fumble.enable", "0")
|
||||||
settings.set("rules.economy.food", "4")
|
eressea.settings.set("rules.economy.food", "4")
|
||||||
|
|
||||||
r = region.create(0, 0, "plain")
|
r = region.create(0, 0, "plain")
|
||||||
f = faction.create("spell_payment@eressea.de", "elf", "de")
|
f = faction.create("spell_payment@eressea.de", "elf", "de")
|
||||||
|
|
17
src/CMakeLists.txt
Normal file → Executable file
17
src/CMakeLists.txt
Normal file → Executable file
|
@ -1,6 +1,8 @@
|
||||||
cmake_minimum_required(VERSION 2.6)
|
cmake_minimum_required(VERSION 2.6)
|
||||||
project (eressea C)
|
project (eressea C)
|
||||||
|
|
||||||
|
add_subdirectory(bindings)
|
||||||
|
|
||||||
IF(CMAKE_COMPILER_IS_GNUCC)
|
IF(CMAKE_COMPILER_IS_GNUCC)
|
||||||
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pedantic -Wall -Werror -Wno-unknown-pragmas -Wstrict-prototypes -Wpointer-arith -Wno-char-subscripts -Wno-long-long")
|
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pedantic -Wall -Werror -Wno-unknown-pragmas -Wstrict-prototypes -Wpointer-arith -Wno-char-subscripts -Wno-long-long")
|
||||||
ELSE(CMAKE_COMPILER_IS_GNUCC)
|
ELSE(CMAKE_COMPILER_IS_GNUCC)
|
||||||
|
@ -88,19 +90,6 @@ set (LIB_SRC
|
||||||
attributes/raceprefix.c
|
attributes/raceprefix.c
|
||||||
attributes/reduceproduction.c
|
attributes/reduceproduction.c
|
||||||
attributes/targetregion.c
|
attributes/targetregion.c
|
||||||
# bindings/bind_attrib.c
|
|
||||||
bindings/bind_building.c
|
|
||||||
bindings/bind_faction.c
|
|
||||||
bindings/bind_gmtool.c
|
|
||||||
bindings/bind_hashtable.c
|
|
||||||
bindings/bindings.c
|
|
||||||
bindings/bind_message.c
|
|
||||||
bindings/bind_region.c
|
|
||||||
bindings/bind_ship.c
|
|
||||||
bindings/bind_sqlite.c
|
|
||||||
bindings/bind_storage.c
|
|
||||||
bindings/bind_unit.c
|
|
||||||
bindings/helpers.c
|
|
||||||
eressea.c
|
eressea.c
|
||||||
gamecode/archetype.c
|
gamecode/archetype.c
|
||||||
gamecode/creation.c
|
gamecode/creation.c
|
||||||
|
@ -218,7 +207,7 @@ set (LIB_SRC
|
||||||
util/xml.c
|
util/xml.c
|
||||||
)
|
)
|
||||||
|
|
||||||
add_library(${ERESSEA_LIBRARY} ${LIB_SRC} ${LIB_HDR})
|
add_library(${ERESSEA_LIBRARY} ${LIB_SRC} ${BIND_SRC} ${LIB_HDR})
|
||||||
target_link_libraries(${ERESSEA_LIBRARY} ${ERESSEA_LIBRARIES})
|
target_link_libraries(${ERESSEA_LIBRARY} ${ERESSEA_LIBRARIES})
|
||||||
|
|
||||||
add_executable(${PROJECT_NAME}_test ${TEST_SRC})
|
add_executable(${PROJECT_NAME}_test ${TEST_SRC})
|
||||||
|
|
78
src/bindings/CMakeLists.txt
Executable file
78
src/bindings/CMakeLists.txt
Executable file
|
@ -0,0 +1,78 @@
|
||||||
|
cmake_minimum_required(VERSION 2.6)
|
||||||
|
project (bindings C)
|
||||||
|
|
||||||
|
IF(CMAKE_COMPILER_IS_GNUCC)
|
||||||
|
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c99 -pedantic -Wall -Werror -Wno-unknown-pragmas -Wstrict-prototypes -Wpointer-arith -Wno-char-subscripts -Wno-long-long")
|
||||||
|
ELSE(CMAKE_COMPILER_IS_GNUCC)
|
||||||
|
MESSAGE(STATUS "Unknown compiler ${CMAKE_C_COMPILER_ID}")
|
||||||
|
ENDIF(CMAKE_COMPILER_IS_GNUCC)
|
||||||
|
|
||||||
|
set (BINDINGS_LIBRARY ${PROJECT_NAME} CACHE INTERNAL "Eressea Lua Bindings")
|
||||||
|
|
||||||
|
find_package (Lua51 REQUIRED)
|
||||||
|
find_package (ToLua REQUIRED)
|
||||||
|
find_package (LibXml2 REQUIRED)
|
||||||
|
find_package (Curses REQUIRED)
|
||||||
|
find_package (SQLite3 REQUIRED)
|
||||||
|
|
||||||
|
include_directories (${ERESSEA_INCLUDE_DIR})
|
||||||
|
include_directories (${CRITBIT_INCLUDE_DIR})
|
||||||
|
include_directories (${CRYPTO_INCLUDE_DIR})
|
||||||
|
include_directories (${QUICKLIST_INCLUDE_DIR})
|
||||||
|
include_directories (${CUTEST_INCLUDE_DIR})
|
||||||
|
include_directories (${LUA_INCLUDE_DIR})
|
||||||
|
include_directories (${TOLUA_INCLUDE_DIR})
|
||||||
|
include_directories (${LIBXML2_INCLUDE_DIR})
|
||||||
|
include_directories (${BSON_INCLUDE_DIR})
|
||||||
|
include_directories (${INIPARSER_INCLUDE_DIR})
|
||||||
|
|
||||||
|
FILE (GLOB_RECURSE LIB_HDR *.h)
|
||||||
|
|
||||||
|
MACRO(ADD_LUA_MODULE MODULE_NAME FILES)
|
||||||
|
ADD_LIBRARY (${MODULE_NAME} SHARED ${FILES})
|
||||||
|
SET_TARGET_PROPERTIES(${MODULE_NAME}
|
||||||
|
PROPERTIES
|
||||||
|
PREFIX ""
|
||||||
|
)
|
||||||
|
ENDMACRO(ADD_LUA_MODULE)
|
||||||
|
|
||||||
|
MACRO(TOLUA_BINDING PKGFILE FILES)
|
||||||
|
ADD_CUSTOM_COMMAND(
|
||||||
|
OUTPUT ${PKGFILE}.c
|
||||||
|
DEPENDS ${FILES} ${PKGFILE}
|
||||||
|
COMMAND tolua
|
||||||
|
ARGS -o ${CMAKE_CURRENT_BINARY_DIR}/${PKGFILE}.c ${PKGFILE}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
)
|
||||||
|
ENDMACRO(TOLUA_BINDING)
|
||||||
|
|
||||||
|
TOLUA_BINDING(process.pkg bind_process.h)
|
||||||
|
TOLUA_BINDING(eressea.pkg bind_eressea.h)
|
||||||
|
TOLUA_BINDING(settings.pkg bind_settings.h)
|
||||||
|
|
||||||
|
set (BIND_SRC
|
||||||
|
process.pkg.c
|
||||||
|
eressea.pkg.c
|
||||||
|
settings.pkg.c
|
||||||
|
|
||||||
|
bind_process.c
|
||||||
|
bind_eressea.c
|
||||||
|
bind_settings.c
|
||||||
|
|
||||||
|
# bind_attrib.c
|
||||||
|
bind_building.c
|
||||||
|
bind_faction.c
|
||||||
|
bind_gmtool.c
|
||||||
|
bind_hashtable.c
|
||||||
|
bindings.c
|
||||||
|
bind_message.c
|
||||||
|
bind_region.c
|
||||||
|
bind_ship.c
|
||||||
|
bind_sqlite.c
|
||||||
|
bind_storage.c
|
||||||
|
bind_unit.c
|
||||||
|
helpers.c
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(${BINDINGS_LIBRARY} ${LIB_SRC} ${BIND_SRC} ${LIB_HDR})
|
||||||
|
target_link_libraries(${BINDINGS_LIBRARY} ${ERESSEA_LIBRARY})
|
19
src/bindings/bind_eressea.c
Executable file
19
src/bindings/bind_eressea.c
Executable file
|
@ -0,0 +1,19 @@
|
||||||
|
#include "bind_eressea.h"
|
||||||
|
|
||||||
|
#include <platform.h>
|
||||||
|
#include <kernel/types.h>
|
||||||
|
#include <kernel/config.h>
|
||||||
|
#include <kernel/save.h>
|
||||||
|
#include <util/storage.h>
|
||||||
|
|
||||||
|
void eressea_free_game(void) {
|
||||||
|
free_gamedata();
|
||||||
|
}
|
||||||
|
|
||||||
|
int eressea_read_game(const char * filename) {
|
||||||
|
return readgame(filename, IO_BINARY, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int eressea_write_game(const char * filename) {
|
||||||
|
return writegame(filename, IO_BINARY);
|
||||||
|
}
|
14
src/bindings/bind_eressea.h
Executable file
14
src/bindings/bind_eressea.h
Executable file
|
@ -0,0 +1,14 @@
|
||||||
|
#ifndef BIND_ERESSEA_H
|
||||||
|
#define BIND_ERESSEA_H
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void eressea_free_game(void);
|
||||||
|
int eressea_read_game(const char * filename);
|
||||||
|
int eressea_write_game(const char * filename);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
18
src/bindings/bind_process.c
Executable file
18
src/bindings/bind_process.c
Executable file
|
@ -0,0 +1,18 @@
|
||||||
|
#include "bind_process.h"
|
||||||
|
|
||||||
|
#include <platform.h>
|
||||||
|
#include <kernel/types.h>
|
||||||
|
#include <kernel/region.h>
|
||||||
|
#include <gamecode/economy.h>
|
||||||
|
#include <gamecode/market.h>
|
||||||
|
|
||||||
|
void process_produce(void) {
|
||||||
|
struct region *r;
|
||||||
|
for (r = regions; r; r = r->next) {
|
||||||
|
produce(r);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void process_markets(void) {
|
||||||
|
do_markets();
|
||||||
|
}
|
13
src/bindings/bind_process.h
Executable file
13
src/bindings/bind_process.h
Executable file
|
@ -0,0 +1,13 @@
|
||||||
|
#ifndef BIND_ERESSEA_PROCESS_H
|
||||||
|
#define BIND_ERESSEA_PROCESS_H
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void process_produce(void);
|
||||||
|
void process_markets(void);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
15
src/bindings/bind_settings.c
Executable file
15
src/bindings/bind_settings.c
Executable file
|
@ -0,0 +1,15 @@
|
||||||
|
#include "bind_settings.h"
|
||||||
|
|
||||||
|
#include <platform.h>
|
||||||
|
#include <kernel/types.h>
|
||||||
|
#include <kernel/config.h>
|
||||||
|
|
||||||
|
const char * settings_get(const char *key)
|
||||||
|
{
|
||||||
|
return get_param(global.parameters, key);
|
||||||
|
}
|
||||||
|
|
||||||
|
void settings_set(const char *key, const char *value)
|
||||||
|
{
|
||||||
|
set_param(&global.parameters, key, value);
|
||||||
|
}
|
13
src/bindings/bind_settings.h
Executable file
13
src/bindings/bind_settings.h
Executable file
|
@ -0,0 +1,13 @@
|
||||||
|
#ifndef BIND_ERESSEA_PROCESS_H
|
||||||
|
#define BIND_ERESSEA_PROCESS_H
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char * settings_get(const char *key);
|
||||||
|
void settings_set(const char *key, const char *value);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
155
src/bindings/bindings.c
Normal file → Executable file
155
src/bindings/bindings.c
Normal file → Executable file
|
@ -13,7 +13,14 @@ without prior permission by the authors of Eressea.
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
#include "bindings.h"
|
#include "bindings.h"
|
||||||
#include "bind_unit.h"
|
#include "bind_unit.h"
|
||||||
|
#include "bind_storage.h"
|
||||||
|
#include "bind_building.h"
|
||||||
|
#include "bind_hashtable.h"
|
||||||
|
#include "bind_message.h"
|
||||||
|
#include "bind_building.h"
|
||||||
#include "bind_faction.h"
|
#include "bind_faction.h"
|
||||||
|
#include "bind_ship.h"
|
||||||
|
#include "bind_gmtool.h"
|
||||||
#include "bind_region.h"
|
#include "bind_region.h"
|
||||||
#include "helpers.h"
|
#include "helpers.h"
|
||||||
|
|
||||||
|
@ -54,6 +61,7 @@ without prior permission by the authors of Eressea.
|
||||||
|
|
||||||
#include <util/attrib.h>
|
#include <util/attrib.h>
|
||||||
#include <util/base36.h>
|
#include <util/base36.h>
|
||||||
|
#include <util/console.h>
|
||||||
#include <util/eventbus.h>
|
#include <util/eventbus.h>
|
||||||
#include <util/language.h>
|
#include <util/language.h>
|
||||||
#include <util/lists.h>
|
#include <util/lists.h>
|
||||||
|
@ -66,10 +74,18 @@ without prior permission by the authors of Eressea.
|
||||||
#include <iniparser.h>
|
#include <iniparser.h>
|
||||||
#include <tolua.h>
|
#include <tolua.h>
|
||||||
#include <lua.h>
|
#include <lua.h>
|
||||||
|
#include <lualib.h>
|
||||||
|
#include <lauxlib.h>
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#define TOLUA_PKG(NAME) extern void tolua_##NAME##_open(lua_State * L)
|
||||||
|
|
||||||
|
TOLUA_PKG(eressea);
|
||||||
|
TOLUA_PKG(process);
|
||||||
|
TOLUA_PKG(settings);
|
||||||
|
|
||||||
int log_lua_error(lua_State * L)
|
int log_lua_error(lua_State * L)
|
||||||
{
|
{
|
||||||
const char *error = lua_tostring(L, -1);
|
const char *error = lua_tostring(L, -1);
|
||||||
|
@ -1016,21 +1032,6 @@ int tolua_read_xml(lua_State * L)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int tolua_process_markets(lua_State * L)
|
|
||||||
{
|
|
||||||
do_markets();
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int tolua_process_produce(lua_State * L)
|
|
||||||
{
|
|
||||||
region *r;
|
|
||||||
for (r = regions; r; r = r->next) {
|
|
||||||
produce(r);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef struct event_args {
|
typedef struct event_args {
|
||||||
int hfunction;
|
int hfunction;
|
||||||
int hargs;
|
int hargs;
|
||||||
|
@ -1104,21 +1105,6 @@ static int tolua_report_unit(lua_State * L)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tolua_settings_get(lua_State * L)
|
|
||||||
{
|
|
||||||
const char *name = tolua_tostring(L, 1, 0);
|
|
||||||
tolua_pushstring(L, get_param(global.parameters, name));
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int tolua_settings_set(lua_State * L)
|
|
||||||
{
|
|
||||||
const char *name = tolua_tostring(L, 1, 0);
|
|
||||||
const char *value = tolua_tostring(L, 2, 0);
|
|
||||||
set_param(&global.parameters, name, value);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void parse_inifile(lua_State * L, dictionary * d, const char *section)
|
static void parse_inifile(lua_State * L, dictionary * d, const char *section)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
@ -1148,10 +1134,14 @@ static void parse_inifile(lua_State * L, dictionary * d, const char *section)
|
||||||
lua_rawset(L, -3);
|
lua_rawset(L, -3);
|
||||||
}
|
}
|
||||||
|
|
||||||
int tolua_eressea_open(lua_State * L)
|
int tolua_bindings_open(lua_State * L)
|
||||||
{
|
{
|
||||||
tolua_open(L);
|
tolua_open(L);
|
||||||
|
|
||||||
|
tolua_eressea_open(L);
|
||||||
|
tolua_process_open(L);
|
||||||
|
tolua_settings_open(L);
|
||||||
|
|
||||||
/* register user types */
|
/* register user types */
|
||||||
tolua_usertype(L, TOLUA_CAST "spell");
|
tolua_usertype(L, TOLUA_CAST "spell");
|
||||||
tolua_usertype(L, TOLUA_CAST "spell_list");
|
tolua_usertype(L, TOLUA_CAST "spell_list");
|
||||||
|
@ -1163,12 +1153,6 @@ int tolua_eressea_open(lua_State * L)
|
||||||
tolua_module(L, NULL, 0);
|
tolua_module(L, NULL, 0);
|
||||||
tolua_beginmodule(L, NULL);
|
tolua_beginmodule(L, NULL);
|
||||||
{
|
{
|
||||||
tolua_module(L, "process", 0);
|
|
||||||
tolua_beginmodule(L, "process");
|
|
||||||
{
|
|
||||||
tolua_function(L, "markets", &tolua_process_markets);
|
|
||||||
tolua_function(L, "produce", &tolua_process_produce);
|
|
||||||
} tolua_endmodule(L);
|
|
||||||
tolua_cclass(L, TOLUA_CAST "alliance", TOLUA_CAST "alliance",
|
tolua_cclass(L, TOLUA_CAST "alliance", TOLUA_CAST "alliance",
|
||||||
TOLUA_CAST "", NULL);
|
TOLUA_CAST "", NULL);
|
||||||
tolua_beginmodule(L, TOLUA_CAST "alliance");
|
tolua_beginmodule(L, TOLUA_CAST "alliance");
|
||||||
|
@ -1198,12 +1182,6 @@ int tolua_eressea_open(lua_State * L)
|
||||||
tolua_function(L, TOLUA_CAST "register", &tolua_eventbus_register);
|
tolua_function(L, TOLUA_CAST "register", &tolua_eventbus_register);
|
||||||
tolua_function(L, TOLUA_CAST "fire", &tolua_eventbus_fire);
|
tolua_function(L, TOLUA_CAST "fire", &tolua_eventbus_fire);
|
||||||
} tolua_endmodule(L);
|
} tolua_endmodule(L);
|
||||||
tolua_module(L, TOLUA_CAST "settings", 1);
|
|
||||||
tolua_beginmodule(L, TOLUA_CAST "settings");
|
|
||||||
{
|
|
||||||
tolua_function(L, TOLUA_CAST "set", &tolua_settings_set);
|
|
||||||
tolua_function(L, TOLUA_CAST "get", &tolua_settings_get);
|
|
||||||
} tolua_endmodule(L);
|
|
||||||
tolua_module(L, TOLUA_CAST "report", 1);
|
tolua_module(L, TOLUA_CAST "report", 1);
|
||||||
tolua_beginmodule(L, TOLUA_CAST "report");
|
tolua_beginmodule(L, TOLUA_CAST "report");
|
||||||
{
|
{
|
||||||
|
@ -1279,3 +1257,94 @@ int tolua_eressea_open(lua_State * L)
|
||||||
} tolua_endmodule(L);
|
} tolua_endmodule(L);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const struct {
|
||||||
|
const char *name;
|
||||||
|
int (*func) (lua_State *);
|
||||||
|
} lualibs[] = {
|
||||||
|
{
|
||||||
|
"", luaopen_base}, {
|
||||||
|
LUA_TABLIBNAME, luaopen_table}, {
|
||||||
|
LUA_IOLIBNAME, luaopen_io}, {
|
||||||
|
LUA_STRLIBNAME, luaopen_string}, {
|
||||||
|
LUA_MATHLIBNAME, luaopen_math}, {
|
||||||
|
LUA_LOADLIBNAME, luaopen_package}, {
|
||||||
|
LUA_DBLIBNAME, luaopen_debug},
|
||||||
|
#if LUA_VERSION_NUM>=501
|
||||||
|
{
|
||||||
|
LUA_OSLIBNAME, luaopen_os},
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
NULL, NULL}
|
||||||
|
};
|
||||||
|
|
||||||
|
static void openlibs(lua_State * L)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i = 0; lualibs[i].func; ++i) {
|
||||||
|
lua_pushcfunction(L, lualibs[i].func);
|
||||||
|
lua_pushstring(L, lualibs[i].name);
|
||||||
|
lua_call(L, 1, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void lua_done(lua_State * L) {
|
||||||
|
lua_close(L);
|
||||||
|
}
|
||||||
|
|
||||||
|
lua_State *lua_init(void) {
|
||||||
|
lua_State *L = lua_open();
|
||||||
|
|
||||||
|
openlibs(L);
|
||||||
|
#ifdef BINDINGS_TOLUA
|
||||||
|
register_tolua_helpers();
|
||||||
|
tolua_bindings_open(L);
|
||||||
|
tolua_eressea_open(L);
|
||||||
|
tolua_sqlite_open(L);
|
||||||
|
tolua_unit_open(L);
|
||||||
|
tolua_building_open(L);
|
||||||
|
tolua_ship_open(L);
|
||||||
|
tolua_region_open(L);
|
||||||
|
tolua_faction_open(L);
|
||||||
|
#ifdef BSON_ATTRIB
|
||||||
|
tolua_attrib_open(L);
|
||||||
|
#endif
|
||||||
|
tolua_unit_open(L);
|
||||||
|
tolua_message_open(L);
|
||||||
|
tolua_hashtable_open(L);
|
||||||
|
tolua_gmtool_open(L);
|
||||||
|
tolua_storage_open(L);
|
||||||
|
#endif
|
||||||
|
return L;
|
||||||
|
}
|
||||||
|
|
||||||
|
int eressea_run(lua_State *L, const char *luafile, const char *entry_point)
|
||||||
|
{
|
||||||
|
int err;
|
||||||
|
|
||||||
|
global.vm_state = L;
|
||||||
|
/* run the main script */
|
||||||
|
if (luafile) {
|
||||||
|
log_debug("executing script %s\n", luafile);
|
||||||
|
lua_getglobal(L, "dofile");
|
||||||
|
lua_pushstring(L, luafile);
|
||||||
|
err = lua_pcall(L, 1, 0, 0);
|
||||||
|
if (err != 0) {
|
||||||
|
log_lua_error(L);
|
||||||
|
abort();
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (entry_point) {
|
||||||
|
lua_getglobal(L, entry_point);
|
||||||
|
err = lua_pcall(L, 0, 1, 0);
|
||||||
|
if (err != 0) {
|
||||||
|
log_lua_error(L);
|
||||||
|
abort();
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
err = lua_console(L);
|
||||||
|
}
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
7
src/bindings/bindings.h
Normal file → Executable file
7
src/bindings/bindings.h
Normal file → Executable file
|
@ -18,7 +18,7 @@ extern "C" {
|
||||||
struct quicklist;
|
struct quicklist;
|
||||||
|
|
||||||
int tolua_sqlite_open(struct lua_State *L);
|
int tolua_sqlite_open(struct lua_State *L);
|
||||||
int tolua_eressea_open(struct lua_State *L);
|
int tolua_bindings_open(struct lua_State *L);
|
||||||
int tolua_spelllist_next(struct lua_State *L);
|
int tolua_spelllist_next(struct lua_State *L);
|
||||||
int tolua_itemlist_next(struct lua_State *L);
|
int tolua_itemlist_next(struct lua_State *L);
|
||||||
int tolua_orderlist_next(struct lua_State *L);
|
int tolua_orderlist_next(struct lua_State *L);
|
||||||
|
@ -26,6 +26,11 @@ extern "C" {
|
||||||
const char *elem_type, struct quicklist *list);
|
const char *elem_type, struct quicklist *list);
|
||||||
|
|
||||||
int log_lua_error(struct lua_State *L);
|
int log_lua_error(struct lua_State *L);
|
||||||
|
|
||||||
|
void lua_done(struct lua_State *L);
|
||||||
|
struct lua_State *lua_init(void);
|
||||||
|
int eressea_run(struct lua_State *L, const char *luafile, const char *entry_point);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
7
src/bindings/eressea.pkg
Executable file
7
src/bindings/eressea.pkg
Executable file
|
@ -0,0 +1,7 @@
|
||||||
|
$#include <bindings/bind_eressea.h>
|
||||||
|
|
||||||
|
module eressea {
|
||||||
|
void eressea_free_game @ free_game(void);
|
||||||
|
int eressea_read_game @ read_game(const char * filename);
|
||||||
|
int eressea_write_game @ write_game(const char * filename);
|
||||||
|
}
|
8
src/bindings/process.pkg
Executable file
8
src/bindings/process.pkg
Executable file
|
@ -0,0 +1,8 @@
|
||||||
|
$#include <bindings/bind_process.h>
|
||||||
|
|
||||||
|
module eressea {
|
||||||
|
module process {
|
||||||
|
void process_markets @ markets(void);
|
||||||
|
void process_produce @ produce(void);
|
||||||
|
}
|
||||||
|
}
|
8
src/bindings/settings.pkg
Executable file
8
src/bindings/settings.pkg
Executable file
|
@ -0,0 +1,8 @@
|
||||||
|
$#include <bindings/bind_settings.h>
|
||||||
|
|
||||||
|
module eressea {
|
||||||
|
module settings {
|
||||||
|
void settings_set @ set(const char *key, const char *value);
|
||||||
|
const char * settings_get @ get(const char *key);
|
||||||
|
}
|
||||||
|
}
|
134
src/eressea.c
Normal file → Executable file
134
src/eressea.c
Normal file → Executable file
|
@ -3,30 +3,8 @@
|
||||||
#include "eressea.h"
|
#include "eressea.h"
|
||||||
|
|
||||||
#include <kernel/config.h>
|
#include <kernel/config.h>
|
||||||
#include <util/console.h>
|
|
||||||
#include <util/log.h>
|
#include <util/log.h>
|
||||||
|
|
||||||
/* lua includes */
|
|
||||||
#ifdef BINDINGS_TOLUA
|
|
||||||
#include <lua.h>
|
|
||||||
#include <lualib.h>
|
|
||||||
#include <lauxlib.h>
|
|
||||||
#include <bindings/bindings.h>
|
|
||||||
#include <bindings/helpers.h>
|
|
||||||
#ifdef BSON_ATTRIB
|
|
||||||
# include <bindings/bind_attrib.h>
|
|
||||||
#endif
|
|
||||||
#include <bindings/bind_building.h>
|
|
||||||
#include <bindings/bind_faction.h>
|
|
||||||
#include <bindings/bind_gmtool.h>
|
|
||||||
#include <bindings/bind_hashtable.h>
|
|
||||||
#include <bindings/bind_message.h>
|
|
||||||
#include <bindings/bind_region.h>
|
|
||||||
#include <bindings/bind_ship.h>
|
|
||||||
#include <bindings/bind_storage.h>
|
|
||||||
#include <bindings/bind_unit.h>
|
|
||||||
#endif /* BINDINGS_TOLUA */
|
|
||||||
|
|
||||||
#if MUSEUM_MODULE
|
#if MUSEUM_MODULE
|
||||||
#include <modules/museum.h>
|
#include <modules/museum.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -52,68 +30,7 @@
|
||||||
#include <items/itemtypes.h>
|
#include <items/itemtypes.h>
|
||||||
#include <attributes/attributes.h>
|
#include <attributes/attributes.h>
|
||||||
|
|
||||||
static const struct {
|
void game_done(void)
|
||||||
const char *name;
|
|
||||||
int (*func) (lua_State *);
|
|
||||||
} lualibs[] = {
|
|
||||||
{
|
|
||||||
"", luaopen_base}, {
|
|
||||||
LUA_TABLIBNAME, luaopen_table}, {
|
|
||||||
LUA_IOLIBNAME, luaopen_io}, {
|
|
||||||
LUA_STRLIBNAME, luaopen_string}, {
|
|
||||||
LUA_MATHLIBNAME, luaopen_math}, {
|
|
||||||
LUA_LOADLIBNAME, luaopen_package}, {
|
|
||||||
LUA_DBLIBNAME, luaopen_debug},
|
|
||||||
#if LUA_VERSION_NUM>=501
|
|
||||||
{
|
|
||||||
LUA_OSLIBNAME, luaopen_os},
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static void openlibs(lua_State * L)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for (i = 0; lualibs[i].func; ++i) {
|
|
||||||
lua_pushcfunction(L, lualibs[i].func);
|
|
||||||
lua_pushstring(L, lualibs[i].name);
|
|
||||||
lua_call(L, 1, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void lua_done(lua_State * L)
|
|
||||||
{
|
|
||||||
lua_close(L);
|
|
||||||
}
|
|
||||||
|
|
||||||
static lua_State *lua_init(void)
|
|
||||||
{
|
|
||||||
lua_State *L = lua_open();
|
|
||||||
|
|
||||||
openlibs(L);
|
|
||||||
#ifdef BINDINGS_TOLUA
|
|
||||||
register_tolua_helpers();
|
|
||||||
tolua_eressea_open(L);
|
|
||||||
tolua_sqlite_open(L);
|
|
||||||
tolua_unit_open(L);
|
|
||||||
tolua_building_open(L);
|
|
||||||
tolua_ship_open(L);
|
|
||||||
tolua_region_open(L);
|
|
||||||
tolua_faction_open(L);
|
|
||||||
#ifdef BSON_ATTRIB
|
|
||||||
tolua_attrib_open(L);
|
|
||||||
#endif
|
|
||||||
tolua_unit_open(L);
|
|
||||||
tolua_message_open(L);
|
|
||||||
tolua_hashtable_open(L);
|
|
||||||
tolua_gmtool_open(L);
|
|
||||||
tolua_storage_open(L);
|
|
||||||
#endif
|
|
||||||
return L;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void game_done(void)
|
|
||||||
{
|
{
|
||||||
#ifdef CLEANUP_CODE
|
#ifdef CLEANUP_CODE
|
||||||
/* Diese Routine enfernt allen allokierten Speicher wieder. Das ist nur
|
/* Diese Routine enfernt allen allokierten Speicher wieder. Das ist nur
|
||||||
|
@ -129,10 +46,12 @@ static void game_done(void)
|
||||||
#endif
|
#endif
|
||||||
calendar_cleanup();
|
calendar_cleanup();
|
||||||
#endif
|
#endif
|
||||||
|
kernel_done();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void game_init(void)
|
void game_init(void)
|
||||||
{
|
{
|
||||||
|
kernel_init();
|
||||||
register_triggers();
|
register_triggers();
|
||||||
register_xmas();
|
register_xmas();
|
||||||
|
|
||||||
|
@ -165,48 +84,3 @@ static void game_init(void)
|
||||||
register_gmcmd();
|
register_gmcmd();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int eressea_init(void)
|
|
||||||
{
|
|
||||||
global.vm_state = lua_init();
|
|
||||||
kernel_init();
|
|
||||||
game_init();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void eressea_done(void)
|
|
||||||
{
|
|
||||||
game_done();
|
|
||||||
kernel_done();
|
|
||||||
lua_done((lua_State *) global.vm_state);
|
|
||||||
}
|
|
||||||
|
|
||||||
int eressea_run(const char *luafile, const char *entry_point)
|
|
||||||
{
|
|
||||||
int err;
|
|
||||||
lua_State *L = (lua_State *) global.vm_state;
|
|
||||||
/* run the main script */
|
|
||||||
if (luafile) {
|
|
||||||
lua_getglobal(L, "dofile");
|
|
||||||
lua_pushstring(L, luafile);
|
|
||||||
err = lua_pcall(L, 1, 0, 0);
|
|
||||||
if (err != 0) {
|
|
||||||
log_lua_error(L);
|
|
||||||
abort();
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (entry_point) {
|
|
||||||
lua_getglobal(L, entry_point);
|
|
||||||
err = lua_pcall(L, 0, 1, 0);
|
|
||||||
if (err != 0) {
|
|
||||||
log_lua_error(L);
|
|
||||||
abort();
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
err = lua_console(L);
|
|
||||||
}
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
5
src/eressea.h
Normal file → Executable file
5
src/eressea.h
Normal file → Executable file
|
@ -4,9 +4,8 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int eressea_init(void);
|
void game_init(void);
|
||||||
void eressea_done(void);
|
void game_done(void);
|
||||||
int eressea_run(const char *luafile, const char *entry_point);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
9
src/kernel/faction.c
Normal file → Executable file
9
src/kernel/faction.c
Normal file → Executable file
|
@ -284,19 +284,22 @@ void destroyfaction(faction * f)
|
||||||
unit *u = f->units;
|
unit *u = f->units;
|
||||||
faction *ff;
|
faction *ff;
|
||||||
|
|
||||||
if (!f->alive)
|
if (!f->alive) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
fset(f, FFL_QUIT);
|
fset(f, FFL_QUIT);
|
||||||
|
|
||||||
|
if (f->spellbook) {
|
||||||
spellbook_clear(f->spellbook);
|
spellbook_clear(f->spellbook);
|
||||||
free(f->spellbook);
|
free(f->spellbook);
|
||||||
f->spellbook = 0;
|
f->spellbook = 0;
|
||||||
|
}
|
||||||
while (f->battles) {
|
while (f->battles) {
|
||||||
struct bmsg *bm = f->battles;
|
struct bmsg *bm = f->battles;
|
||||||
f->battles = bm->next;
|
f->battles = bm->next;
|
||||||
if (bm->msgs)
|
if (bm->msgs) {
|
||||||
free_messagelist(bm->msgs);
|
free_messagelist(bm->msgs);
|
||||||
|
}
|
||||||
free(bm);
|
free(bm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue