summaryrefslogtreecommitdiff
path: root/src/teams.c
blob: 9b6d37bd8acc99c16e83b9a1630a6f3c34460d30 (plain) (blame)
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
93
94
95
96
97
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "teams.h"
#define __COBJ_PRIV_IMPLS_H__
#include "cobj.h"

typedef struct team_impl_struct {
	char name[255];
	char members[3][255];
	char institution[255];
	uint8_t solved;
} TEAM_impl;

// base functions
NEW(team, {
	return (TEAM_impl *)malloc(sizeof(TEAM_impl));
})

DEL(team, {
	if(self) free(self);
})

// Setter definitions
// @set char[]: TEAM.name -> bool
SETTER(team, name,			const ref(char), {
	return !(strncpy(self->name, value, 255) == NULL);
})

// @set char[]: TEAM.institution -> bool
SETTER(team, institution,	const ref(char), {
	return !(strncpy(self->institution, value, 255) == NULL);
})

// @set char[]: TEAM.member_name, int: id -> bool
SETTER(team, member_name,	const ref(char), {
	return (id > 0 && id < 4 && !(strncpy(self->members[id-1], value, 255) == NULL));
}, int id)

// @set int: TEAM.solved -> bool
SETTER(team, solved,		uint8_t, {
	if (value <= 10)
		self->solved = value;
	return (value <= 10);
})

// Getter definitions
// @get TEAM.name -> char[]
GETTER(team, name,			char *, {
	return self->name;
})

// @get TEAM.institution -> char[]
GETTER(team, institution,	char *, {
	return self->institution;
})

// @get TEAM.solved -> int
GETTER(team, solved,		uint8_t, {
	return self->solved;
})

// @get TEAM.member_name, id -> char[]
GETTER(team, member_name,	char *, {
	return (id > 0 && id < 4)? self->members[id - 1] : "(incorrect id)";
}, int id)

DEFINE(team, printf, int, {
	return ask(team, fprintf, self, stdout);
})

DEFINE(team, fprintf, int, {
	return fprintf(file,
	               "Team name  : %s\n"
	               "Institution: %s\n"
	               "Solved     : %u\n"
	               "   Member 1: %s\n"
	               "   Member 2: %s\n"
	               "   Member 3: %s\n",
	               self->name,
	               self->institution,
	               self->solved,
	               self->members[0],
	               self->members[1],
	               self->members[2]);
}, FILE *file)

DEFINE(team, find_champion, team, {
	UNUSED(self);

	team champion = teams[num - 1];
	while(num --)
		if ( teams[num]->solved > champion->solved )
			champion = teams[num];
	return champion;
}, team *teams, unsigned num)