1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
|
#include "pilercr.h"
static int GetTargetPos(int QueryPos, int DiagIndex)
{
return QueryPos - DiagIndex;
}
static void SaveTrap(FILE *f, const Trapezoid &Trap)
{
int QueryFrom = Trap.bot;
int QueryTo = Trap.top;
int TargetFrom = GetTargetPos(Trap.bot, Trap.rgt);
int TargetTo = GetTargetPos(Trap.top, Trap.lft);
WriteGFFRecord(f, QueryFrom, QueryTo, TargetFrom, TargetTo, false, "trap", 0, 0);
}
void SaveTraps(const Trapezoid *Traps)
{
const char *FileName = ValueOpt("traps");
if (FileName == 0)
return;
FILE *f = CreateStdioFile(FileName);
for (const Trapezoid *Trap = Traps; Trap; Trap = Trap->next)
SaveTrap(f, *Trap);
fclose(f);
}
static void LogTrap(const Trapezoid &Trap)
{
int TargetFrom = GetTargetPos(Trap.bot, Trap.rgt);
int TargetTo = GetTargetPos(Trap.top, Trap.lft);
Log("%10d %10d %10d %10d %10d %10d\n",
Trap.bot, Trap.top, Trap.lft, Trap.rgt, TargetFrom, TargetTo);
}
void LogTraps(const Trapezoid *Traps)
{
if (!FlagOpt("logtraps"))
return;
Log("\n");
Log(" QFrom QTo Left Right TFrom TTo\n");
Log("========== ========== ========== ========== ========== ==========\n");
for (const Trapezoid *Trap = Traps; Trap; Trap = Trap->next)
LogTrap(*Trap);
Log("\n");
}
|