Merge branch 'crashlog_improvements' into jgrpp

pull/59/head
Jonathan G Rennison 6 years ago
commit 4aa211e454

@ -15,6 +15,8 @@
#include "strings_func.h"
#include "company_base.h"
#include "vehicle_base.h"
#include "station_base.h"
#include "waypoint_base.h"
#include "table/strings.h"
#include "safeguards.h"
@ -106,4 +108,31 @@ const char *scope_dumper::VehicleInfo(const Vehicle *v)
return this->buffer;
}
const char *scope_dumper::StationInfo(const BaseStation *st)
{
char *b = this->buffer;
const char *last = lastof(this->buffer);
if (st) {
const bool waypoint = Waypoint::IsExpected(st);
b += seprintf(b, last, "%s: %u: (", waypoint ? "waypoint" : "station", st->index);
SetDParam(0, st->index);
b = GetString(b, waypoint ? STR_WAYPOINT_NAME : STR_STATION_NAME, last);
b += seprintf(b, last, ", c:%d, facil: ", (int) st->owner);
auto dump_facil = [&](char c, StationFacility flag) {
if (st->facilities & flag) b += seprintf(b, last, "%c", c);
};
dump_facil('R', FACIL_TRAIN);
dump_facil('T', FACIL_TRUCK_STOP);
dump_facil('B', FACIL_BUS_STOP);
dump_facil('A', FACIL_AIRPORT);
dump_facil('D', FACIL_DOCK);
dump_facil('W', FACIL_WAYPOINT);
b += seprintf(b, last, ")");
} else {
b += seprintf(b, last, "station/waypoint: NULL");
}
return this->buffer;
}
#endif

@ -17,6 +17,7 @@
#include <vector>
struct Vehicle;
struct BaseStation;
extern std::vector<std::function<int(char *, const char *)>> _scope_stack;
@ -61,6 +62,7 @@ int WriteScopeLog(char *buf, const char *last);
struct scope_dumper {
const char *CompanyInfo(int company_id);
const char *VehicleInfo(const Vehicle *v);
const char *StationInfo(const BaseStation *st);
private:
char buffer[256];

@ -1094,8 +1094,11 @@ void CallVehicleTicks()
if (_tick_skip_counter == 0) RunVehicleDayProc();
Station *st;
FOR_ALL_STATIONS(st) LoadUnloadStation(st);
{
Station *st = nullptr;
SCOPE_INFO_FMT([&st], "CallVehicleTicks: LoadUnloadStation: %s", scope_dumper().StationInfo(st));
FOR_ALL_STATIONS(st) LoadUnloadStation(st);
}
Vehicle *v = NULL;
SCOPE_INFO_FMT([&v], "CallVehicleTicks: %s", scope_dumper().VehicleInfo(v));

Loading…
Cancel
Save