aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkartofen <mladenovnasko0@gmail.com>2022-08-08 16:16:47 +0300
committerkartofen <mladenovnasko0@gmail.com>2022-08-08 16:16:47 +0300
commitf158268a0d59133b7cef538b3fa57ece16f2981d (patch)
tree846760a497a6c08d61adae96cbce6ffe4e6383c6
Big Bang
-rw-r--r--.gitignore2
-rwxr-xr-xbuild.sh23
-rw-r--r--src/gen_tiles.c49
-rw-r--r--src/main.c17
-rw-r--r--src/ppm.c81
-rw-r--r--src/ppm.h10
-rw-r--r--src/tiles.c39
-rw-r--r--src/tiles.h8
8 files changed, 229 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..cbbd0b5
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,2 @@
+bin/
+obj/ \ No newline at end of file
diff --git a/build.sh b/build.sh
new file mode 100755
index 0000000..39849a5
--- /dev/null
+++ b/build.sh
@@ -0,0 +1,23 @@
+#!/bin/sh
+cd ${0%/*} # go to project root
+set -xe
+
+FLAGS="-Wall -Wextra -g"
+SRCD="src"
+ODIR="obj"
+BIN="bin"
+
+mkdir -p $ODIR
+mkdir -p $BIN
+
+
+gcc -c $SRCD/gen_tiles.c -o $ODIR/gen_tiles.o $FLAGS
+gcc -c $SRCD/ppm.c -o $ODIR/ppm.o $FLAGS
+gcc -c $SRCD/tiles.c -o $ODIR/tiles.o $FLAGS
+gcc -c $SRCD/main.c -o $ODIR/main.o $FLAGS
+gcc -o $BIN/wfc $ODIR/main.o $ODIR/ppm.o $ODIR/tiles.o $FLAGS
+
+gcc -o $BIN/gen_tiles $ODIR/gen_tiles.o $ODIR/ppm.o $FLAGS
+
+$BIN/gen_tiles
+$BIN/wfc
diff --git a/src/gen_tiles.c b/src/gen_tiles.c
new file mode 100644
index 0000000..87e50bd
--- /dev/null
+++ b/src/gen_tiles.c
@@ -0,0 +1,49 @@
+#include <stdio.h>
+#include <sys/stat.h>
+#include "ppm.h"
+
+int tile_0[9] = {
+ 0, 0, 0,
+ 0, 0, 0,
+ 0, 0, 0
+};
+
+int tile_1[9] = {
+ 0, 1, 0,
+ 1, 1, 1,
+ 0, 0, 0
+};
+
+int tile_2[9] = {
+ 0, 1, 0,
+ 0, 1, 1,
+ 0, 1, 0
+};
+
+int tile_3[9] = {
+ 0, 1, 0,
+ 1, 1, 0,
+ 0, 1, 0
+};
+
+int tile_4[9] = {
+ 0, 0, 0,
+ 1, 1, 1,
+ 0, 1, 0
+};
+
+void gen()
+{
+ mkdir("files/", S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH);
+ save_as_ppm("files/tile_0.ppm", tile_0, 3, 3);
+ save_as_ppm("files/tile_1.ppm", tile_1, 3, 3);
+ save_as_ppm("files/tile_2.ppm", tile_2, 3, 3);
+ save_as_ppm("files/tile_3.ppm", tile_3, 3, 3);
+ save_as_ppm("files/tile_4.ppm", tile_4, 3, 3);
+}
+
+int main(void)
+{
+ gen();
+ return 0;
+}
diff --git a/src/main.c b/src/main.c
new file mode 100644
index 0000000..1db4858
--- /dev/null
+++ b/src/main.c
@@ -0,0 +1,17 @@
+#include <stdio.h>
+#include "tiles.h"
+#include "ppm.h"
+
+#define TILES 5
+
+int *(tiles[TILES]) = {0};
+int TILE_WIDTH;
+int TILE_HEIGHT;
+
+int main(void)
+{
+ load_tiles(TILES);
+ print_tiles(TILES);
+ free_tiles(TILES);
+ return 0;
+}
diff --git a/src/ppm.c b/src/ppm.c
new file mode 100644
index 0000000..7ac29f3
--- /dev/null
+++ b/src/ppm.c
@@ -0,0 +1,81 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include "ppm.h"
+
+void save_as_ppm(char* file_path, int *t, int width, int height)
+{
+ FILE *fp = fopen(file_path, "wb");
+ if(!fp) {
+ fprintf(stderr, "ERROR: Could not open file: %s\n", file_path);
+ exit(EXIT_FAILURE);
+ }
+
+ fprintf(fp, "P6\n%d %d 255\n", width, height);
+
+ for(int i = 0; i < height; i++)
+ for(int j = 0; j < width; j++)
+ {
+ char c = (t[i * width + j] == 0) ? 255 : 0;
+ for(int j = 0; j < 3; j++)
+ fwrite(&c, 1, 1, fp);
+ }
+
+ // int scaler = 10;
+
+ // fprintf(fp, "P6\n%d %d 255\n", width*scaler, height*scaler);
+
+ // for(int i = 0; i < height * scaler; i++)
+ // for(int j = 0; j < width * scaler; j++)
+ // {
+ // char c = (t[(i/scaler) * width + (j/scaler)] == 0) ? 255 : 0;
+ // for(int j = 0; j < 3; j++)
+ // fwrite(&c, 1, 1, fp);
+ // }
+
+
+
+ fclose(fp);
+}
+
+int *load_from_ppm(char *file_path, int *width, int *height)
+{
+ FILE *fp = fopen(file_path, "rb");
+ if(!fp) {
+ fprintf(stderr, "ERROR: Could not open file: %s\n", file_path);
+ exit(EXIT_FAILURE);
+ }
+
+ char line[64] = {0};
+
+ fgets(line, sizeof(line), fp);
+ if(strncmp(line, "P6", 2) != 0) {
+ fprintf(stderr, "ERROR: PPM header is not correct of file: %s\n", file_path);
+ exit(EXIT_FAILURE);
+ }
+
+ fgets(line, sizeof(line), fp);
+ *width = atoi(strtok(line, " "));
+ *height = atoi(strtok(NULL, " "));
+ (void)strtok(NULL, " ");
+
+ char *pixels = malloc((*width) * (*height ) * 3);
+
+ fread(pixels, *width*3, *height, fp);
+
+ int *t = malloc((*width) * (*height ) * sizeof(int));
+ for(int i = 0; i < *height; i++)
+ for(int j = 0; j < *width; j++)
+ t[i * *width + j] = (pixels[(i * *width + j) * 3] == 0) ? 1 : 0;
+
+ free(pixels);
+
+ fclose(fp);
+
+ return t;
+}
+
+void free_ppm(int *t)
+{
+ free(t);
+}
diff --git a/src/ppm.h b/src/ppm.h
new file mode 100644
index 0000000..b68e77c
--- /dev/null
+++ b/src/ppm.h
@@ -0,0 +1,10 @@
+#ifndef PPM_H
+#define PPM_H
+
+void save_as_ppm(char* file_path, int *t, int width, int height);
+
+int *load_from_ppm(char *file_path, int *width, int *height);
+
+void free_ppm(int *img);
+
+#endif
diff --git a/src/tiles.c b/src/tiles.c
new file mode 100644
index 0000000..b09ca95
--- /dev/null
+++ b/src/tiles.c
@@ -0,0 +1,39 @@
+#include <stdio.h>
+#include "ppm.h"
+
+extern int *(tiles[]);
+extern int TILE_WIDTH;
+extern int TILE_HEIGHT;
+
+void load_tiles(int n)
+{
+ int width, height;
+ for(int i = 0; i < n; i++)
+ {
+ char file_path[26];
+ sprintf(file_path, "files/tile_%d.ppm", i);
+ tiles[i] = load_from_ppm(file_path, &width, &height);
+ }
+ TILE_WIDTH = width;
+ TILE_HEIGHT = height;
+}
+
+void free_tiles(int n)
+{
+ for(int i = 0; i < n; i++)
+ free_ppm(tiles[i]);
+}
+
+void print_tiles(int n)
+{
+ for(int i = 0; i < n; i++)
+ {
+ for(int y = 0; y < TILE_HEIGHT; y++)
+ {
+ for(int x = 0; x < TILE_WIDTH; x++)
+ putchar(tiles[i][y * TILE_WIDTH + x] + '0');
+ putchar('\n');
+ }
+ putchar('\n');
+ }
+}
diff --git a/src/tiles.h b/src/tiles.h
new file mode 100644
index 0000000..14e4dd8
--- /dev/null
+++ b/src/tiles.h
@@ -0,0 +1,8 @@
+#ifndef TILES_H
+#define TILES_H
+
+void load_tiles(int n);
+void free_tiles(int n);
+void print_tiles(int n);
+
+#endif