summaryrefslogtreecommitdiff
path: root/agbsum/src/chkpar.c
blob: e388305a540a682d59d2cff71608e551323fbcd2 (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
/*
	Copyright 2022-2023 Gabriel Jensen.

	This file is part of agbsum.
	agbsum is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
	agbsum is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
	You should have received a copy of the GNU Affero General Public License along with agbsum. If not, see <https://www.gnu.org/licenses/>.
*/

#include <agbsum.h>

#include <stddef.h>
#include <stdio.h>
#include <string.h>

noreturn static void agb_expparval(char const chrpar) {
	fprintf(stderr,"Expected value for character parameter '%c'\n",chrpar);
	agb_exi(agb_cnd_err,NULL);
}

static bool agb_chkchrpar(agb_dat * const restrict dat,char const* const restrict par) {
	char const chrpar = par[0x0u];
	if (chrpar == '\x0') {return true;}

	char const* const restrict paramval = &par[0x1];
	
	switch (chrpar) {
	default:
		fprintf(stderr,"Invalid character parameter '%c'\n",chrpar);
		agb_exi(agb_cnd_err,NULL);
	case 'h':
		agb_hlp();
		agb_exi(agb_cnd_oky,NULL);
	case 'i':
		{
			if (paramval[0x0u] == '\x0') {agb_expparval(chrpar);}
			dat->pth = paramval;
		}
		return true;
	case 'p':
		dat->dopat = true;
		return false;
	case 's':
		dat->sil = true;
		return false;
	}
}

void agb_chkpar(agb_dat * const restrict dat,int const argc,char const* const* const argv) {
	if (argc < 0x2) {
		agb_hlp();
		agb_exi(agb_cnd_oky,NULL);
	}
	else {
		size_t const numpar = argc;

		for (size_t pos = 0x1u;pos < numpar;++pos) {

			char const* const par = argv[pos];
			if (par[0x0u] == '-') {
				if (par[0x1u] == '-') {
					char const* const lngparam = &par[0x2u];

					if (lngparam[0x0u] == '\x0') {
						fputs("Missing long parameter after '--' sequence\n",stderr);
						agb_exi(agb_cnd_err,NULL);
					}

					if (!strcmp(lngparam,"help")) {
						agb_hlp();
						agb_exi(agb_cnd_oky,NULL);
					}
					
					fprintf(stderr,"Invalid long parameter \"%s\"\n",lngparam);
					agb_exi(agb_cnd_err,NULL);
				}

				if (par[0x1u] == '\x0') {
					fputs("Missing character parameter after '-'\n",stderr);
					agb_exi(agb_cnd_err,NULL);
				}

				for (char const* chrpos = &par[0x1u];;++chrpos) {if (agb_chkchrpar(dat,chrpos)) {break;}}

				continue;
			}
		}

		if (dat->pth == NULL) {
			fputs("ROM not set (missing character parameter 'i')\n",stderr);
			agb_exi(agb_cnd_err,NULL);
		}
	}
}