diff options
author | Mathieu Lirzin <mthl@gnu.org> | 2017-04-25 00:29:32 +0200 |
---|---|---|
committer | Mathieu Lirzin <mthl@gnu.org> | 2017-09-28 15:57:21 +0200 |
commit | c01106387f6d0866ef6fd4801473984cc642e60b (patch) | |
tree | 5e526b3efa61472cceecc01d6888da9cd52173e8 | |
parent | 9b52c0d4544b2ed0fba156f87b75632c75b2084c (diff) | |
download | mcron-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.am | 9 | ||||
-rw-r--r-- | configure.ac | 2 | ||||
-rw-r--r-- | src/cron.c (renamed from src/wrapper.c) | 32 | ||||
-rw-r--r-- | src/crontab.c | 49 | ||||
-rw-r--r-- | src/mcron.c | 49 |
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"))); +} |