forked from github/server
bindings for the json export.
+ unit test (incomplete).
This commit is contained in:
parent
e8b28725e1
commit
dd3de9a1d7
9 changed files with 88 additions and 11 deletions
|
@ -59,12 +59,6 @@ TOLUA_BINDING(eressea.pkg bind_eressea.h)
|
||||||
TOLUA_BINDING(settings.pkg bind_settings.h)
|
TOLUA_BINDING(settings.pkg bind_settings.h)
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
set(TESTS
|
|
||||||
laws_test.c
|
|
||||||
economy_test.c
|
|
||||||
market_test.c
|
|
||||||
)
|
|
||||||
|
|
||||||
set (SERVER_SRC
|
set (SERVER_SRC
|
||||||
process.pkg.c
|
process.pkg.c
|
||||||
eressea.pkg.c
|
eressea.pkg.c
|
||||||
|
@ -133,6 +127,7 @@ set(SERVER_TEST_SRC
|
||||||
test_eressea.c
|
test_eressea.c
|
||||||
tests.c
|
tests.c
|
||||||
tests_test.c
|
tests_test.c
|
||||||
|
bindings_test.c
|
||||||
economy_test.c
|
economy_test.c
|
||||||
market_test.c
|
market_test.c
|
||||||
laws_test.c
|
laws_test.c
|
||||||
|
|
|
@ -1,11 +1,16 @@
|
||||||
#include "bind_eressea.h"
|
#include "bind_eressea.h"
|
||||||
|
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
|
|
||||||
|
#include "export.h"
|
||||||
|
|
||||||
#include <kernel/types.h>
|
#include <kernel/types.h>
|
||||||
#include <kernel/config.h>
|
#include <kernel/config.h>
|
||||||
#include <kernel/save.h>
|
#include <kernel/save.h>
|
||||||
|
|
||||||
#include <storage.h>
|
#include <stream.h>
|
||||||
|
#include <filestream.h>
|
||||||
|
|
||||||
|
|
||||||
void eressea_free_game(void) {
|
void eressea_free_game(void) {
|
||||||
free_gamedata();
|
free_gamedata();
|
||||||
|
@ -23,3 +28,17 @@ int eressea_write_game(const char * filename) {
|
||||||
int eressea_read_orders(const char * filename) {
|
int eressea_read_orders(const char * filename) {
|
||||||
return readorders(filename);
|
return readorders(filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int eressea_export_json(const char * filename, unsigned int flags) {
|
||||||
|
FILE *F = fopen(filename, "wt");
|
||||||
|
if (F) {
|
||||||
|
stream out = { 0 };
|
||||||
|
int err;
|
||||||
|
fstream_init(&out, F);
|
||||||
|
err = export_json(&out, flags);
|
||||||
|
fstream_done(&out);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
perror(filename);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ void eressea_free_game(void);
|
||||||
int eressea_read_game(const char * filename);
|
int eressea_read_game(const char * filename);
|
||||||
int eressea_write_game(const char * filename);
|
int eressea_write_game(const char * filename);
|
||||||
int eressea_read_orders(const char * filename);
|
int eressea_read_orders(const char * filename);
|
||||||
|
int eressea_export_json(const char * filename, unsigned int flags);
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
26
src/bindings_test.c
Normal file
26
src/bindings_test.c
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
#include <platform.h>
|
||||||
|
#include <CuTest.h>
|
||||||
|
#include <stream.h>
|
||||||
|
#include <memstream.h>
|
||||||
|
#include "export.h"
|
||||||
|
#include "bind_eressea.h"
|
||||||
|
|
||||||
|
static void test_export(CuTest * tc) {
|
||||||
|
char buf[1024];
|
||||||
|
stream out = { 0 };
|
||||||
|
int err;
|
||||||
|
|
||||||
|
mstream_init(&out);
|
||||||
|
err = export_json(&out, EXPORT_REGIONS);
|
||||||
|
CuAssertIntEquals(tc, 0, err);
|
||||||
|
out.api->rewind(out.handle);
|
||||||
|
out.api->readln(out.handle, buf, sizeof(buf));
|
||||||
|
CuAssertStrEquals(tc, "{}", buf);
|
||||||
|
mstream_done(&out);
|
||||||
|
}
|
||||||
|
|
||||||
|
CuSuite *get_bindings_suite(void) {
|
||||||
|
CuSuite *suite = CuSuiteNew();
|
||||||
|
SUITE_ADD_TEST(suite, test_export);
|
||||||
|
return suite;
|
||||||
|
}
|
|
@ -5,4 +5,5 @@ module eressea {
|
||||||
int eressea_read_game @ read_game(const char * filename);
|
int eressea_read_game @ read_game(const char * filename);
|
||||||
int eressea_write_game @ write_game(const char * filename);
|
int eressea_write_game @ write_game(const char * filename);
|
||||||
int eressea_read_orders @ read_orders(const char * filename);
|
int eressea_read_orders @ read_orders(const char * filename);
|
||||||
|
int eressea_export_json @ export(const char * filename, unsigned int flags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*
|
/*
|
||||||
** Lua binding: eressea
|
** Lua binding: eressea
|
||||||
** Generated automatically by tolua 5.1.3 on Sat Mar 8 10:21:00 2014.
|
** Generated automatically by tolua 5.1.3 on Thu Mar 13 14:40:47 2014.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "tolua.h"
|
#include "tolua.h"
|
||||||
|
@ -131,6 +131,35 @@ static int tolua_eressea_eressea_read_orders00(lua_State* tolua_S)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* function: eressea_export_json */
|
||||||
|
static int tolua_eressea_eressea_export00(lua_State* tolua_S)
|
||||||
|
{
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_Error tolua_err;
|
||||||
|
if (
|
||||||
|
!tolua_isstring(tolua_S,1,0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,2,0,&tolua_err) ||
|
||||||
|
!tolua_isnoobj(tolua_S,3,&tolua_err)
|
||||||
|
)
|
||||||
|
goto tolua_lerror;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
const char* filename = ((const char*) tolua_tostring(tolua_S,1,0));
|
||||||
|
unsigned int flags = ((unsigned int) tolua_tonumber(tolua_S,2,0));
|
||||||
|
{
|
||||||
|
int tolua_ret = (int) eressea_export_json(filename,flags);
|
||||||
|
tolua_pushnumber(tolua_S,(lua_Number)tolua_ret);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_lerror:
|
||||||
|
tolua_error(tolua_S,"#ferror in function 'export'.",&tolua_err);
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/* Open lib function */
|
/* Open lib function */
|
||||||
LUALIB_API int luaopen_eressea (lua_State* tolua_S)
|
LUALIB_API int luaopen_eressea (lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
|
@ -144,6 +173,7 @@ LUALIB_API int luaopen_eressea (lua_State* tolua_S)
|
||||||
tolua_function(tolua_S,"read_game",tolua_eressea_eressea_read_game00);
|
tolua_function(tolua_S,"read_game",tolua_eressea_eressea_read_game00);
|
||||||
tolua_function(tolua_S,"write_game",tolua_eressea_eressea_write_game00);
|
tolua_function(tolua_S,"write_game",tolua_eressea_eressea_write_game00);
|
||||||
tolua_function(tolua_S,"read_orders",tolua_eressea_eressea_read_orders00);
|
tolua_function(tolua_S,"read_orders",tolua_eressea_eressea_read_orders00);
|
||||||
|
tolua_function(tolua_S,"export",tolua_eressea_eressea_export00);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
|
@ -11,8 +11,11 @@
|
||||||
#include <stream.h>
|
#include <stream.h>
|
||||||
#include "cJSON.h"
|
#include "cJSON.h"
|
||||||
|
|
||||||
void export_json(stream * out, unsigned int flags) {
|
#include <assert.h>
|
||||||
|
|
||||||
|
int export_json(stream * out, unsigned int flags) {
|
||||||
cJSON *json, *root = cJSON_CreateObject();
|
cJSON *json, *root = cJSON_CreateObject();
|
||||||
|
assert(out && out->api);
|
||||||
if (flags & EXPORT_REGIONS) {
|
if (flags & EXPORT_REGIONS) {
|
||||||
region * r;
|
region * r;
|
||||||
cJSON_AddItemToObject(root, "regions", json = cJSON_CreateObject());
|
cJSON_AddItemToObject(root, "regions", json = cJSON_CreateObject());
|
||||||
|
@ -50,4 +53,5 @@ void export_json(stream * out, unsigned int flags) {
|
||||||
free(output);
|
free(output);
|
||||||
}
|
}
|
||||||
cJSON_Delete(root);
|
cJSON_Delete(root);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,6 @@
|
||||||
#define EXPORT_UNITS 1<<2
|
#define EXPORT_UNITS 1<<2
|
||||||
|
|
||||||
struct stream;
|
struct stream;
|
||||||
void export_json(struct stream * out, unsigned int flags);
|
int export_json(struct stream * out, unsigned int flags);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include <util/log.h>
|
#include <util/log.h>
|
||||||
|
|
||||||
CuSuite *get_tests_suite(void);
|
CuSuite *get_tests_suite(void);
|
||||||
|
CuSuite *get_bindings_suite(void);
|
||||||
CuSuite *get_economy_suite(void);
|
CuSuite *get_economy_suite(void);
|
||||||
CuSuite *get_laws_suite(void);
|
CuSuite *get_laws_suite(void);
|
||||||
CuSuite *get_market_suite(void);
|
CuSuite *get_market_suite(void);
|
||||||
|
@ -34,6 +35,7 @@ int RunAllTests(void)
|
||||||
|
|
||||||
/* self-test */
|
/* self-test */
|
||||||
CuSuiteAddSuite(suite, get_tests_suite());
|
CuSuiteAddSuite(suite, get_tests_suite());
|
||||||
|
CuSuiteAddSuite(suite, get_bindings_suite());
|
||||||
/* util */
|
/* util */
|
||||||
CuSuiteAddSuite(suite, get_base36_suite());
|
CuSuiteAddSuite(suite, get_base36_suite());
|
||||||
CuSuiteAddSuite(suite, get_bsdstring_suite());
|
CuSuiteAddSuite(suite, get_bsdstring_suite());
|
||||||
|
|
Loading…
Reference in a new issue