AboutSummaryRefsLogTreeCommitDiffStats
diff options
context:
space:
mode:
authorMathieu Lirzin <mthl@gnu.org>2017-04-25 00:29:32 +0200
committerMathieu Lirzin <mthl@gnu.org>2017-09-28 15:57:21 +0200
commitc01106387f6d0866ef6fd4801473984cc642e60b (patch)
tree5e526b3efa61472cceecc01d6888da9cd52173e8
parent9b52c0d4544b2ed0fba156f87b75632c75b2084c (diff)
downloadmcron-c01106387f6d0866ef6fd4801473984cc642e60b.tar.gz
mcron-c01106387f6d0866ef6fd4801473984cc642e60b.tar.bz2
mcron-c01106387f6d0866ef6fd4801473984cc642e60b.zip
Replace generic C wrapper with individual programs
* src/wrapper.c: Delete. * src/crontab.c: New file. * src/mcron.c: Likewise. * src/cron.c: Likewise. * configure.ac: Adapt 'AC_CONFIG_DIR' to use "src/mcron.c". * Makefile.am (bin_crontab_SOURCES, bin_cron_SOURCES) (bin_mcron_SOURCES): Use new files. (bin_cron_CPPFLAGS, bin_mcron_CPPFLAGS, bin_crontab_CPPFLAGS): Delete.
-rw-r--r--Makefile.am9
-rw-r--r--configure.ac2
-rw-r--r--src/cron.c (renamed from src/wrapper.c)32
-rw-r--r--src/crontab.c49
-rw-r--r--src/mcron.c49
5 files changed, 113 insertions, 28 deletions
diff --git a/Makefile.am b/Makefile.am
index e5a105f..edca6a9 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -38,16 +38,13 @@ AM_CPPFLAGS = \
AM_CFLAGS = @GUILE_CFLAGS@
LDADD = @GUILE_LIBS@ src/libmcron.a
-bin_mcron_SOURCES = src/wrapper.c
-bin_mcron_CPPFLAGS = $(AM_CPPFLAGS) -DPROGRAM="\"mcron\""
+bin_mcron_SOURCES = src/mcron.c
bin_mcron_DEPENDENCIES = $(compiled_modules)
-bin_cron_SOURCES = src/wrapper.c
-bin_cron_CPPFLAGS = $(AM_CPPFLAGS) -DPROGRAM="\"cron\""
+bin_cron_SOURCES = src/cron.c
bin_cron_DEPENDENCIES = $(compiled_modules)
-bin_crontab_SOURCES = src/wrapper.c
-bin_crontab_CPPFLAGS = $(AM_CPPFLAGS) -DPROGRAM="\"crontab\""
+bin_crontab_SOURCES = src/crontab.c
bin_crontab_DEPENDENCIES = $(compiled_modules)
# wrapper to be used in the build environment and for running tests.
diff --git a/configure.ac b/configure.ac
index 98df7f9..0ce6475 100644
--- a/configure.ac
+++ b/configure.ac
@@ -22,7 +22,7 @@ AC_PREREQ(2.61)
AC_INIT([GNU Mcron],
m4_esyscmd([build-aux/git-version-gen .tarball-version]),
[bug-mcron@gnu.org])
-AC_CONFIG_SRCDIR([src/wrapper.c])
+AC_CONFIG_SRCDIR([src/mcron.c])
AC_CONFIG_AUX_DIR([build-aux])
AC_REQUIRE_AUX_FILE([test-driver.scm])
AC_REQUIRE_AUX_FILE([git-version-gen])
diff --git a/src/wrapper.c b/src/cron.c
index d5be805..55bcaaf 100644
--- a/src/wrapper.c
+++ b/src/cron.c
@@ -1,4 +1,4 @@
-/* wrapper.c -- C code booting Guile
+/* cron.c -- run jobs at scheduled times
Copyright © 2003, 2014 Dale Mellor <dale_mellor@users.sourceforge.net>
Copyright © 2015, 2016, 2017 Mathieu Lirzin <mthl@gnu.org>
@@ -17,25 +17,17 @@
You should have received a copy of the GNU General Public License
along with GNU Mcron. If not, see <http://www.gnu.org/licenses/>. */
-/* This C code represents a thin wrapper around the Guile code of Mcron. It
- is needed because the crontab personality requires SUID which is not
- permitted for executable scripts. */
-
#include "utils.h"
#include <libguile.h>
#include <signal.h>
-#include <stdbool.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
/* Forward declarations. */
-static void inner_main (void *closure, int argc, char **argv);
+static void inner_main (void *closure, int argc, char *argv[]);
static void react_to_terminal_signal (int sig);
static SCM set_cron_signals (void);
int
-main (int argc, char **argv)
+main (int argc, char *argv[])
{
/* Set Guile load paths to ensure that Mcron modules will be found after
installation. In a build environment let the 'pre-inst-env' script set
@@ -46,25 +38,23 @@ main (int argc, char **argv)
wrap_env_path ("GUILE_LOAD_COMPILED_PATH", PACKAGE_LOAD_COMPILED_PATH);
}
- scm_boot_guile (argc, argv, inner_main, 0);
+ scm_boot_guile (argc, argv, inner_main, NULL);
return EXIT_SUCCESS;
}
/* Launch the Mcron Guile main program. */
static void
-inner_main (void *closure, int argc, char **argv)
+inner_main (void *closure, int argc, char *argv[])
{
- scm_set_current_module (scm_c_resolve_module ("mcron scripts " PROGRAM));
- /* Register the procedures to be called from Guile. */
+ scm_set_current_module (scm_c_resolve_module ("mcron scripts cron"));
scm_c_define_gsubr ("c-set-cron-signals", 0, 0, 0, set_cron_signals);
- /* Call main procedure. */
scm_call_0 (scm_variable_ref (scm_c_lookup ("main")));
}
-/* Set up all the signal handlers as required by the cron personality. This
- is necessary to perform the signal processing in C because the sigaction
- function won't work when called from Guile. */
+/* Set up all the signal handlers. This is necessary to perform the signal
+ processing in C because the sigaction function won't work when called from
+ Guile. */
static SCM
set_cron_signals ()
{
@@ -80,8 +70,8 @@ set_cron_signals ()
return SCM_BOOL_T;
}
-/* Handle signal SIG and exit. All signals that mcron handles will produce
- the same behavior so we don't need to use SIG in the implementation. */
+/* Handle signal SIG and exit. All signals that cron handles will produce the
+ same behavior so we don't need to use SIG in the implementation. */
static void
react_to_terminal_signal (int sig)
{
diff --git a/src/crontab.c b/src/crontab.c
new file mode 100644
index 0000000..a432f1d
--- /dev/null
+++ b/src/crontab.c
@@ -0,0 +1,49 @@
+/* crontab.c -- edit users' crontab files
+ Copyright © 2003, 2014 Dale Mellor <dale_mellor@users.sourceforge.net>
+ Copyright © 2015, 2016, 2017 Mathieu Lirzin <mthl@gnu.org>
+
+ This file is part of GNU Mcron.
+
+ GNU Mcron 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.
+
+ GNU Mcron 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 GNU Mcron. If not, see <http://www.gnu.org/licenses/>. */
+
+#include "utils.h"
+#include <libguile.h>
+
+/* Forward declarations. */
+static void inner_main (void *closure, int argc, char *argv[]);
+
+int
+main (int argc, char *argv[])
+{
+ /* Set Guile load paths to ensure that Mcron modules will be found after
+ installation. In a build environment let the 'pre-inst-env' script set
+ the correct paths. */
+ if (getenv ("MCRON_UNINSTALLED") == NULL)
+ {
+ wrap_env_path ("GUILE_LOAD_PATH", PACKAGE_LOAD_PATH);
+ wrap_env_path ("GUILE_LOAD_COMPILED_PATH", PACKAGE_LOAD_COMPILED_PATH);
+ }
+
+ scm_boot_guile (argc, argv, inner_main, NULL);
+
+ return EXIT_SUCCESS;
+}
+
+/* Launch the Mcron Guile main program. */
+static void
+inner_main (void *closure, int argc, char *argv[])
+{
+ scm_set_current_module (scm_c_resolve_module ("mcron scripts crontab"));
+ scm_call_0 (scm_variable_ref (scm_c_lookup ("main")));
+}
diff --git a/src/mcron.c b/src/mcron.c
new file mode 100644
index 0000000..43afc72
--- /dev/null
+++ b/src/mcron.c
@@ -0,0 +1,49 @@
+/* mcron.c -- run jobs at scheduled times
+ Copyright © 2003, 2014 Dale Mellor <dale_mellor@users.sourceforge.net>
+ Copyright © 2015, 2016, 2017 Mathieu Lirzin <mthl@gnu.org>
+
+ This file is part of GNU Mcron.
+
+ GNU Mcron 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.
+
+ GNU Mcron 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 GNU Mcron. If not, see <http://www.gnu.org/licenses/>. */
+
+#include "utils.h"
+#include <libguile.h>
+
+/* Forward declarations. */
+static void inner_main (void *closure, int argc, char *argv[]);
+
+int
+main (int argc, char *argv[])
+{
+ /* Set Guile load paths to ensure that Mcron modules will be found after
+ installation. In a build environment let the 'pre-inst-env' script set
+ the correct paths. */
+ if (getenv ("MCRON_UNINSTALLED") == NULL)
+ {
+ wrap_env_path ("GUILE_LOAD_PATH", PACKAGE_LOAD_PATH);
+ wrap_env_path ("GUILE_LOAD_COMPILED_PATH", PACKAGE_LOAD_COMPILED_PATH);
+ }
+
+ scm_boot_guile (argc, argv, inner_main, NULL);
+
+ return EXIT_SUCCESS;
+}
+
+/* Launch the Mcron Guile main program. */
+static void
+inner_main (void *closure, int argc, char *argv[])
+{
+ scm_set_current_module (scm_c_resolve_module ("mcron scripts mcron"));
+ scm_call_0 (scm_variable_ref (scm_c_lookup ("main")));
+}