More to come...
25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

326 lines
11KB

  1. #ifndef CHAPTER_X_SOURCE
  2. #define CHAPTER_X_SOURCE
  3. #include <stdlib.h>
  4. #include <stdarg.h>
  5. #include "chapter_x.h"
  6. /*
  7. So, what are actually getters and setters, and why you should never use them? Lets explain.
  8. */
  9. #define MEMORY_LIMIT (1024 * 1024)
  10. static number_t game_memory_length = 0;
  11. static memory_t * game_memory = NULL;
  12. static procedure_t game_free_memory (memory_t memory) {
  13. ++game_memory_length;
  14. game_memory = reallocate (game_memory, game_memory_length * (number_t) sizeof (* game_memory));
  15. game_memory [game_memory_length - 1] = memory;
  16. }
  17. procedure_t game_clean_up (procedure_t) {
  18. for (number_t pointer = 0; pointer < game_memory_length; ++pointer) {
  19. game_memory [pointer] = deallocate (game_memory [pointer]);
  20. }
  21. game_memory = deallocate (game_memory);
  22. }
  23. bundle_t * game_bundle (number_t minimum, number_t maximum, number_t current) {
  24. bundle_t * bundle = allocate ((number_t) sizeof (* bundle));
  25. bundle->minimum = minimum;
  26. bundle->maximum = maximum;
  27. bundle->current = current;
  28. game_free_memory (bundle);
  29. return (bundle);
  30. }
  31. symbol_t * game_symbol (number_t character, number_t colour, number_t effect) {
  32. symbol_t * symbol = allocate ((number_t) sizeof (* symbol));
  33. symbol->character = character;
  34. symbol->colour = colour;
  35. symbol->effect = effect;
  36. game_free_memory (symbol);
  37. return (symbol);
  38. }
  39. sprite_t * game_sprite (number_t width, number_t height, memory_t data) {
  40. sprite_t * sprite = allocate ((number_t) sizeof (* sprite));
  41. sprite->width = width;
  42. sprite->height = height;
  43. sprite->data = data;
  44. game_free_memory (sprite);
  45. return (sprite);
  46. }
  47. generator_t * game_generator (generate_t function) {
  48. generator_t * generator = allocate ((number_t) sizeof (* generator));
  49. generator->generate = function;
  50. game_free_memory (generator);
  51. return (generator);
  52. }
  53. attribute_t * game_attribute (string_t name, bundle_t * points, ...) {
  54. va_list list;
  55. attribute_t * attribute = allocate ((number_t) sizeof (* attribute));
  56. string_copy ((attribute->name = allocate (string_length (name) + 1)), name);
  57. memory_copy ((attribute->points = allocate ((number_t) sizeof (* attribute->points))), points, (number_t) sizeof (* points));
  58. va_start (list, points);
  59. for (;;) {
  60. number_t action = (number_t) va_arg (list, int);
  61. if (action > 0) {
  62. attribute->positive_count += 1;
  63. attribute->positive = reallocate (attribute->positive, attribute->positive_count * (number_t) sizeof (action));
  64. attribute->positive [attribute->positive_count - 1] = (action_t) action;
  65. } else if (action < 0) {
  66. attribute->negative_count += 1;
  67. attribute->negative = reallocate (attribute->negative, attribute->negative_count * (number_t) sizeof (action));
  68. attribute->negative [attribute->negative_count - 1] = (action_t) -action;
  69. } else break;
  70. }
  71. va_end (list);
  72. game_free_memory (attribute->name);
  73. game_free_memory (attribute->points);
  74. game_free_memory (attribute->positive);
  75. game_free_memory (attribute->negative);
  76. game_free_memory (attribute);
  77. return (attribute);
  78. }
  79. skill_t * game_skill (string_t name, bundle_t * points, ...) {
  80. va_list list;
  81. skill_t * skill = allocate ((number_t) sizeof (* skill));
  82. string_copy ((skill->name = allocate (string_length (name) + 1)), name);
  83. memory_copy ((skill->points = allocate ((number_t) sizeof (* skill->points))), points, (number_t) sizeof (* points));
  84. va_start (list, points);
  85. for (;;) {
  86. action_t action = (action_t) va_arg (list, int);
  87. if (action > 0) {
  88. skill->positive_count += 1;
  89. skill->positive = reallocate (skill->positive, skill->positive_count * (number_t) sizeof (action));
  90. skill->positive [skill->positive_count - 1] = action;
  91. } else break;
  92. }
  93. va_end (list);
  94. game_free_memory (skill->name);
  95. game_free_memory (skill->points);
  96. game_free_memory (skill->positive);
  97. game_free_memory (skill);
  98. return (skill);
  99. }
  100. bot_t * game_bot (string_t name, symbol_t * symbol, sprite_t * sprite, bundle_t * health, bundle_t * mana, bundle_t * stamina) {
  101. bot_t * bot = allocate ((number_t) sizeof (* bot));
  102. string_copy ((bot->name = allocate (string_length (name) + 1)), name);
  103. bot->x = 0;
  104. bot->y = 0;
  105. memory_copy ((bot->symbol = allocate ((number_t) sizeof (* bot->symbol))), symbol, (number_t) sizeof (* symbol));
  106. memory_copy ((bot->sprite = allocate ((number_t) sizeof (* bot->sprite))), sprite, (number_t) sizeof (* sprite));
  107. memory_copy ((bot->health = allocate ((number_t) sizeof (* bot->health))), health, (number_t) sizeof (* health));
  108. memory_copy ((bot->mana = allocate ((number_t) sizeof (* bot->mana))), mana, (number_t) sizeof (* mana));
  109. memory_copy ((bot->stamina = allocate ((number_t) sizeof (* bot->stamina))), stamina, (number_t) sizeof (* stamina));
  110. game_free_memory (bot->name);
  111. game_free_memory (bot->symbol);
  112. game_free_memory (bot->sprite);
  113. game_free_memory (bot->health);
  114. game_free_memory (bot->mana);
  115. game_free_memory (bot->stamina);
  116. game_free_memory (bot);
  117. return (bot);
  118. }
  119. player_t * game_player (string_t name, symbol_t * symbol, sprite_t * sprite, bundle_t * health, bundle_t * mana, bundle_t * stamina, ...) {
  120. va_list list;
  121. player_t * player = allocate ((number_t) sizeof (* player));
  122. string_copy ((player->name = allocate (string_length (name) + 1)), name);
  123. player->x = 3;
  124. player->y = 3;
  125. memory_copy ((player->symbol = allocate ((number_t) sizeof (* player->symbol))), symbol, (number_t) sizeof (* symbol));
  126. memory_copy ((player->sprite = allocate ((number_t) sizeof (* player->sprite))), sprite, (number_t) sizeof (* sprite));
  127. memory_copy ((player->health = allocate ((number_t) sizeof (* player->health))), health, (number_t) sizeof (* health));
  128. memory_copy ((player->mana = allocate ((number_t) sizeof (* player->mana))), mana, (number_t) sizeof (* mana));
  129. memory_copy ((player->stamina = allocate ((number_t) sizeof (* player->stamina))), stamina, (number_t) sizeof (* stamina));
  130. player->attribute_count = 0;
  131. player->skill_count = 0;
  132. va_start (list, stamina);
  133. for (;;) {
  134. attribute_t * attribute = (attribute_t *) va_arg (list, void *);
  135. if (attribute != NULL) {
  136. player->attribute_count += 1;
  137. player->attributes = reallocate (player->attributes, player->attribute_count * (number_t) sizeof (* player->attributes));
  138. player->attributes [player->attribute_count - 1] = attribute;
  139. } else break;
  140. }
  141. for (;;) {
  142. skill_t * skill = (skill_t *) va_arg (list, void *);
  143. if (skill != NULL) {
  144. player->skill_count += 1;
  145. player->skills = reallocate (player->skills, player->skill_count * (number_t) sizeof (* player->skills));
  146. player->skills [player->skill_count - 1] = skill;
  147. } else break;
  148. }
  149. va_end (list);
  150. game_free_memory (player->name);
  151. game_free_memory (player->symbol);
  152. game_free_memory (player->sprite);
  153. game_free_memory (player->health);
  154. game_free_memory (player->mana);
  155. game_free_memory (player->stamina);
  156. game_free_memory (player->attributes);
  157. game_free_memory (player->skills);
  158. game_free_memory (player);
  159. return (player);
  160. }
  161. block_t * game_block (string_t name, symbol_t * symbol, sprite_t * sprite, number_t collision, number_t override) {
  162. block_t * block = allocate ((number_t) sizeof (* block));
  163. string_copy ((block->name = allocate (string_length (name) + 1)), name);
  164. memory_copy ((block->symbol = allocate ((number_t) sizeof (* block->symbol))), symbol, (number_t) sizeof (* symbol));
  165. memory_copy ((block->sprite = allocate ((number_t) sizeof (* block->sprite))), sprite, (number_t) sizeof (* sprite));
  166. block->collision = collision;
  167. block->override = override;
  168. game_free_memory (block->name);
  169. game_free_memory (block->symbol);
  170. game_free_memory (block->sprite);
  171. game_free_memory (block);
  172. return (block);
  173. }
  174. world_t * game_world (number_t width, number_t height, ...) {
  175. va_list list;
  176. world_t * world = allocate ((number_t) sizeof (* world));
  177. world->width = width;
  178. world->height = height;
  179. world->block = allocate (width * height * (number_t) sizeof (* world->block));
  180. va_start (list, height);
  181. for (;;) {
  182. generator_t * generator = (generator_t *) va_arg (list, void *);
  183. if (generator != NULL) {
  184. memory_t data = (memory_t) va_arg (list, void *);
  185. number_t w = (number_t) va_arg (list, int);
  186. number_t h = (number_t) va_arg (list, int);
  187. number_t x = (number_t) va_arg (list, int);
  188. number_t y = (number_t) va_arg (list, int);
  189. generator->generate (world, data, w, h, x, y);
  190. } else break;
  191. }
  192. va_end (list);
  193. game_free_memory (world->bots);
  194. game_free_memory (world->block);
  195. game_free_memory (world);
  196. return (world);
  197. }
  198. procedure_t game_render_attribute (attribute_t * attribute, number_t x, number_t y) {
  199. curses_render_string (attribute->name, COLOUR_CYAN, EFFECT_NORMAL, x + 0, y);
  200. curses_render_string ("[ ", COLOUR_GREY, EFFECT_BOLD, x + 18, y);
  201. curses_render_string (format_to_string (attribute->points->minimum, 0, 10, 4, ' '), COLOUR_RED, EFFECT_NORMAL, x + 20, y);
  202. curses_render_string (format_to_string (attribute->points->current, 0, 10, 4, ' '), COLOUR_WHITE, EFFECT_NORMAL, x + 24, y);
  203. curses_render_string (format_to_string (attribute->points->maximum, 0, 10, 4, ' '), COLOUR_GREEN, EFFECT_NORMAL, x + 28, y);
  204. curses_render_string (" ]", COLOUR_GREY, EFFECT_BOLD, x + 32, y);
  205. }
  206. procedure_t game_render_skill (skill_t * skill, number_t x, number_t y) {
  207. curses_render_string (skill->name, COLOUR_CYAN, EFFECT_NORMAL, x + 0, y);
  208. curses_render_string ("[ ", COLOUR_GREY, EFFECT_BOLD, x + 18, y);
  209. curses_render_string (format_to_string (skill->points->minimum, 0, 10, 4, ' '), COLOUR_RED, EFFECT_NORMAL, x + 20, y);
  210. curses_render_string (format_to_string (skill->points->current, 0, 10, 4, ' '), COLOUR_WHITE, EFFECT_NORMAL, x + 24, y);
  211. curses_render_string (format_to_string (skill->points->maximum, 0, 10, 4, ' '), COLOUR_GREEN, EFFECT_NORMAL, x + 28, y);
  212. curses_render_string (" ]", COLOUR_GREY, EFFECT_BOLD, x + 32, y);
  213. }
  214. procedure_t game_render_bot (bot_t * bot) {
  215. curses_render_character ((char) bot->symbol->character, bot->symbol->colour, bot->symbol->effect, bot->x, bot->y);
  216. }
  217. procedure_t game_render_player (player_t * player) {
  218. curses_render_character ((char) player->symbol->character, player->symbol->colour, player->symbol->effect, player->x, player->y);
  219. }
  220. procedure_t game_render_block (block_t * block, number_t x, number_t y) {
  221. curses_render_character ((char) block->symbol->character, block->symbol->colour, block->symbol->effect, x, y);
  222. }
  223. procedure_t game_render_world (world_t * world, number_t x, number_t y, number_t width, number_t height) {
  224. for (number_t j = 0; (j < height) && (j < world->height); ++j) {
  225. for (number_t i = 0; (i < width) && (i < world->width); ++i) {
  226. game_render_block (world->block [j * world->width + i], i + x, j + y);
  227. }
  228. }
  229. for (number_t index = 0; index < world->bot_count; ++index) {
  230. game_render_bot (& world->bots [index]);
  231. }
  232. }
  233. #endif