summaryrefslogtreecommitdiff
path: root/libappstream-builder/asb-plugin.c
blob: 2450514aa7693362a779a9bae82e571e2eaf68ae (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
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*-
 *
 * Copyright (C) 2014 Richard Hughes <richard@hughsie.com>
 *
 * SPDX-License-Identifier: LGPL-2.1+
 */

/**
 * SECTION:asb-plugin
 * @short_description: Generic plugin helpers.
 * @stability: Unstable
 *
 * Utilities for plugins.
 */

#include "config.h"

#include <glib.h>
#include <fnmatch.h>

#include "asb-plugin.h"
#include "asb-utils.h"

/**
 * asb_plugin_process:
 * @plugin: A #AsbPlugin
 * @pkg: A #AsbPackage
 * @tmpdir: the temporary location
 * @error: A #GError or %NULL
 *
 * Runs a function on a specific plugin.
 *
 * Returns: (transfer none) (element-type AsbApp): applications
 *
 * Since: 0.1.0
 **/
GList *
asb_plugin_process (AsbPlugin *plugin,
		    AsbPackage *pkg,
		    const gchar *tmpdir,
		    GError **error)
{
	AsbPluginProcessFunc plugin_func = NULL;
	gboolean ret;

	/* run each plugin */
	asb_package_log (pkg,
			 ASB_PACKAGE_LOG_LEVEL_DEBUG,
			 "Running asb_plugin_process() from %s",
			 plugin->name);
	ret = g_module_symbol (plugin->module,
			       "asb_plugin_process",
			       (gpointer *) &plugin_func);
	if (!ret) {
		g_set_error_literal (error,
				     ASB_PLUGIN_ERROR,
				     ASB_PLUGIN_ERROR_FAILED,
				     "no asb_plugin_process");
		return NULL;
	}
	return plugin_func (plugin, pkg, tmpdir, error);
}

/**
 * asb_plugin_add_app:
 * @list: (element-type AsApp): A list of #AsApp's
 * @app: A #AsApp
 *
 * Adds an application to a list.
 *
 * Since: 0.1.0
 **/
void
asb_plugin_add_app (GList **list, AsApp *app)
{
	*list = g_list_prepend (*list, g_object_ref (app));
}

/**
 * asb_plugin_add_glob:
 * @array: (element-type utf8): A #GPtrArray
 * @glob: a filename glob
 *
 * Adds a glob from the plugin.
 *
 * Since: 0.1.0
 **/
void
asb_plugin_add_glob (GPtrArray *array, const gchar *glob)
{
	g_ptr_array_add (array, asb_glob_value_new (glob, ""));
}

/**
 * asb_plugin_match_glob:
 * @glob: a filename glob
 * @value: a filename value
 *
 * Matches a value against a glob.
 *
 * Since: 0.3.5
 **/
gboolean
asb_plugin_match_glob (const gchar *glob, const gchar *value)
{
	return (fnmatch (glob, value, 0) == 0);
}