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@
|
||||
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.
|
||||
|
|
|
|||
|
|
@ -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])
|
||||
|
|
|
|||
|
|
@ -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)
|
||||
{
|
||||
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