visual.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. /* $NetBSD: visual.c,v 1.6 2003/08/07 09:37:55 agc Exp $ */
  2. /*
  3. * Copyright (c) 1980, 1993
  4. * The Regents of the University of California. All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * 2. Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * 3. Neither the name of the University nor the names of its contributors
  15. * may be used to endorse or promote products derived from this software
  16. * without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  19. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  20. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  21. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  22. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  23. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  24. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  25. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  26. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  27. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. */
  30. #include <sys/cdefs.h>
  31. #ifndef lint
  32. #if 0
  33. static char sccsid[] = "@(#)visual.c 8.1 (Berkeley) 5/31/93";
  34. #else
  35. __RCSID("$NetBSD: visual.c,v 1.6 2003/08/07 09:37:55 agc Exp $");
  36. #endif
  37. #endif /* not lint */
  38. #include <stdio.h>
  39. #include "trek.h"
  40. #include "getpar.h"
  41. /*
  42. ** VISUAL SCAN
  43. **
  44. ** A visual scan is made in a particular direction of three sectors
  45. ** in the general direction specified. This takes time, and
  46. ** Klingons can attack you, so it should be done only when sensors
  47. ** are out.
  48. */
  49. /* This struct[] has the delta x, delta y for particular directions */
  50. struct xy Visdelta[11] =
  51. {
  52. { -1, -1 },
  53. { -1, 0 },
  54. { -1, 1 },
  55. { 0, 1 },
  56. { 1, 1 },
  57. { 1, 0 },
  58. { 1, -1 },
  59. { 0, -1 },
  60. { -1, -1 },
  61. { -1, 0 },
  62. { -1, 1 }
  63. };
  64. /*ARGSUSED*/
  65. void
  66. visual(z)
  67. int z __attribute__((__unused__));
  68. {
  69. int ix, iy;
  70. int co;
  71. struct xy *v;
  72. co = getintpar("direction");
  73. if (co < 0 || co > 360)
  74. return;
  75. co = (co + 22) / 45;
  76. v = &Visdelta[co];
  77. ix = Ship.sectx + v->x;
  78. iy = Ship.secty + v->y;
  79. if (ix < 0 || ix >= NSECTS || iy < 0 || iy >= NSECTS)
  80. co = '?';
  81. else
  82. co = Sect[ix][iy];
  83. printf("%d,%d %c ", ix, iy, co);
  84. v++;
  85. ix = Ship.sectx + v->x;
  86. iy = Ship.secty + v->y;
  87. if (ix < 0 || ix >= NSECTS || iy < 0 || iy >= NSECTS)
  88. co = '?';
  89. else
  90. co = Sect[ix][iy];
  91. printf("%c ", co);
  92. v++;
  93. ix = Ship.sectx + v->x;
  94. iy = Ship.secty + v->y;
  95. if (ix < 0 || ix >= NSECTS || iy < 0 || iy >= NSECTS)
  96. co = '?';
  97. else
  98. co = Sect[ix][iy];
  99. printf("%c %d,%d\n", co, ix, iy);
  100. Move.time = 0.05;
  101. Move.free = 0;
  102. }