forked from github/server
NMR-Zaehlung auch fuer LUA
This commit is contained in:
parent
7590fa50ef
commit
c3e4e828a8
7 changed files with 73 additions and 38 deletions
|
@ -2646,18 +2646,15 @@ report_summary(summary * s, summary * o, boolean full)
|
||||||
FILE * F = NULL;
|
FILE * F = NULL;
|
||||||
int i, newplayers = 0;
|
int i, newplayers = 0;
|
||||||
faction * f;
|
faction * f;
|
||||||
int * nmrs = malloc(sizeof(int)*(NMRTimeout()+1));
|
char zText[MAX_PATH];
|
||||||
|
|
||||||
{
|
if (full) {
|
||||||
char zText[MAX_PATH];
|
sprintf(zText, "%s/parteien.full", basepath());
|
||||||
if (full) {
|
} else {
|
||||||
sprintf(zText, "%s/parteien.full", basepath());
|
sprintf(zText, "%s/parteien", basepath());
|
||||||
} else {
|
|
||||||
sprintf(zText, "%s/parteien", basepath());
|
|
||||||
}
|
|
||||||
F = cfopen(zText, "w");
|
|
||||||
if (!F) return;
|
|
||||||
}
|
}
|
||||||
|
F = cfopen(zText, "w");
|
||||||
|
if (!F) return;
|
||||||
printf("Schreibe Zusammenfassung (parteien)...\n");
|
printf("Schreibe Zusammenfassung (parteien)...\n");
|
||||||
fprintf(F, "%s\n%s\n\n", global.gamename, gamedate2(default_locale));
|
fprintf(F, "%s\n%s\n\n", global.gamename, gamedate2(default_locale));
|
||||||
fprintf(F, "Auswertung Nr: %d\n\n", turn);
|
fprintf(F, "Auswertung Nr: %d\n\n", turn);
|
||||||
|
@ -2751,24 +2748,8 @@ report_summary(summary * s, summary * o, boolean full)
|
||||||
|
|
||||||
fprintf(F, "\n\n");
|
fprintf(F, "\n\n");
|
||||||
|
|
||||||
for (i = 0; i <= NMRTimeout(); ++i) {
|
newplayers = update_nmrs();
|
||||||
nmrs[i] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (f = factions; f; f = f->next) {
|
|
||||||
if (fval(f, FFL_ISNEW)) {
|
|
||||||
++newplayers;
|
|
||||||
} else if (f->no != MONSTER_FACTION) {
|
|
||||||
int nmr = turn-f->lastorders;
|
|
||||||
if (nmr<0 || nmr>NMRTimeout()) {
|
|
||||||
log_error(("faction %s has %d NMRS\n", factionid(f), nmr));
|
|
||||||
nmr = max(0, nmr);
|
|
||||||
nmr = min(nmr, NMRTimeout());
|
|
||||||
}
|
|
||||||
nmrs[nmr]++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i <= NMRTimeout(); ++i) {
|
for (i = 0; i <= NMRTimeout(); ++i) {
|
||||||
if (i == NMRTimeout()) {
|
if (i == NMRTimeout()) {
|
||||||
fprintf(F, "+ NMRs:\t\t %d\n", nmrs[i]);
|
fprintf(F, "+ NMRs:\t\t %d\n", nmrs[i]);
|
||||||
|
@ -2827,6 +2808,7 @@ report_summary(summary * s, summary * o, boolean full)
|
||||||
writemonument();
|
writemonument();
|
||||||
}
|
}
|
||||||
free(nmrs);
|
free(nmrs);
|
||||||
|
nmrs = NULL;
|
||||||
}
|
}
|
||||||
/******* end summary ******/
|
/******* end summary ******/
|
||||||
|
|
||||||
|
|
|
@ -164,6 +164,35 @@ report_item(const unit * owner, const item * i, const faction * viewer, const ch
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int * nmrs = NULL;
|
||||||
|
|
||||||
|
int
|
||||||
|
update_nmrs(void)
|
||||||
|
{
|
||||||
|
int i, newplayers =0;
|
||||||
|
faction *f;
|
||||||
|
|
||||||
|
if (nmrs==NULL) nmrs = malloc(sizeof(int)*(NMRTimeout()+1));
|
||||||
|
for (i = 0; i <= NMRTimeout(); ++i) {
|
||||||
|
nmrs[i] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (f = factions; f; f = f->next) {
|
||||||
|
if (fval(f, FFL_ISNEW)) {
|
||||||
|
++newplayers;
|
||||||
|
} else if (f->no != MONSTER_FACTION) {
|
||||||
|
int nmr = turn-f->lastorders;
|
||||||
|
if (nmr<0 || nmr>NMRTimeout()) {
|
||||||
|
log_error(("faction %s has %d NMRS\n", factionid(f), nmr));
|
||||||
|
nmr = max(0, nmr);
|
||||||
|
nmr = min(nmr, NMRTimeout());
|
||||||
|
}
|
||||||
|
++nmrs[nmr];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return newplayers;
|
||||||
|
}
|
||||||
|
|
||||||
#define ORDERS_IN_NR 1
|
#define ORDERS_IN_NR 1
|
||||||
static size_t
|
static size_t
|
||||||
buforder(char * bufp, size_t size, const order * ord, int mode)
|
buforder(char * bufp, size_t size, const order * ord, int mode)
|
||||||
|
|
|
@ -103,7 +103,10 @@ extern int bufunit(const struct faction * f, const struct unit * u, int indent,
|
||||||
extern const char * reportpath(void);
|
extern const char * reportpath(void);
|
||||||
extern const char * trailinto(const struct region * r, const struct locale * lang);
|
extern const char * trailinto(const struct region * r, const struct locale * lang);
|
||||||
|
|
||||||
extern void reports_init(void);
|
extern void reports_init(void);
|
||||||
|
|
||||||
|
extern int update_nmrs(void);
|
||||||
|
extern int * nmrs;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -559,14 +559,14 @@ factionorders(void)
|
||||||
/* Die Partei hat sich zumindest gemeldet, so daß sie noch
|
/* Die Partei hat sich zumindest gemeldet, so daß sie noch
|
||||||
* nicht als untätig gilt */
|
* nicht als untätig gilt */
|
||||||
|
|
||||||
/* TODO: +1 ist ein Workaround, weil turn erst in process_orders
|
/* TODO: +1 ist ein Workaround, weil turn erst in process_orders
|
||||||
* incrementiert wird. */
|
* incrementiert wird. */
|
||||||
f->lastorders = global.data_turn+1;
|
f->lastorders = global.data_turn+1;
|
||||||
|
|
||||||
} else
|
} else {
|
||||||
log_warning(("Befehle für die ungültige Partei %s\n", fid));
|
log_warning(("Befehle für die ungültige Partei %s\n", fid));
|
||||||
|
}
|
||||||
return f;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
double
|
double
|
||||||
|
|
|
@ -51,6 +51,16 @@ get_turn(void)
|
||||||
return turn;
|
return turn;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
get_nmrs(int n)
|
||||||
|
{
|
||||||
|
if (n<=NMRTimeout()) {
|
||||||
|
if (nmrs==NULL) update_nmrs();
|
||||||
|
return nmrs[n];
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
find_plane_id(const char * name)
|
find_plane_id(const char * name)
|
||||||
{
|
{
|
||||||
|
@ -229,6 +239,7 @@ bind_eressea(lua_State * L)
|
||||||
def("dice_roll", &dice_rand),
|
def("dice_roll", &dice_rand),
|
||||||
def("equipment_setitem", &lua_addequipment),
|
def("equipment_setitem", &lua_addequipment),
|
||||||
def("get_turn", &get_turn),
|
def("get_turn", &get_turn),
|
||||||
|
def("get_nmrs", &get_nmrs),
|
||||||
def("remove_empty_units", &remove_empty_units),
|
def("remove_empty_units", &remove_empty_units),
|
||||||
|
|
||||||
def("update_subscriptions", &update_subscriptions),
|
def("update_subscriptions", &update_subscriptions),
|
||||||
|
|
|
@ -62,6 +62,12 @@ function process(orders)
|
||||||
print("could not read " .. orders)
|
print("could not read " .. orders)
|
||||||
return -1
|
return -1
|
||||||
end
|
end
|
||||||
|
nmrs = get_nmrs(1)
|
||||||
|
if nmrs >= 60 then
|
||||||
|
print("Shit. More than 60 factions with 1 NMR (" .. nmrs .. ")")
|
||||||
|
return -1
|
||||||
|
fi
|
||||||
|
print (nmrs .. " Factions with 1 NMR")
|
||||||
run_scripts()
|
run_scripts()
|
||||||
|
|
||||||
-- create new monsters:
|
-- create new monsters:
|
||||||
|
|
|
@ -1,5 +1,9 @@
|
||||||
local function kill_multis()
|
local function kill_multis()
|
||||||
local multis = { ["ms04"]="Wird wegen Parteiuebernahme geloescht" }
|
local multis = {
|
||||||
|
-- ["Luna"]="Wird wegen Missbrauch von Sonnensegeln geloescht",
|
||||||
|
-- ["amam"]="Wird wegen Missbrauch von Sonnensegeln geloescht",
|
||||||
|
-- ["jr81"]="Wird wegen Missbrauch von Sonnensegeln geloescht"
|
||||||
|
}
|
||||||
for k, v in multis do
|
for k, v in multis do
|
||||||
local f = get_faction(atoi36(k))
|
local f = get_faction(atoi36(k))
|
||||||
if f~=nil then
|
if f~=nil then
|
||||||
|
|
Loading…
Reference in a new issue