aboutsummaryrefslogtreecommitdiff
path: root/src/main.c
blob: 3820cd5050b06d8655835c4616450dfbbb23c216 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/* ************************************************************************** */
/*                                                                            */
/*                                                        :::      ::::::::   */
/*   main.c                                             :+:      :+:    :+:   */
/*                                                    +:+ +:+         +:+     */
/*   By: charles <charles.cabergs@gmail.com>        +#+  +:+       +#+        */
/*                                                +#+#+#+#+#+   +#+           */
/*   Created: 2020/05/09 10:20:09 by charles           #+#    #+#             */
/*   Updated: 2020/05/14 16:48:35 by charles          ###   ########.fr       */
/*                                                                            */
/* ************************************************************************** */

#include "scop.h"

/*
** TODO
** - texture
**   - parse vt
**   - parse coord index of f
**   - transition color/texture
** - cleaner code
*/

void	debugmat(t_ftmmat4 *mat)
{
	for (int i = 0; i < 4; i++)
	{
		for (int j = 0; j < 4; j++)
		{
			printf("%.2f, ", mat->m[i * 4 + j]);
		}
		printf("\n");
	}
	printf("\n");
}

int main(int argc, char **argv)
{
	t_state	state;
	t_model_data data;

	if (argc != 2 && argc != 3)
	{
		ft_putstr("Usage: ");
		ft_putstr(argv[0]);
		ft_putendl(" OBJ_FILE [BMP_FILE]");
		return (1);
	}
	if (parse(argv[1], &data) == -1)
	{
		ft_putstr("Error: couldn't parse ");
		ft_putendl(argv[1]);
		return (1);
	}
	color_init(data.vertices, data.vertices_num);
	texture_coord_init(data.vertices, data.vertices_num);
	if (argc == 3)
		data.texture_filepath = argv[2];
	else
		data.texture_filepath = "res/brick.bmp";

	printf("size %lu\n", data.indices_num);
	for (size_t i = 0; i < data.indices_num; i++)
	{
		printf("%u, ", data.indices[i++]);
		printf("%u, ", data.indices[i++]);
		printf("%u\n", data.indices[i]);
	}

	printf("size %lu\n", data.vertices_num);
	for (size_t i = 0; i < data.vertices_num; i++)
	{
		printf("% f, ", data.vertices[i++]);
		printf("% f, ", data.vertices[i++]);
		printf("% f, ", data.vertices[i++]);
		printf("% f | ", data.vertices[i++]);
		printf("% f, ", data.vertices[i++]);
		printf("% f, ", data.vertices[i++]);
		printf("% f, ", data.vertices[i++]);
		printf("% f | ", data.vertices[i++]);
		printf("% f ", data.vertices[i++]);
		printf("% f\n", data.vertices[i]);
	}

	if (!state_init(&state, &data))
		return (1);
	state_run(&state);
	state_quit(&state);
	free(data.vertices);
	free(data.indices);
	return 0;
}