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