-static void mv_yx_in_hex_dir(char d, struct yx_uint8 * yx)
-{
- if (d == 'e')
- {
- yx->x = yx->x + (yx->y % 2);
- yx->y--;
- }
- else if (d == 'd')
- {
- yx->x++;
- }
- else if (d == 'c')
- {
- yx->x = yx->x + (yx->y % 2);
- yx->y++;
- }
- else if (d == 'x')
- {
- yx->x = yx->x - !(yx->y % 2);
- yx->y++;
- }
- else if (d == 's')
- {
- yx->x--;
- }
- else if (d == 'w')
- {
- yx->x = yx->x - !(yx->y % 2);
- yx->y--;
- }
-}
-
-
-
-static uint8_t mv_yx_in_dir_wrap(char d, struct yx_uint8 * yx, uint8_t unwrap)
-{
- static uint8_t wrap = 0;
- if (unwrap)
- {
- wrap = 0;
- return 0;
- }
- struct yx_uint8 original;
- original.y = yx->y;
- original.x = yx->x;
- mv_yx_in_hex_dir(d, yx);
- if (strchr("edc", d) && yx->x < original.x)
- {
- wrap = wrap & WRAP_W ? wrap ^ WRAP_W : wrap | WRAP_E;
- }
- else if (strchr("xsw", d) && yx->x > original.x)
- {
- wrap = wrap & WRAP_E ? wrap ^ WRAP_E : wrap | WRAP_W;
- }
- if (strchr("we", d) && yx->y > original.y)
- {
- wrap = wrap & WRAP_S ? wrap ^ WRAP_S : wrap | WRAP_N;
- }
- else if (strchr("xc", d) && yx->y < original.y)
- {
- wrap = wrap & WRAP_N ? wrap ^ WRAP_N : wrap | WRAP_S;
- }
- return wrap;
-}
-
-
-
-static uint8_t mv_yx_in_dir_legal(char dir, struct yx_uint8 * yx)
-{
- uint8_t wraptest = mv_yx_in_dir_wrap(dir, yx, 0);
- if (!wraptest && yx->x < world.map.length && yx->y < world.map.length)
- {
- return 1;
- }
- return 0;
-}
-
-
-