aboutsummaryrefslogtreecommitdiff
path: root/src/cfg.c
blob: b30bd3f146772cefa49fc0c6fa95b8fba805227b (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
/**
* duser - Manage MajorDomo lists
* Copyright (C) 2011 Joseph Hunkeler <jhunkeler@gmail.com, jhunk@stsci.edu>
*
* This file is part of duser.
*
* duser is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* duser 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with duser. If not, see <http://www.gnu.org/licenses/>.
**/

#define _GNU_SOURCE

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include "duser.h"
#include "cfg.h"

FILE *cfgfp;

int cfg_open(const char* filename)
{
	if((cfgfp = fopen(filename, "r")) == NULL)
		return errno;
	else
		return 0;
}

void cfg_close()
{
	fclose(cfgfp);
}

//Value of key
int cfg_get_key(char* val, const char* key)
{

	if(cfgfp == NULL)
		return -1;

	if((fseek(cfgfp, 0L, SEEK_SET)) != 0)
		return errno;

	char buffer[CFG_MAX];
	char *buf = buffer; //= (char*)malloc(sizeof(char) * CFG_MAX+1);
	if(buffer == NULL)
	{
		fprintf(stderr, "%s: %s\n", SELF, strerror(errno));
		exit(1);
	}

	int i = 0;
	while(!feof(cfgfp))
	{
		memset(buffer, 0L, CFG_MAX);
		fgets(buffer, CFG_MAX, cfgfp);
		if((strcasestr(buffer, key)))
		{
			while(buf)
			{
				if(isspace(*buf))
				{
					strncpy(val, &buf[i+1], CFG_MAX);
					val[strlen(val)-1] = 0;
					break;
				}
				buf++;
			}
			i++;
			break;
		}
	}

	return 0; 
}