summaryrefslogtreecommitdiff
path: root/wrapper/plugins.h
blob: 1e88279e988c12deec60e5d5ee0a65806b045667 (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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/* wrapper/plugins.h -- struct definitions and basic functions for rvs plugins
   system depends: this file is truly system-independant
   Copyright (C) 2009 Luke Shumaker
   system depends: this file is completely system-independant
   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_plugins_h_SEEN
#define FILE_plugins_h_SEEN

#include "rvs.h"

/* a plugin */
/* a generic binary tree emulating a n-ary tree via linked list */
struct plugin
{
	char *name;
	struct plugin_command *commands;/* left  leaf */
	struct plugin         *next;    /* right leaf */
};

/* a single plugin command */
struct plugin_command
{
	/* node */
	char *name;
	struct plugin         *plugin; /* which plugin does it belong to? */
	struct plugin_command *depend; /* what does this depend on? */
	char                  *depends;/* what does this depend on? (string) */
	
	/* linked list */
	struct plugin_command *next;
	
	/* depends, linked list */
	/* for a dependancy tree, this seems like it should be a    *\
	\* separate struct, but this is the simplest way.           */
	struct plugin_command *d_child;
	struct plugin_command *d_next;
};

/* create a blank plugin_command */
struct plugin_command *
plugin_mk_command()
{
	struct plugin_command *command;
	command=(struct plugin_command *)xmalloc(sizeof(*command));
	#ifdef DEBUG
		printf("malloc'd command: %p\n",command);
	#endif
	
	/* node */
	command->name=NULL;
	command->plugin=NULL;
	command->depend=NULL;
	command->depends=NULL;
	
	/* linked list */
	command->next=NULL;
	
	/* depends */
	command->d_child=NULL;
	command->d_next=NULL;
	
	return command;
}

void
plugin_free_command(struct plugin_command *command)
{
	if (command!=NULL) {
		plugin_free_command(command->next);
		#ifdef DEBUG
			printf("  free'd command: %p \"%s\"\n",
				command,command->name);
		#endif
		xfree(command->name);
		xfree(command->depends);
		xfree(command);
	}
}

void
plugin_free_plugin(struct plugin *plugin)
{
	if (plugin!=NULL) {
		xfree(plugin->name);
		plugin_free_command(plugin->commands);
		plugin_free_plugin(plugin->next);
		xfree(plugin);
	}
}

#endif