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.
This commit is contained in:
parent
9b52c0d454
commit
c01106387f
5 changed files with 113 additions and 28 deletions
|
|
@ -38,16 +38,13 @@ AM_CPPFLAGS = \
|
||||||
AM_CFLAGS = @GUILE_CFLAGS@
|
AM_CFLAGS = @GUILE_CFLAGS@
|
||||||
LDADD = @GUILE_LIBS@ src/libmcron.a
|
LDADD = @GUILE_LIBS@ src/libmcron.a
|
||||||
|
|
||||||
bin_mcron_SOURCES = src/wrapper.c
|
bin_mcron_SOURCES = src/mcron.c
|
||||||
bin_mcron_CPPFLAGS = $(AM_CPPFLAGS) -DPROGRAM="\"mcron\""
|
|
||||||
bin_mcron_DEPENDENCIES = $(compiled_modules)
|
bin_mcron_DEPENDENCIES = $(compiled_modules)
|
||||||
|
|
||||||
bin_cron_SOURCES = src/wrapper.c
|
bin_cron_SOURCES = src/cron.c
|
||||||
bin_cron_CPPFLAGS = $(AM_CPPFLAGS) -DPROGRAM="\"cron\""
|
|
||||||
bin_cron_DEPENDENCIES = $(compiled_modules)
|
bin_cron_DEPENDENCIES = $(compiled_modules)
|
||||||
|
|
||||||
bin_crontab_SOURCES = src/wrapper.c
|
bin_crontab_SOURCES = src/crontab.c
|
||||||
bin_crontab_CPPFLAGS = $(AM_CPPFLAGS) -DPROGRAM="\"crontab\""
|
|
||||||
bin_crontab_DEPENDENCIES = $(compiled_modules)
|
bin_crontab_DEPENDENCIES = $(compiled_modules)
|
||||||
|
|
||||||
# wrapper to be used in the build environment and for running tests.
|
# wrapper to be used in the build environment and for running tests.
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@ AC_PREREQ(2.61)
|
||||||
AC_INIT([GNU Mcron],
|
AC_INIT([GNU Mcron],
|
||||||
m4_esyscmd([build-aux/git-version-gen .tarball-version]),
|
m4_esyscmd([build-aux/git-version-gen .tarball-version]),
|
||||||
[bug-mcron@gnu.org])
|
[bug-mcron@gnu.org])
|
||||||
AC_CONFIG_SRCDIR([src/wrapper.c])
|
AC_CONFIG_SRCDIR([src/mcron.c])
|
||||||
AC_CONFIG_AUX_DIR([build-aux])
|
AC_CONFIG_AUX_DIR([build-aux])
|
||||||
AC_REQUIRE_AUX_FILE([test-driver.scm])
|
AC_REQUIRE_AUX_FILE([test-driver.scm])
|
||||||
AC_REQUIRE_AUX_FILE([git-version-gen])
|
AC_REQUIRE_AUX_FILE([git-version-gen])
|
||||||
|
|
|
||||||
|
|
@ -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 © 2003, 2014 Dale Mellor <dale_mellor@users.sourceforge.net>
|
||||||
Copyright © 2015, 2016, 2017 Mathieu Lirzin <mthl@gnu.org>
|
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
|
You should have received a copy of the GNU General Public License
|
||||||
along with GNU Mcron. If not, see <http://www.gnu.org/licenses/>. */
|
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 "utils.h"
|
||||||
#include <libguile.h>
|
#include <libguile.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <stdbool.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/* Forward declarations. */
|
/* 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 void react_to_terminal_signal (int sig);
|
||||||
static SCM set_cron_signals (void);
|
static SCM set_cron_signals (void);
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char **argv)
|
main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
/* Set Guile load paths to ensure that Mcron modules will be found after
|
/* 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
|
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);
|
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;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Launch the Mcron Guile main program. */
|
/* Launch the Mcron Guile main program. */
|
||||||
static void
|
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));
|
scm_set_current_module (scm_c_resolve_module ("mcron scripts cron"));
|
||||||
/* Register the procedures to be called from Guile. */
|
|
||||||
scm_c_define_gsubr ("c-set-cron-signals", 0, 0, 0, set_cron_signals);
|
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")));
|
scm_call_0 (scm_variable_ref (scm_c_lookup ("main")));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set up all the signal handlers as required by the cron personality. This
|
/* Set up all the signal handlers. This is necessary to perform the signal
|
||||||
is necessary to perform the signal processing in C because the sigaction
|
processing in C because the sigaction function won't work when called from
|
||||||
function won't work when called from Guile. */
|
Guile. */
|
||||||
static SCM
|
static SCM
|
||||||
set_cron_signals ()
|
set_cron_signals ()
|
||||||
{
|
{
|
||||||
|
|
@ -80,8 +70,8 @@ set_cron_signals ()
|
||||||
return SCM_BOOL_T;
|
return SCM_BOOL_T;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Handle signal SIG and exit. All signals that mcron handles will produce
|
/* Handle signal SIG and exit. All signals that cron handles will produce the
|
||||||
the same behavior so we don't need to use SIG in the implementation. */
|
same behavior so we don't need to use SIG in the implementation. */
|
||||||
static void
|
static void
|
||||||
react_to_terminal_signal (int sig)
|
react_to_terminal_signal (int sig)
|
||||||
{
|
{
|
||||||
49
src/crontab.c
Normal file
49
src/crontab.c
Normal file
|
|
@ -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")));
|
||||||
|
}
|
||||||
49
src/mcron.c
Normal file
49
src/mcron.c
Normal file
|
|
@ -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")));
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue