mu/mu/mu-cmd-script.c

190 lines
4.4 KiB
C
Raw Normal View History

2012-10-23 10:32:55 +02:00
2012-10-21 14:52:34 +02:00
/* -*-mode: c; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*-*/
/*
** Copyright (C) 2012 Dirk-Jan C. Binnema <djcb@djcbsoftware.nl>
**
** This program 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, or (at your option) any
** later version.
**
** This program 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 this program; if not, write to the Free Software Foundation,
** Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**
*/
#if HAVE_CONFIG_H
#include "config.h"
#endif /*HAVE_CONFIG_H*/
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <dirent.h>
#include <errno.h>
#include "mu-cmd.h"
#include "mu-util.h"
#include "mu-str.h"
#include "mu-script.h"
#define MU_GUILE_EXT ".scm"
2012-10-22 22:16:01 +02:00
#define MU_GUILE_DESCR_PREFIX ";; INFO: "
static void
print_script (const char *name, const char *oneline, const char *descr,
gboolean verbose)
{
g_print ("%s%s%s%s",
verbose ? "\n" : " * ",
name,
oneline ? ": " : "",
oneline ? oneline :"");
if (verbose && descr)
g_print ("%s", descr);
}
2012-10-22 22:16:01 +02:00
static gboolean
print_scripts (GSList *scripts, gboolean verbose, const char *rxstr,
GError **err)
2012-10-21 14:52:34 +02:00
{
2012-10-21 17:51:14 +02:00
GSList *cur;
2012-10-21 14:52:34 +02:00
2012-10-21 17:51:14 +02:00
if (!scripts) {
2012-10-22 22:16:01 +02:00
g_print ("No scripts available\n");
return TRUE; /* not an error */
2012-10-21 14:52:34 +02:00
}
2012-10-22 22:16:01 +02:00
if (rxstr)
g_print ("Available scripts matching '%s':\n", rxstr);
else
g_print ("Available scripts:\n");
2012-10-21 14:52:34 +02:00
for (cur = scripts; cur; cur = g_slist_next (cur)) {
2012-10-21 17:51:14 +02:00
2012-10-22 22:16:01 +02:00
MuScriptInfo *msi;
const char* descr, *oneline, *name;
msi = (MuScriptInfo*)cur->data;
name = mu_script_info_name (msi);
oneline = mu_script_info_one_line (msi);
descr = mu_script_info_description (msi);
/* if rxstr is provide, only consider matching scriptinfos */
if (rxstr && !mu_script_info_matches_regex (msi, rxstr, err)) {
if (err && *err)
return FALSE;
continue;
}
print_script (name, oneline, descr, verbose);
2012-10-21 17:51:14 +02:00
}
2012-10-22 22:16:01 +02:00
return TRUE;
2012-10-21 14:52:34 +02:00
}
2012-10-21 17:51:14 +02:00
static GSList*
get_script_info_list (const char *muhome, GError **err)
{
GSList *scripts, *userscripts, *last;
char *userpath;
2012-10-22 22:16:01 +02:00
scripts = mu_script_get_script_info_list
(MU_SCRIPTS_DIR, MU_GUILE_EXT,
MU_GUILE_DESCR_PREFIX,
err);
2012-10-21 17:51:14 +02:00
if (err && *err)
return NULL;
userpath = g_strdup_printf ("%s%c%s",
muhome, G_DIR_SEPARATOR,
"scripts" G_DIR_SEPARATOR_S "stats");
/* is there are userdir for scripts? */
if (!mu_util_check_dir (userpath, TRUE, FALSE))
return scripts;
/* append it to the list we already have */
userscripts = mu_script_get_script_info_list (userpath, MU_GUILE_EXT,
MU_GUILE_DESCR_PREFIX,
err);
/* some error, return nothing */
if (err && *err) {
mu_script_info_list_destroy (scripts);
return NULL;
}
/* append the user scripts */
last = g_slist_last (scripts);
if (last) {
last->next = userscripts;
return scripts;
} else
return userscripts; /* apparently, scripts was NULL */
}
2012-10-21 14:52:34 +02:00
static gboolean
check_params (MuConfig *opts, GError **err)
{
if (!mu_util_supports (MU_FEATURE_GUILE | MU_FEATURE_GNUPLOT)) {
mu_util_g_set_error (err, MU_ERROR_IN_PARAMETERS,
2012-10-22 22:16:01 +02:00
"the 'script' command is not supported");
2012-10-21 14:52:34 +02:00
return FALSE;
}
return TRUE;
}
MuError
2012-10-22 22:16:01 +02:00
mu_cmd_script (MuConfig *opts, GError **err)
2012-10-21 14:52:34 +02:00
{
MuScriptInfo *msi;
GSList *scripts;
g_return_val_if_fail (opts, MU_ERROR_INTERNAL);
2012-10-22 22:16:01 +02:00
g_return_val_if_fail (opts->cmd == MU_CONFIG_CMD_SCRIPT,
2012-10-21 14:52:34 +02:00
MU_ERROR_INTERNAL);
if (!check_params (opts, err))
return MU_ERROR;
2012-10-21 17:51:14 +02:00
scripts = get_script_info_list (opts->muhome, err);
2012-10-21 14:52:34 +02:00
if (err && *err)
2012-10-21 17:51:14 +02:00
goto leave;
2012-10-22 22:16:01 +02:00
if (!opts->script) {
print_scripts (scripts, opts->verbose,
opts->params[1], err);
2012-10-21 17:51:14 +02:00
goto leave;
}
2012-10-21 14:52:34 +02:00
2012-10-22 22:16:01 +02:00
msi = mu_script_find_script_with_name (scripts, opts->script);
2012-10-21 14:52:34 +02:00
if (!msi) {
mu_util_g_set_error (err, MU_ERROR_IN_PARAMETERS,
"script not found");
2012-10-21 17:51:14 +02:00
goto leave;
2012-10-21 14:52:34 +02:00
}
/* do it! */
2012-10-22 22:16:01 +02:00
mu_script_guile_run (msi, opts->muhome,
(const gchar**)&opts->params[1], err);
2012-10-21 17:51:14 +02:00
leave:
2012-10-21 14:52:34 +02:00
/* this won't be reached, unless there is some error */
mu_script_info_list_destroy (scripts);
2012-10-21 17:51:14 +02:00
return (err && *err) ? MU_ERROR : MU_OK;
2012-10-21 14:52:34 +02:00
}