forked from github/server
- Neues Script für Jadee/Wente-Gates, nur Braut/Bräutigam durchlassen
- SQL-Stream verbessert, File wird nur erzeugt wenn auch geschrieben wird.
This commit is contained in:
parent
565b78bcd4
commit
f1328bff7c
10 changed files with 76 additions and 53 deletions
|
@ -121,8 +121,10 @@ restart_race(unit *u, const race * rc)
|
||||||
order ** ordp = &u->orders;
|
order ** ordp = &u->orders;
|
||||||
f->subscription = u->faction->subscription;
|
f->subscription = u->faction->subscription;
|
||||||
fset(f, FFL_RESTART);
|
fset(f, FFL_RESTART);
|
||||||
if (f->subscription) fprintf(sqlstream, "UPDATE subscriptions set faction='%s', race='%s' where id=%u;\n",
|
if (f->subscription) {
|
||||||
itoa36(f->no), dbrace(rc), f->subscription);
|
sql_print(("UPDATE subscriptions set faction='%s', race='%s' where id=%u;\n",
|
||||||
|
itoa36(f->no), dbrace(rc), f->subscription));
|
||||||
|
}
|
||||||
f->magiegebiet = u->faction->magiegebiet;
|
f->magiegebiet = u->faction->magiegebiet;
|
||||||
f->options = u->faction->options;
|
f->options = u->faction->options;
|
||||||
free_orders(&nu->orders);
|
free_orders(&nu->orders);
|
||||||
|
@ -1208,15 +1210,15 @@ parse_quit(void)
|
||||||
char info[256];
|
char info[256];
|
||||||
sprintf(info, "%d Einheiten, %d Personen, %d Silber",
|
sprintf(info, "%d Einheiten, %d Personen, %d Silber",
|
||||||
f->no_units, f->number, f->money);
|
f->no_units, f->number, f->money);
|
||||||
if (f->subscription) fprintf(sqlstream,
|
if (f->subscription) {
|
||||||
"UPDATE subscriptions SET lastturn=%d, password='%s', info='%s' "
|
sql_print(("UPDATE subscriptions SET lastturn=%d, password='%s', info='%s' WHERE id=%u;\n",
|
||||||
"WHERE id=%u;\n",
|
f->lastorders, f->override, info, f->subscription));
|
||||||
f->lastorders, f->override, info, f->subscription);
|
}
|
||||||
} else {
|
} else {
|
||||||
if (f->subscription) fprintf(sqlstream,
|
if (f->subscription) {
|
||||||
"UPDATE subscriptions SET status='ACTIVE', lastturn=%d, password='%s' "
|
sql_print(("UPDATE subscriptions SET status='ACTIVE', lastturn=%d, password='%s' WHERE id=%u;\n",
|
||||||
"WHERE id=%u;\n",
|
f->lastorders, f->override, f->subscription));
|
||||||
f->lastorders, f->override, f->subscription);
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (NMRTimeout()>0 && turn - f->lastorders >= (NMRTimeout() - 1)) {
|
if (NMRTimeout()>0 && turn - f->lastorders >= (NMRTimeout() - 1)) {
|
||||||
|
@ -2797,9 +2799,10 @@ renumber_factions(void)
|
||||||
for (rp=renum;rp;rp=rp->next) {
|
for (rp=renum;rp;rp=rp->next) {
|
||||||
f = rp->faction;
|
f = rp->faction;
|
||||||
a_remove(&f->attribs, rp->attrib);
|
a_remove(&f->attribs, rp->attrib);
|
||||||
if (f->subscription) fprintf(sqlstream, "UPDATE subscriptions set faction='%s' where "
|
if (f->subscription) {
|
||||||
"id=%u;\n", itoa36(rp->want),
|
sql_print(("UPDATE subscriptions set faction='%s' where id=%u;\n",
|
||||||
f->subscription);
|
itoa36(rp->want), f->subscription));
|
||||||
|
}
|
||||||
f->no = rp->want;
|
f->no = rp->want;
|
||||||
register_faction_id(rp->want);
|
register_faction_id(rp->want);
|
||||||
fset(f, FF_NEWID);
|
fset(f, FF_NEWID);
|
||||||
|
|
|
@ -2354,7 +2354,7 @@ kernel_done(void)
|
||||||
translation_done();
|
translation_done();
|
||||||
skill_done();
|
skill_done();
|
||||||
gc_done();
|
gc_done();
|
||||||
if (sqlstream!=NULL) sql_done();
|
sql_done();
|
||||||
}
|
}
|
||||||
|
|
||||||
const char * localenames[] = {
|
const char * localenames[] = {
|
||||||
|
@ -2494,14 +2494,12 @@ remove_empty_factions(boolean writedropouts)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (f->subscription) fprintf(sqlstream, "UPDATE subscriptions set status='DEAD' where "
|
if (f->subscription) {
|
||||||
"id=%u\n;", f->subscription);
|
sql_print(("UPDATE subscriptions set status='DEAD' where id=%u\n;",
|
||||||
|
f->subscription));
|
||||||
|
}
|
||||||
|
|
||||||
*fp = f->next;
|
*fp = f->next;
|
||||||
/* stripfaction(f);
|
|
||||||
* free(f);
|
|
||||||
* Wir können die nicht löschen, weil sie evtl. noch in attributen
|
|
||||||
* referenziert sind ! */
|
|
||||||
}
|
}
|
||||||
else fp = &(*fp)->next;
|
else fp = &(*fp)->next;
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,30 +49,24 @@ info_name(const tnode * tnext, const char * str, void * data, struct order * ord
|
||||||
unused(str);
|
unused(str);
|
||||||
unused(data);
|
unused(data);
|
||||||
unused(ord);
|
unused(ord);
|
||||||
if (sqlstream!=NULL) {
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
info_address(const tnode * tnext, const char * str, void * data, struct order * ord)
|
info_address(const tnode * tnext, const char * str, void * data, struct order * ord)
|
||||||
{
|
{
|
||||||
if (sqlstream!=NULL) {
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
info_phone(const tnode * tnext, const char * str, void * data, struct order * ord)
|
info_phone(const tnode * tnext, const char * str, void * data, struct order * ord)
|
||||||
{
|
{
|
||||||
if (sqlstream!=NULL) {
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
info_vacation(const tnode * tnext, const char * str, void * data, struct order * ord)
|
info_vacation(const tnode * tnext, const char * str, void * data, struct order * ord)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (sqlstream!=NULL) {
|
|
||||||
#ifdef SQLOUTPUT
|
#ifdef SQLOUTPUT
|
||||||
|
if (sqlstream!=NULL) {
|
||||||
unit * u = (unit*)data;
|
unit * u = (unit*)data;
|
||||||
faction * f = u->faction;
|
faction * f = u->faction;
|
||||||
const char * email = sqlquote(igetstrtoken(str));
|
const char * email = sqlquote(igetstrtoken(str));
|
||||||
|
@ -86,8 +80,8 @@ info_vacation(const tnode * tnext, const char * str, void * data, struct order *
|
||||||
start.tm_year, start.tm_mon, start.tm_mday, itoa36(f->no));
|
start.tm_year, start.tm_mon, start.tm_mday, itoa36(f->no));
|
||||||
fprintf(sqlstream, "UPDATE factions SET vacation_end = '%04d-%02d-%02d' WHERE id = '%s';\n",
|
fprintf(sqlstream, "UPDATE factions SET vacation_end = '%04d-%02d-%02d' WHERE id = '%s';\n",
|
||||||
end.tm_year, end.tm_mon, end.tm_mday, itoa36(f->no));
|
end.tm_year, end.tm_mon, end.tm_mday, itoa36(f->no));
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static tnode g_keys;
|
static tnode g_keys;
|
||||||
|
@ -112,7 +106,6 @@ infocommands(void)
|
||||||
}
|
}
|
||||||
if (*rp==r) rp = &r->next;
|
if (*rp==r) rp = &r->next;
|
||||||
}
|
}
|
||||||
fflush(sqlstream);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -24,18 +24,32 @@
|
||||||
|
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
FILE * sqlstream;
|
#include <stdarg.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
static FILE * sqlstream = NULL;
|
||||||
|
static char * sqlfilename = NULL;
|
||||||
|
|
||||||
void
|
void
|
||||||
sql_init(const char * filename)
|
sql_init(const char * filename)
|
||||||
{
|
{
|
||||||
static boolean init = false;
|
if (sqlfilename!=NULL) free(sqlfilename);
|
||||||
if (!init) {
|
sqlfilename = strdup(filename);
|
||||||
sqlstream = fopen(filename, "wt+");
|
|
||||||
if (sqlstream==NULL) {
|
|
||||||
log_error(("could not open file: %s\n", filename));
|
|
||||||
}
|
}
|
||||||
init = true;
|
|
||||||
|
void
|
||||||
|
_sql_print(const char * format, ...)
|
||||||
|
{
|
||||||
|
if (!sqlstream && sqlfilename) {
|
||||||
|
sqlstream=fopen(sqlfilename, "wt+");
|
||||||
|
free(sqlfilename);
|
||||||
|
sqlfilename=NULL;
|
||||||
|
}
|
||||||
|
if (sqlstream!=NULL) {
|
||||||
|
va_list marker;
|
||||||
|
va_start(marker, format);
|
||||||
|
vfprintf(sqlstream, format, marker);
|
||||||
|
va_end(marker);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +57,9 @@ void
|
||||||
sql_done(void)
|
sql_done(void)
|
||||||
{
|
{
|
||||||
if (sqlstream) fclose(sqlstream);
|
if (sqlstream) fclose(sqlstream);
|
||||||
/* TODO */
|
if (sqlfilename) free(sqlfilename);
|
||||||
|
sqlstream=NULL;
|
||||||
|
sqlfilename=NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
|
|
|
@ -25,10 +25,12 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern FILE * sqlstream;
|
|
||||||
extern void sql_init(const char * filename);
|
extern void sql_init(const char * filename);
|
||||||
extern void sql_done(void);
|
extern void sql_done(void);
|
||||||
extern const char * sqlquote(const char * str);
|
extern const char * sqlquote(const char * str);
|
||||||
|
extern void _sql_print(const char * format, ...);
|
||||||
|
|
||||||
|
#define sql_print(x) _sql_print x
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,6 +71,7 @@ lc_write(const struct attrib * a, FILE* F)
|
||||||
|
|
||||||
write_building_reference(b, F);
|
write_building_reference(b, F);
|
||||||
fwritestr(F, fname);
|
fwritestr(F, fname);
|
||||||
|
fputc(' ', F);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include <attributes/key.h>
|
#include <attributes/key.h>
|
||||||
|
|
||||||
// kernel includes
|
// kernel includes
|
||||||
|
#include <kernel/building.h>
|
||||||
#include <kernel/faction.h>
|
#include <kernel/faction.h>
|
||||||
#include <kernel/item.h>
|
#include <kernel/item.h>
|
||||||
#include <kernel/magic.h>
|
#include <kernel/magic.h>
|
||||||
|
@ -232,7 +233,7 @@ unit_getregion(const unit& u)
|
||||||
static void
|
static void
|
||||||
unit_setbuilding(unit& u, building& b)
|
unit_setbuilding(unit& u, building& b)
|
||||||
{
|
{
|
||||||
leave(u.region, u);
|
leave(u.region, &u);
|
||||||
u.building = &b;
|
u.building = &b;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -549,11 +549,11 @@ void
|
||||||
confirm_newbies(void)
|
confirm_newbies(void)
|
||||||
{
|
{
|
||||||
faction * f = factions;
|
faction * f = factions;
|
||||||
if (sqlstream==NULL) return;
|
|
||||||
while (f) {
|
while (f) {
|
||||||
if (!fval(f, FFL_DBENTRY)) {
|
if (!fval(f, FFL_DBENTRY)) {
|
||||||
if (f->subscription) {
|
if (f->subscription) {
|
||||||
fprintf(sqlstream, "UPDATE subscriptions SET status='ACTIVE', faction='%s', race='%s' WHERE id=%u;\n", itoa36(f->no), dbrace(f->race), f->subscription);
|
sql_print(("UPDATE subscriptions SET status='ACTIVE', faction='%s', race='%s' WHERE id=%u;\n",
|
||||||
|
itoa36(f->no), dbrace(f->race), f->subscription));
|
||||||
fset(f, FFL_DBENTRY);
|
fset(f, FFL_DBENTRY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,20 +6,29 @@ hellgate = nil
|
||||||
peacegate = nil
|
peacegate = nil
|
||||||
|
|
||||||
function gate_exchange(b1, b2)
|
function gate_exchange(b1, b2)
|
||||||
local units = {}
|
local units1 = {}
|
||||||
|
local units2 = {}
|
||||||
local u
|
local u
|
||||||
for u in b1.units do
|
for u in b1.units do
|
||||||
units[u.no] = u
|
if u:get_flag("wdgt") then
|
||||||
|
units1[u.no] = u
|
||||||
|
end
|
||||||
end
|
end
|
||||||
for u in b2.units do
|
for u in b2.units do
|
||||||
u.region = b1.region
|
if u:get_flag("wdgt") then
|
||||||
u.building = b1
|
units2[u.no] = u
|
||||||
end
|
end
|
||||||
for id in units do
|
end
|
||||||
u = units[id]
|
for id in units1 do
|
||||||
|
u = units1[id]
|
||||||
u.region = b2.region
|
u.region = b2.region
|
||||||
u.building = b2
|
u.building = b2
|
||||||
end
|
end
|
||||||
|
for id in units2 do
|
||||||
|
u = units2[id]
|
||||||
|
u.region = b1.region
|
||||||
|
u.building = b1
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function hellgate_action(b)
|
function hellgate_action(b)
|
||||||
|
|
Loading…
Reference in a new issue