|
|
@ -459,6 +459,100 @@ static digmask diag5[5] =
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static digmask diag5r[5] =
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
{0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0},
|
|
|
|
|
|
|
|
{1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static digmask ladder[3] =
|
|
|
|
static digmask ladder[3] =
|
|
|
|
{
|
|
|
|
{
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -517,6 +611,64 @@ static digmask ladder[3] =
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static digmask ladderr[3] =
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0},
|
|
|
|
|
|
|
|
{0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static digmask all_tiles =
|
|
|
|
static digmask all_tiles =
|
|
|
|
{
|
|
|
|
{
|
|
|
|
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1},
|
|
|
|
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1},
|
|
|
@ -560,7 +712,9 @@ enum explo_how
|
|
|
|
{
|
|
|
|
{
|
|
|
|
EXPLO_NOTHING,
|
|
|
|
EXPLO_NOTHING,
|
|
|
|
EXPLO_DIAG5,
|
|
|
|
EXPLO_DIAG5,
|
|
|
|
|
|
|
|
EXPLO_DIAG5R,
|
|
|
|
EXPLO_LADDER,
|
|
|
|
EXPLO_LADDER,
|
|
|
|
|
|
|
|
EXPLO_LADDERR,
|
|
|
|
EXPLO_CLEAR,
|
|
|
|
EXPLO_CLEAR,
|
|
|
|
EXPLO_CROSS,
|
|
|
|
EXPLO_CROSS,
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -653,6 +807,10 @@ DFhackCExport command_result expdig (Core * c, vector <string> & parameters)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
how = EXPLO_DIAG5;
|
|
|
|
how = EXPLO_DIAG5;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else if(parameters[i] == "diag5r")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
how = EXPLO_DIAG5R;
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(parameters[i] == "clear")
|
|
|
|
else if(parameters[i] == "clear")
|
|
|
|
{
|
|
|
|
{
|
|
|
|
how = EXPLO_CLEAR;
|
|
|
|
how = EXPLO_CLEAR;
|
|
|
@ -661,6 +819,10 @@ DFhackCExport command_result expdig (Core * c, vector <string> & parameters)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
how = EXPLO_LADDER;
|
|
|
|
how = EXPLO_LADDER;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else if(parameters[i] == "ladderr")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
how = EXPLO_LADDERR;
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(parameters[i] == "cross")
|
|
|
|
else if(parameters[i] == "cross")
|
|
|
|
{
|
|
|
|
{
|
|
|
|
how = EXPLO_CROSS;
|
|
|
|
how = EXPLO_CROSS;
|
|
|
@ -674,7 +836,9 @@ DFhackCExport command_result expdig (Core * c, vector <string> & parameters)
|
|
|
|
"There are two variables that can be set: pattern and filter.\n"
|
|
|
|
"There are two variables that can be set: pattern and filter.\n"
|
|
|
|
"Patterns:\n"
|
|
|
|
"Patterns:\n"
|
|
|
|
" diag5 = diagonals separated by 5 tiles\n"
|
|
|
|
" diag5 = diagonals separated by 5 tiles\n"
|
|
|
|
" ladder = A 'ladder' pattern\n"
|
|
|
|
" diag5r = diag5 rotated 90 degrees\n"
|
|
|
|
|
|
|
|
" ladder = A 'ladder' pattern\n"
|
|
|
|
|
|
|
|
"ladderr = ladder rotated 90 degrees\n"
|
|
|
|
" clear = Just remove all dig designations\n"
|
|
|
|
" clear = Just remove all dig designations\n"
|
|
|
|
" cross = A cross, exactly in the middle of the map.\n"
|
|
|
|
" cross = A cross, exactly in the middle of the map.\n"
|
|
|
|
"Filters:\n"
|
|
|
|
"Filters:\n"
|
|
|
@ -719,6 +883,19 @@ DFhackCExport command_result expdig (Core * c, vector <string> & parameters)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else if(how == EXPLO_DIAG5R)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
int which;
|
|
|
|
|
|
|
|
for(uint32_t x = 0; x < x_max; x++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
for(int32_t y = 0 ; y < y_max; y++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
which = (4*x + 1000-y) % 5;
|
|
|
|
|
|
|
|
stamp_pattern(maps, x,y_max - 1 - y, z_level, diag5r[which],
|
|
|
|
|
|
|
|
how, what, x_max, y_max);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(how == EXPLO_LADDER)
|
|
|
|
else if(how == EXPLO_LADDER)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int which;
|
|
|
|
int which;
|
|
|
@ -732,6 +909,19 @@ DFhackCExport command_result expdig (Core * c, vector <string> & parameters)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else if(how == EXPLO_LADDERR)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
int which;
|
|
|
|
|
|
|
|
for(int32_t y = 0 ; y < y_max; y++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
which = y % 3;
|
|
|
|
|
|
|
|
for(uint32_t x = 0; x < x_max; x++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stamp_pattern(maps, x, y, z_level, ladderr[which],
|
|
|
|
|
|
|
|
how, what, x_max, y_max);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(how == EXPLO_CROSS)
|
|
|
|
else if(how == EXPLO_CROSS)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// middle + recentering for the image
|
|
|
|
// middle + recentering for the image
|
|
|
@ -941,4 +1131,4 @@ DFhackCExport command_result vdig (Core * c, vector <string> & parameters)
|
|
|
|
DFhackCExport command_result autodig (Core * c, vector <string> & parameters)
|
|
|
|
DFhackCExport command_result autodig (Core * c, vector <string> & parameters)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return CR_NOT_IMPLEMENTED;
|
|
|
|
return CR_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
}
|
|
|
|