aboutsummaryrefslogtreecommitdiff
path: root/src/gen_tiles.c
diff options
context:
space:
mode:
authorkartofen <mladenovnasko0@gmail.com>2022-12-21 01:06:18 +0200
committerkartofen <mladenovnasko0@gmail.com>2022-12-21 01:06:18 +0200
commit85601f555a3a57db44631706a25e0f933afd8551 (patch)
tree576f7f7518ebd6f7d1b6f3534218c747d2a14a43 /src/gen_tiles.c
parent88dd7e5fb0798d441dab81e9173d0e2d63f0b75e (diff)
works with different connections
Diffstat (limited to 'src/gen_tiles.c')
-rw-r--r--src/gen_tiles.c127
1 files changed, 25 insertions, 102 deletions
diff --git a/src/gen_tiles.c b/src/gen_tiles.c
index e4e2159..c29bc29 100644
--- a/src/gen_tiles.c
+++ b/src/gen_tiles.c
@@ -3,135 +3,58 @@
#include <string.h>
#include <sys/stat.h>
#include "typedef.h"
-#include "ppm.h"
-#include "config.h"
-
-#define TILE_TYPES 5
-#define TILE_WIDTH 3
-#define TILE_HEIGHT 3
-
-// possible types: X T I
-char symetry[TILE_TYPES] = "XTIIT";
-
-char tile_names[TILE_TYPES][7] = {
- "blank", "t", "plus", "line", "corner"
-};
-
-small_t tiles[TILE_TYPES][TILE_WIDTH*TILE_HEIGHT] = {
- {
- 0, 0, 0,
- 0, 0, 0,
- 0, 0, 0
- }, {
- 0, 0, 0,
- 1, 1, 1,
- 0, 1, 0
- }, {
- 0, 1, 0,
- 1, 1, 1,
- 0, 1, 0
- },{
- 0, 0, 0,
- 1, 1, 1,
- 0, 0, 0
- }, {
- 0, 1, 0,
- 0, 1, 1,
- 0, 0, 0
- }
-};
-small_t tiles_connections[TILE_TYPES][4] = {
- { 0, 0, 0, 0 },
- { 0, 1, 1, 1 },
- { 1, 1, 1, 1 },
- { 0, 1, 1, 0 },
- { 1, 1, 0, 0 },
-};
+typedef struct tile {
+ char name[64];
+ char symetry;
+ small_t connections[SIDES_MAX];
+ // small_t neighbours[TILES_CAP];
+// size_t neigbours_sz;
+} tile;
-void set_color(small_t *pixels, small_t *t, int x, int y, char k, char blank, char connection)
-{
- pixels[(y * TILE_WIDTH + x)*3 + k] = (t[y * TILE_WIDTH + x] == 0) ? blank : connection;
-
-}
-FILE *fp;
+#include "config.h"
-void save(small_t *t, small_t *c, int n, int i)
+void copy(char *tile_set, char *name, int n)
{
-#ifdef GENERATE_PPM_TILES
- (void)i;
-
- char file_name[64] = {0};
-
- sprintf(file_name, "files/tiles/tile_%d.ppm", n);
-
- small_t *pixels = malloc(TILE_WIDTH * TILE_HEIGHT *3);
- for(int y = 0; y < TILE_HEIGHT; y++)
- for(int x = 0; x < TILE_WIDTH; x++) {
- set_color(pixels, t, x, y, 0,
- generated_tile_colors[0][0],
- generated_tile_colors[1][0]);
- set_color(pixels, t, x, y, 1,
- generated_tile_colors[0][1],
- generated_tile_colors[1][1]);
- set_color(pixels, t, x, y, 2,
- generated_tile_colors[0][2],
- generated_tile_colors[1][2]);
- }
-
- save_as_ppm(file_name, pixels, TILE_WIDTH, TILE_HEIGHT, 1);
- free(pixels);
- printf("Saved file: %s\n", file_name);
-#endif
-#ifdef TILESET_NAME
- (void)t; (void)c;
-
- char command[128];
- sprintf(command, "cp files/tilesets/%s/%s.ppm files/tiles/tile_%d.ppm", TILESET_NAME, tile_names[i], n);
+ char command[512];
+ sprintf(command, "cp files/tilesets/%s/%s.ppm files/tiles/tile_%d.ppm",
+ tile_set, name, n);
system(command);
-#endif
-
- small_t connections = 0;
- for(int ci = 0; ci < 4; ci++)
- {
- connections |= (c[ci] << (3-ci));
- }
-
- fwrite(&connections, sizeof(connections), 1, fp);
}
void gen()
{
- mkdir("files", S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH);
- mkdir("files/tiles", S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH);
+ system("mkdir files");
+ system("mkdir files/tiles");
- fp = fopen("files/tiles/tiles.dat", "wb");
+ FILE *fp = fopen("files/tiles/tiles.dat", "wb");
if(!fp) {
fprintf(stderr, "ERROR: Could not open file files/tiles/tiles.dat");
exit(EXIT_FAILURE);
}
+ small_t dim = DIMENTIONS;
+ fwrite(&dim, sizeof(small_t), 1, fp);
+
size_t tiles_sz = sizeof(tiles_to_load)/sizeof(int);
fwrite(&tiles_sz, sizeof(size_t), 1, fp);
- char syms[TILE_TYPES];
- size_t sym_sz = 0;
-
for(size_t n = 0; n < tiles_sz; n++)
{
- int i = tiles_to_load[n];
- save(tiles[i], tiles_connections[i], n, i);
- syms[sym_sz++] = symetry[i];
- }
+ int t = tiles_to_load[n];
+ copy(TILESET_NAME, tiles[t].name, n);
- fwrite(syms, 1, sym_sz, fp);
+ fwrite(tiles[t].connections, sizeof(small_t), SIDES, fp);
+ fwrite(&(tiles[t].symetry), sizeof(char), 1, fp);
+ }
fclose(fp);
}
-
int main(void)
{
+ puts("INFO: Generating Tile Data");
gen();
+ puts("INFO: Successful");
return 0;
}