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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
/* Copyright (C) 2009 Luke Shumaker
This file is part of rvs.
rvs 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 2, or (at your
option) any later version.
rvs 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 rvs; see the file COPYING.
If not, write to the Free Software Foundation,
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef FILE_plugin_c_SEEN
#define FILE_plugin_c_SEEN
#include <stdio.h>
#include <stdlib.h> /* EXIT_FAILURE */
#include <unistd.h> /* file acces */
#include <string.h>
#include <errno.h>
#include <error.h>
#include <dirent.h>
#include <sys/stat.h>
#include "rvs.h"
#include "plugin.h"
/* finds a plugin with `name'. Start looking at `plugin' (linked list) */
struct plugin *
_plugin_find_plugin(struct plugin *plugin, char *name)
{
if (strcmp(plugin->name,name) == 0) {
return plugin;
} else {
if (plugin->next==NULL) {
error(EXIT_FAILURE,0,"cannot find plugin `%s'",name);
return NULL;
} else {
return _plugin_find_plugin(plugin->next,name);
}
}
}
/* finds a command with `name'. Start looking at `command' (linked list) */
struct plugin_command *
_plugin_find_command(struct plugin_command *command, char *name)
{
if (strcmp(command->name,name) == 0) {
return command;
} else {
if (command->p_next==NULL) {
error(EXIT_FAILURE,0,
"plugin `%s' does not contain command `%s'",
command->plugin->name,name);
return NULL;
} else {
return _plugin_find_command(command->p_next,name);
}
}
}
#include "plugin-parse.c"
#include "plugin-depend.c"
struct plugin *
_plugin_load (const char *plug_name, const char *plugin_conf)
{
struct plugin *plugin=(struct plugin *)xmalloc(sizeof(*plugin));
char *plug_name2 = (char *)xmalloc(strlen(plug_name)+1);
strcpy(plug_name2,plug_name);
plugin->name=plug_name2;
plugin->next=NULL;
xchdir(plug_name);
FILE *file = xfopen(plugin_conf,"r");
plugin->child=_plugin_parse(plugin, file);
fclose( file );
xchdir("..");
return plugin;
}
struct plugin_tree *
load_plugins (const char *libexecdir, const char *plugin_conf)
{
struct plugin_tree *tree=(struct plugin_tree *)xmalloc(sizeof(*tree));
struct plugin **last=&tree->plugins;
*last=NULL;
struct plugin *plugin;
xchdir(libexecdir);
DIR *cwd;
struct dirent *dirent;
int serr;
struct stat sbuf;
cwd = xopendir ("./");
while ( (dirent = readdir (cwd)) != NULL ) {
if ((strcmp(dirent->d_name,"." )!=0)&&
(strcmp(dirent->d_name,"..")!=0)) {
serr = stat(dirent->d_name, &sbuf);
if (!serr && S_ISDIR(sbuf.st_mode)) {
plugin=_plugin_load(dirent->d_name,plugin_conf);
*last=plugin;/* this sets the last's `next' */
last=&plugin->next;
}
}
}
closedir (cwd);
xchdir("..");
return tree;
}
#endif
|