]> granicus.if.org Git - cronie/commitdiff
Cron source was ready for merge with patches. After the merge
authormmaslano <mmaslano@redhat.com>
Fri, 24 Aug 2007 06:35:07 +0000 (08:35 +0200)
committerTomas Janousek <tomi@nomi.cz>
Mon, 27 Aug 2007 14:03:55 +0000 (16:03 +0200)
I used autotools (files were copied to new dirs and configure.ac
and Makefile.am were written).

49 files changed:
AUTHORS [new file with mode: 0644]
COPYING [new file with mode: 0644]
ChangeLog [new file with mode: 0644]
INSTALL
Makefile [deleted file]
Makefile.am [new file with mode: 0644]
NEWS [new file with mode: 0644]
README
config.h.in [new file with mode: 0644]
configure.ac [new file with mode: 0644]
crond.sysconfig [new file with mode: 0644]
doc/CHANGES [moved from CHANGES with 100% similarity]
doc/CONVERSION [moved from CONVERSION with 100% similarity]
doc/FEATURES [moved from FEATURES with 100% similarity]
doc/INSTALL [new file with mode: 0644]
doc/MAIL [moved from MAIL with 100% similarity]
doc/Makefile.am [new file with mode: 0644]
doc/README [new file with mode: 0644]
doc/THANKS [moved from THANKS with 100% similarity]
man/Makefile.am [new file with mode: 0644]
man/bitstring.3.in [moved from bitstring.3 with 100% similarity]
man/cron.8.in [moved from cron.8 with 100% similarity]
man/crontab.1.in [moved from crontab.1 with 100% similarity]
man/crontab.5.in [moved from crontab.5 with 100% similarity]
putman.sh [deleted file]
src/Makefile.am [new file with mode: 0644]
src/bitstring.h [moved from bitstring.h with 100% similarity]
src/config.h [moved from config.h with 100% similarity]
src/cron.c [moved from cron.c with 100% similarity]
src/cron.h [moved from cron.h with 100% similarity]
src/crontab.c [moved from crontab.c with 100% similarity]
src/database.c [moved from database.c with 100% similarity]
src/do_command.c [moved from do_command.c with 100% similarity]
src/entry.c [moved from entry.c with 100% similarity]
src/env.c [moved from env.c with 100% similarity]
src/externs.h [moved from externs.h with 100% similarity]
src/funcs.h [moved from funcs.h with 100% similarity]
src/globals.h [moved from globals.h with 100% similarity]
src/job.c [moved from job.c with 100% similarity]
src/macros.h [moved from macros.h with 100% similarity]
src/misc.c [moved from misc.c with 100% similarity]
src/pathnames.h [moved from pathnames.h with 100% similarity]
src/popen.c [moved from popen.c with 100% similarity]
src/pw_dup.c [moved from pw_dup.c with 100% similarity]
src/security.c [moved from security.c with 100% similarity]
src/structs.h [moved from structs.h with 100% similarity]
src/user.c [moved from user.c with 100% similarity]
stamp-h1 [new file with mode: 0644]
vixie-cron.init [new file with mode: 0755]

diff --git a/AUTHORS b/AUTHORS
new file mode 100644 (file)
index 0000000..1cbd2b5
--- /dev/null
+++ b/AUTHORS
@@ -0,0 +1,2 @@
+Original vixie-cron was written by Paul Vixie.
+
diff --git a/COPYING b/COPYING
new file mode 100644 (file)
index 0000000..b7b5f53
--- /dev/null
+++ b/COPYING
@@ -0,0 +1,340 @@
+                   GNU GENERAL PUBLIC LICENSE
+                      Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
+       51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+                           Preamble
+
+  The licenses for most software are designed to take away your
+freedom to share and change it.  By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users.  This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it.  (Some other Free Software Foundation software is covered by
+the GNU Library General Public License instead.)  You can apply it to
+your programs, too.
+
+  When we speak of free software, we are referring to freedom, not
+price.  Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+  To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+  For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have.  You must make sure that they, too, receive or can get the
+source code.  And you must show them these terms so they know their
+rights.
+
+  We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+  Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software.  If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+  Finally, any free program is threatened constantly by software
+patents.  We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary.  To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+  The precise terms and conditions for copying, distribution and
+modification follow.
+\f
+                   GNU GENERAL PUBLIC LICENSE
+   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+  0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License.  The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language.  (Hereinafter, translation is included without limitation in
+the term "modification".)  Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope.  The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+  1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+  2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+    a) You must cause the modified files to carry prominent notices
+    stating that you changed the files and the date of any change.
+
+    b) You must cause any work that you distribute or publish, that in
+    whole or in part contains or is derived from the Program or any
+    part thereof, to be licensed as a whole at no charge to all third
+    parties under the terms of this License.
+
+    c) If the modified program normally reads commands interactively
+    when run, you must cause it, when started running for such
+    interactive use in the most ordinary way, to print or display an
+    announcement including an appropriate copyright notice and a
+    notice that there is no warranty (or else, saying that you provide
+    a warranty) and that users may redistribute the program under
+    these conditions, and telling the user how to view a copy of this
+    License.  (Exception: if the Program itself is interactive but
+    does not normally print such an announcement, your work based on
+    the Program is not required to print an announcement.)
+\f
+These requirements apply to the modified work as a whole.  If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works.  But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+  3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+    a) Accompany it with the complete corresponding machine-readable
+    source code, which must be distributed under the terms of Sections
+    1 and 2 above on a medium customarily used for software interchange; or,
+
+    b) Accompany it with a written offer, valid for at least three
+    years, to give any third party, for a charge no more than your
+    cost of physically performing source distribution, a complete
+    machine-readable copy of the corresponding source code, to be
+    distributed under the terms of Sections 1 and 2 above on a medium
+    customarily used for software interchange; or,
+
+    c) Accompany it with the information you received as to the offer
+    to distribute corresponding source code.  (This alternative is
+    allowed only for noncommercial distribution and only if you
+    received the program in object code or executable form with such
+    an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it.  For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable.  However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+\f
+  4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License.  Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+  5. You are not required to accept this License, since you have not
+signed it.  However, nothing else grants you permission to modify or
+distribute the Program or its derivative works.  These actions are
+prohibited by law if you do not accept this License.  Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+  6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions.  You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+  7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License.  If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all.  For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices.  Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+\f
+  8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded.  In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+  9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time.  Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number.  If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation.  If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+  10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission.  For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this.  Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+                           NO WARRANTY
+
+  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+  12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+                    END OF TERMS AND CONDITIONS
+\f
+           How to Apply These Terms to Your New Programs
+
+  If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+  To do so, attach the following notices to the program.  It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+    <one line to give the program's name and a brief idea of what it does.>
+    Copyright (C) <year>  <name of author>
+
+    This program 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 2 of the License, or
+    (at your option) any later version.
+
+    This program 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 this program; if not, write to the Free Software
+    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
+
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+    Gnomovision version 69, Copyright (C) year  name of author
+    Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+    This is free software, and you are welcome to redistribute it
+    under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License.  Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary.  Here is a sample; alter the names:
+
+  Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+  `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+  <signature of Ty Coon>, 1 April 1989
+  Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs.  If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library.  If this is what you want to do, use the GNU Library General
+Public License instead of this License.
diff --git a/ChangeLog b/ChangeLog
new file mode 100644 (file)
index 0000000..1eddc12
--- /dev/null
+++ b/ChangeLog
@@ -0,0 +1,3 @@
+vixie-cron-4.2 changes are in vixie-cron.spec
+
+vixie-cron-4.1 and older changes are in /doc
diff --git a/INSTALL b/INSTALL
index e92adba93a4db5e8216f882405640671cdc495bc..5458714e1e2cb289572992ad92eceffc848f64d6 100644 (file)
--- a/INSTALL
+++ b/INSTALL
-/* Copyright 1993,1994 by Paul Vixie
- * All rights reserved
- */
-
-/*
- * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
- * Copyright (c) 1997,2000 by Internet Software Consortium, Inc.
- *
- * Permission to use, copy, modify, and distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
- * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-$Id: INSTALL,v 1.4 2004/01/23 18:56:42 vixie Exp $
-
-Read the comments at the top of the Makefile, then edit the area marked
-'configurable stuff'.
-
-Edit config.h.  The stuff I expect you to change is down a bit from the
-top of the file, but it's clearly marked.  Also look at pathnames.h.
-
-You don't have to create the /var/cron or /var/cron/tabs directories, since
-both the daemon and the `crontab' program will do this the first time they
-run if they don't exist.  You do need to have a /var, though -- just "mkdir
-/var" if you don't have one, or you can "mkdir /usr/var; ln -s /usr/var /var"
-if you expect your /var to have a lot of stuff in it.
-
-You will also need /usr/local/etc and /usr/local/bin directories unless you
-change the Makefile.  These will have to be created by hand, but if you are
-a long-time Usenet user you probably have them already.  /usr/local/man is
-where I keep my man pages, but I have the source for `man' and you probably
-do not.  Therefore you may have to put the man pages into /usr/man/manl,
-which will be hard since there will be name collisions.  (Note that the man
-command was originally written by Bill Joy before he left Berkeley, and it
-contains no AT&T code, so it is in UUNET's archive of freely-distributable
-BSD code.)
-
-LINUX note: /usr/include/paths.h on some linux systems shows _PATH_SENDMAIL
-       to be /usr/bin/sendmail even though sendmail is installed in /usr/lib.
-       you should check this out.
-
-say:
-       make all
-
-su and say:
-       make install
-
-Note that if I can get you to "su and say" something just by asking, you have
-a very serious security problem on your system and you should look into it.
-
-Edit your /usr/lib/crontab file into little pieces -- see the CONVERSION file
-for help on this.
-
-Use the `crontab' command to install all the little pieces you just created.
-Some examples (see below before trying any of these!)
-
-       crontab -u uucp -r /usr/lib/uucp/crontab.src
-       crontab -u news -r /usr/lib/news/crontab.src
-       crontab -u root -r /usr/adm/crontab.src
-
-Notes on above examples: (1) the .src files are copied at the time the
-command is issued; changing the source files later will have no effect until
-they are reinstalled with another `crontab -r' command.  (2) The crontab
-command will affect the crontab of the person using the command unless `-u
-USER' is given; `-u' only works for root.  When using most `su' commands
-under most BSD's, `crontab' will still think of you as yourself even though
-you may think of yourself as root -- so use `-u' liberally.  (3) the `-r'
-option stands for `replace'; check the man page for crontab(1) for other
-possibilities.
-
-Kill your existing cron daemon -- do `ps aux' and look for /etc/cron.
-
-Edit your /etc/rc or /etc/rc.local, looking for the line that starts up
-/etc/cron.  Comment it out and add a line to start the new cron daemon
--- usually /usr/local/etc/cron, unless you changed it in the Makefile.
-
-Start up this cron daemon yourself as root.  Just type /usr/local/etc/cron
-(or whatever); no '&' is needed since the daemon forks itself and the
-process you executed returns immediately.
-
-ATT notes: for those people unfortunate enough to be stuck on a AT&T UNIX,
-you will need the public-domain "libndir", found in the B News source and in
-any comp.sources.unix archive.  You will also need to hack the code some.
+Installation Instructions
+*************************
+
+Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002, 2004, 2005,
+2006 Free Software Foundation, Inc.
+
+This file is free documentation; the Free Software Foundation gives
+unlimited permission to copy, distribute and modify it.
+
+Basic Installation
+==================
+
+Briefly, the shell commands `./configure; make; make install' should
+configure, build, and install this package.  The following
+more-detailed instructions are generic; see the `README' file for
+instructions specific to this package.
+
+   The `configure' shell script attempts to guess correct values for
+various system-dependent variables used during compilation.  It uses
+those values to create a `Makefile' in each directory of the package.
+It may also create one or more `.h' files containing system-dependent
+definitions.  Finally, it creates a shell script `config.status' that
+you can run in the future to recreate the current configuration, and a
+file `config.log' containing compiler output (useful mainly for
+debugging `configure').
+
+   It can also use an optional file (typically called `config.cache'
+and enabled with `--cache-file=config.cache' or simply `-C') that saves
+the results of its tests to speed up reconfiguring.  Caching is
+disabled by default to prevent problems with accidental use of stale
+cache files.
+
+   If you need to do unusual things to compile the package, please try
+to figure out how `configure' could check whether to do them, and mail
+diffs or instructions to the address given in the `README' so they can
+be considered for the next release.  If you are using the cache, and at
+some point `config.cache' contains results you don't want to keep, you
+may remove or edit it.
+
+   The file `configure.ac' (or `configure.in') is used to create
+`configure' by a program called `autoconf'.  You need `configure.ac' if
+you want to change it or regenerate `configure' using a newer version
+of `autoconf'.
+
+The simplest way to compile this package is:
+
+  1. `cd' to the directory containing the package's source code and type
+     `./configure' to configure the package for your system.
+
+     Running `configure' might take a while.  While running, it prints
+     some messages telling which features it is checking for.
+
+  2. Type `make' to compile the package.
+
+  3. Optionally, type `make check' to run any self-tests that come with
+     the package.
+
+  4. Type `make install' to install the programs and any data files and
+     documentation.
+
+  5. You can remove the program binaries and object files from the
+     source code directory by typing `make clean'.  To also remove the
+     files that `configure' created (so you can compile the package for
+     a different kind of computer), type `make distclean'.  There is
+     also a `make maintainer-clean' target, but that is intended mainly
+     for the package's developers.  If you use it, you may have to get
+     all sorts of other programs in order to regenerate files that came
+     with the distribution.
+
+Compilers and Options
+=====================
+
+Some systems require unusual options for compilation or linking that the
+`configure' script does not know about.  Run `./configure --help' for
+details on some of the pertinent environment variables.
+
+   You can give `configure' initial values for configuration parameters
+by setting variables in the command line or in the environment.  Here
+is an example:
+
+     ./configure CC=c99 CFLAGS=-g LIBS=-lposix
+
+   *Note Defining Variables::, for more details.
+
+Compiling For Multiple Architectures
+====================================
+
+You can compile the package for more than one kind of computer at the
+same time, by placing the object files for each architecture in their
+own directory.  To do this, you can use GNU `make'.  `cd' to the
+directory where you want the object files and executables to go and run
+the `configure' script.  `configure' automatically checks for the
+source code in the directory that `configure' is in and in `..'.
+
+   With a non-GNU `make', it is safer to compile the package for one
+architecture at a time in the source code directory.  After you have
+installed the package for one architecture, use `make distclean' before
+reconfiguring for another architecture.
+
+Installation Names
+==================
+
+By default, `make install' installs the package's commands under
+`/usr/local/bin', include files under `/usr/local/include', etc.  You
+can specify an installation prefix other than `/usr/local' by giving
+`configure' the option `--prefix=PREFIX'.
+
+   You can specify separate installation prefixes for
+architecture-specific files and architecture-independent files.  If you
+pass the option `--exec-prefix=PREFIX' to `configure', the package uses
+PREFIX as the prefix for installing programs and libraries.
+Documentation and other data files still use the regular prefix.
+
+   In addition, if you use an unusual directory layout you can give
+options like `--bindir=DIR' to specify different values for particular
+kinds of files.  Run `configure --help' for a list of the directories
+you can set and what kinds of files go in them.
+
+   If the package supports it, you can cause programs to be installed
+with an extra prefix or suffix on their names by giving `configure' the
+option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
+
+Optional Features
+=================
+
+Some packages pay attention to `--enable-FEATURE' options to
+`configure', where FEATURE indicates an optional part of the package.
+They may also pay attention to `--with-PACKAGE' options, where PACKAGE
+is something like `gnu-as' or `x' (for the X Window System).  The
+`README' should mention any `--enable-' and `--with-' options that the
+package recognizes.
+
+   For packages that use the X Window System, `configure' can usually
+find the X include and library files automatically, but if it doesn't,
+you can use the `configure' options `--x-includes=DIR' and
+`--x-libraries=DIR' to specify their locations.
+
+Specifying the System Type
+==========================
+
+There may be some features `configure' cannot figure out automatically,
+but needs to determine by the type of machine the package will run on.
+Usually, assuming the package is built to be run on the _same_
+architectures, `configure' can figure that out, but if it prints a
+message saying it cannot guess the machine type, give it the
+`--build=TYPE' option.  TYPE can either be a short name for the system
+type, such as `sun4', or a canonical name which has the form:
+
+     CPU-COMPANY-SYSTEM
+
+where SYSTEM can have one of these forms:
+
+     OS KERNEL-OS
+
+   See the file `config.sub' for the possible values of each field.  If
+`config.sub' isn't included in this package, then this package doesn't
+need to know the machine type.
+
+   If you are _building_ compiler tools for cross-compiling, you should
+use the option `--target=TYPE' to select the type of system they will
+produce code for.
+
+   If you want to _use_ a cross compiler, that generates code for a
+platform different from the build platform, you should specify the
+"host" platform (i.e., that on which the generated programs will
+eventually be run) with `--host=TYPE'.
+
+Sharing Defaults
+================
+
+If you want to set default values for `configure' scripts to share, you
+can create a site shell script called `config.site' that gives default
+values for variables like `CC', `cache_file', and `prefix'.
+`configure' looks for `PREFIX/share/config.site' if it exists, then
+`PREFIX/etc/config.site' if it exists.  Or, you can set the
+`CONFIG_SITE' environment variable to the location of the site script.
+A warning: not all `configure' scripts look for a site script.
+
+Defining Variables
+==================
+
+Variables not defined in a site shell script can be set in the
+environment passed to `configure'.  However, some packages may run
+configure again during the build, and the customized values of these
+variables may be lost.  In order to avoid this problem, you should set
+them in the `configure' command line, using `VAR=value'.  For example:
+
+     ./configure CC=/usr/local2/bin/gcc
+
+causes the specified `gcc' to be used as the C compiler (unless it is
+overridden in the site shell script).
+
+Unfortunately, this technique does not work for `CONFIG_SHELL' due to
+an Autoconf bug.  Until the bug is fixed you can use this workaround:
+
+     CONFIG_SHELL=/bin/bash /bin/bash ./configure CONFIG_SHELL=/bin/bash
+
+`configure' Invocation
+======================
+
+`configure' recognizes the following options to control how it operates.
+
+`--help'
+`-h'
+     Print a summary of the options to `configure', and exit.
+
+`--version'
+`-V'
+     Print the version of Autoconf used to generate the `configure'
+     script, and exit.
+
+`--cache-file=FILE'
+     Enable the cache: use and save the results of the tests in FILE,
+     traditionally `config.cache'.  FILE defaults to `/dev/null' to
+     disable caching.
+
+`--config-cache'
+`-C'
+     Alias for `--cache-file=config.cache'.
+
+`--quiet'
+`--silent'
+`-q'
+     Do not print messages saying which checks are being made.  To
+     suppress all normal output, redirect it to `/dev/null' (any error
+     messages will still be shown).
+
+`--srcdir=DIR'
+     Look for the package's source code in directory DIR.  Usually
+     `configure' can determine that directory automatically.
+
+`configure' also accepts some other, not widely useful, options.  Run
+`configure --help' for more details.
+
diff --git a/Makefile b/Makefile
deleted file mode 100644 (file)
index dbd1a2e..0000000
--- a/Makefile
+++ /dev/null
@@ -1,156 +0,0 @@
-#/* Copyright 1988,1990,1993,1994 by Paul Vixie
-# * All rights reserved
-# */
-
-##
-## Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
-## Copyright (c) 1997,2000 by Internet Software Consortium, Inc.
-##
-## Permission to use, copy, modify, and distribute this software for any
-## purpose with or without fee is hereby granted, provided that the above
-## copyright notice and this permission notice appear in all copies.
-##
-## THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
-## WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-## MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR
-## ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-## WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-## ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
-## OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-##
-
-# Makefile for ISC cron
-#
-# $Id: Makefile,v 1.9 2004/01/23 18:56:42 vixie Exp $
-#
-# vix 03mar88 [moved to RCS, rest of log is in there]
-# vix 30mar87 [goodbye, time.c; hello, getopt]
-# vix 12feb87 [cleanup for distribution]
-# vix 30dec86 [written]
-
-# NOTES:
-#      'make' can be done by anyone
-#      'make install' must be done by root
-#
-#      this package needs getopt(3), bitstring(3), and BSD install(8).
-#
-#      the configurable stuff in this makefile consists of compilation
-#      options (use -O, cron runs forever) and destination directories.
-#      SHELL is for the 'augumented make' systems where 'make' imports
-#      SHELL from the environment and then uses it to run its commands.
-#      if your environment SHELL variable is /bin/csh, make goes real
-#      slow and sometimes does the wrong thing.  
-#
-#      this package needs the 'bitstring macros' library, which is
-#      available from me or from the comp.sources.unix archive.  if you
-#      put 'bitstring.h' in a non-standard place (i.e., not intuited by
-#      cc(1)), you will have to define INCLUDE to set the include
-#      directory for cc.  INCLUDE should be `-Isomethingorother'.
-#
-#      there's more configuration info in config.h; edit that first!
-
-#################################### begin configurable stuff
-#<<DESTROOT is assumed to have ./etc, ./bin, and ./man subdirectories>>
-DESTROOT       =       $(DESTDIR)/usr
-DESTSBIN       =       $(DESTROOT)/sbin
-DESTBIN                =       $(DESTROOT)/bin
-DESTMAN                =       $(DESTROOT)/share/man
-DESTETC                =       $(DESTROOT)/../etc
-#<<need bitstring.h>>
-INCLUDE                =       -I.
-#INCLUDE       =
-#<<need getopt()>>
-ifdef WITH_SELINUX
-SELINUX_LIBS=-lselinux
-SELINUX_DEFS=-DWITH_SELINUX
-endif
-ifdef WITH_PAM
-PAM_LIBS=-lpam -lpam_misc
-PAM_DEFS=-DWITH_PAM
-endif
-ifdef WITH_AUDIT
-AUDIT_LIBS=-laudit
-AUDIT_DEFS=-DWITH_AUDIT
-endif
-LIBS           =       $(SELINUX_LIBS) $(PAM_LIBS) $(AUDIT_LIBS)
-#<<optimize or debug?>>
-#CDEBUG                =       -O
-#CDEBUG                =       -g
-CDEBUG         =       $(RPM_OPT_FLAGS)
-#<<lint flags of choice?>>
-LINTFLAGS      =       -hbxa $(INCLUDE) $(DEBUGGING)
-#<<want to use a nonstandard CC?>>
-CC             =       gcc -Wall -Wno-unused -Wno-comment
-#<<manifest defines>>
-DEFS           =       $(SELINUX_DEFS) $(PAM_DEFS) $(AUDIT_DEFS)
-#(SGI IRIX systems need this)
-#DEFS          =       -D_BSD_SIGNALS -Dconst=
-#<<the name of the BSD-like install program>>
-#INSTALL = installbsd
-INSTALL = install
-#<<any special load flags>>
-LDFLAGS                =       -g
-#################################### end configurable stuff
-
-SHELL          =       /bin/sh
-CFLAGS         =       $(CDEBUG) $(INCLUDE) $(DEFS)
-
-INFOS          =       README CHANGES FEATURES INSTALL CONVERSION THANKS MAIL
-MANPAGES       =       bitstring.3 crontab.5 crontab.1 cron.8 putman.sh
-HEADERS                =       bitstring.h cron.h config.h pathnames.h externs.h \
-                       macros.h structs.h funcs.h globals.h
-SOURCES                =       cron.c crontab.c database.c do_command.c entry.c \
-                       env.c job.c user.c popen.c misc.c pw_dup.c security.c
-SHAR_SOURCE    =       $(INFOS) $(MANPAGES) Makefile $(HEADERS) $(SOURCES)
-LINT_CRON      =       cron.c database.c user.c entry.c \
-                       misc.c job.c do_command.c env.c popen.c pw_dup.c
-LINT_CRONTAB   =       crontab.c misc.c entry.c env.c
-CRON_OBJ       =       cron.o database.o user.o entry.o job.o do_command.o \
-                       misc.o env.o popen.o pw_dup.o security.o
-CRONTAB_OBJ    =       crontab.o misc.o entry.o env.o pw_dup.o security.o
-
-all            :       cron crontab
-
-lint           :
-                       lint $(LINTFLAGS) $(LINT_CRON) $(LIBS) \
-                       |grep -v "constant argument to NOT" 2>&1
-                       lint $(LINTFLAGS) $(LINT_CRONTAB) $(LIBS) \
-                       |grep -v "constant argument to NOT" 2>&1
-
-cron           :       $(CRON_OBJ)
-                       $(CC) $(LDFLAGS) -o cron -pie $(CRON_OBJ) $(LIBS)
-
-crontab                :       $(CRONTAB_OBJ)
-                       $(CC) $(LDFLAGS) -o crontab $(CRONTAB_OBJ) $(LIBS)
-
-install                :       all
-                       $(INSTALL) -c -m 755 cron    $(DESTSBIN)/crond
-                       $(INSTALL) -c -m 4755 crontab $(DESTBIN)/
-                       $(INSTALL) -c -m 0600 crond.pam $(DESTETC)/pam.d/crond
-#                      $(INSTALL) -c -m  111 -o root -g crontab -s cron $(DESTSBIN)/
-#                      $(INSTALL) -c -m 2111 -o root -g crontab -s crontab $(DESTBIN)/
-                       sh putman.sh crontab.1 $(DESTMAN)
-                       chmod 644 $(DESTMAN)/man1/crontab.1
-                       sh putman.sh cron.8    $(DESTMAN)
-                       chmod 644 $(DESTMAN)/man8/cron.8
-                       ln -sf cron.8 $(DESTMAN)/man8/crond.8
-                       sh putman.sh crontab.5 $(DESTMAN)
-                       chmod 644 $(DESTMAN)/man5/crontab.5
-
-distclean      :       clean
-                       rm -f *.orig *.rej *.BAK *.CKP *~ #*
-                       rm -f a.out core tags
-
-clean          :
-                       rm -f *.o cron crontab a.out core tags *~ #*
-
-tags           :;      ctags ${SOURCES}
-
-kit            :       $(SHAR_SOURCE)
-                       shar $(SHAR_SOURCE) >kit
-
-$(CRON_OBJ)    :       cron.h config.h externs.h pathnames.h Makefile
-$(CRONTAB_OBJ) :       cron.h config.h externs.h pathnames.h Makefile
-
-$(CRON_OBJ): %.o: %.c
-       $(CC) $(CFLAGS) -fpie -c $<
diff --git a/Makefile.am b/Makefile.am
new file mode 100644 (file)
index 0000000..f096c20
--- /dev/null
@@ -0,0 +1,2 @@
+SUBDIRS = src man doc
+
diff --git a/NEWS b/NEWS
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/README b/README
index fcc64c998d00008303c06992136f5129e8be4725..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 100644 (file)
--- a/README
+++ b/README
@@ -1,72 +0,0 @@
-#/* Copyright 1988,1990,1993 by Paul Vixie
-# * All rights reserved
-# */
-
-##
-## Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
-## Copyright (c) 1997,2000 by Internet Software Consortium, Inc.
-##
-## Permission to use, copy, modify, and distribute this software for any
-## purpose with or without fee is hereby granted, provided that the above
-## copyright notice and this permission notice appear in all copies.
-##
-## THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
-## WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-## MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR
-## ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-## WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-## ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
-## OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-##
-
-ISC Cron - January 2004
-[V4.0 was November, 2000]
-[V4.0b1 was September 7, 1997]
-[V3.1 was some time after 1993]
-[V3.0 was December 27, 1993]
-[V2.2 was some time in 1992]
-[V2.1 was May 29, 1991]
-[V2.0 was July 5, 1990]
-[V2.0-beta was December 9, 1988]
-[V1.0 was May 6, 1987]
-ftp://ftp.isc.org/isc/cron/
-
-This is a version of 'cron' that is known to run on most systems.  It
-is functionally based on the SysV cron, which means that each user can have
-their own crontab file (all crontab files are stored in a read-protected
-directory, usually /var/cron/tabs).  No direct support is provided for
-'at'; you can continue to run 'atrun' from the crontab as you have been
-doing.  If you don't have atrun (i.e., System V) you are in trouble.
-
-A messages is logged each time a command is executed; also, the files
-"allow" and "deny" in /var/cron can be used to control access to the
-"crontab" command (which installs crontabs).  It hasn't been tested on
-SysV, although some effort has gone into making the port an easy one.
-
-To use this: Sorry, folks, there is no cutesy 'Configure' script.  You'll
-have to go edit a couple of files... So, here's the checklist:
-
-       Read all the FEATURES, INSTALL, and CONVERSION files
-       Edit config.h
-       Edit Makefile
-               (both of these files have instructions inside; note that
-                some things in config.h are definable in Makefile and are
-                therefore surrounded by #ifndef...#endif)
-       'make'
-       'su' and 'make install'
-               (you may have to install the man pages by hand)
-       kill your existing cron process
-               (actually you can run your existing cron if you want, but why?)
-       build new crontabs using /usr/lib/{crontab,crontab.local}
-               (either put them all in "root"'s crontab, or divide it up
-                and rip out all the 'su' commands, collapse the lengthy
-                lists into ranges with steps -- basically, this step is
-                as much work as you want to make it)
-       start up the new cron
-               (must be done as root)
-       watch it. test it with 'crontab -r' and watch the daemon track your
-               changes.
-       if you like it, change your /etc/{rc,rc.local} to use it instead of
-               the old one.
-
-$Id: README,v 1.6 2004/01/23 19:03:32 vixie Exp $
diff --git a/config.h.in b/config.h.in
new file mode 100644 (file)
index 0000000..4b0301c
--- /dev/null
@@ -0,0 +1,88 @@
+/* config.h.in.  Generated from configure.ac by autoheader.  */
+
+/* Define to 1 if you have the <inttypes.h> header file. */
+#undef HAVE_INTTYPES_H
+
+/* Define to 1 if you have the <memory.h> header file. */
+#undef HAVE_MEMORY_H
+
+/* Define to 1 if you have the <stdint.h> header file. */
+#undef HAVE_STDINT_H
+
+/* Define to 1 if you have the <stdlib.h> header file. */
+#undef HAVE_STDLIB_H
+
+/* Define to 1 if you have the <strings.h> header file. */
+#undef HAVE_STRINGS_H
+
+/* Define to 1 if you have the <string.h> header file. */
+#undef HAVE_STRING_H
+
+/* Define to 1 if you have the <sys/stat.h> header file. */
+#undef HAVE_SYS_STAT_H
+
+/* Define to 1 if you have the <sys/types.h> header file. */
+#undef HAVE_SYS_TYPES_H
+
+/* Define to 1 if you have the <unistd.h> header file. */
+#undef HAVE_UNISTD_H
+
+/* Name of package */
+#undef PACKAGE
+
+/* Define to the address where bug reports for this package should be sent. */
+#undef PACKAGE_BUGREPORT
+
+/* Define to the full name of this package. */
+#undef PACKAGE_NAME
+
+/* Define to the full name and version of this package. */
+#undef PACKAGE_STRING
+
+/* Define to the one symbol short name of this package. */
+#undef PACKAGE_TARNAME
+
+/* Define to the version of this package. */
+#undef PACKAGE_VERSION
+
+/* Define as the return type of signal handlers (`int' or `void'). */
+#undef RETSIGTYPE
+
+/* Define to 1 if you have the ANSI C header files. */
+#undef STDC_HEADERS
+
+/* Define to 1 if your <sys/time.h> declares `struct tm'. */
+#undef TM_IN_SYS_TIME
+
+/* Version number of package */
+#undef VERSION
+
+/* Use when section with_audit */
+#undef WITH_AUDIT
+
+/* Use when section with_pam */
+#undef WITH_PAM
+
+/* Use when section with_selinux */
+#undef WITH_SELINUX
+
+/* Define to empty if `const' does not conform to ANSI C. */
+#undef const
+
+/* Define to `int' if <sys/types.h> doesn't define. */
+#undef gid_t
+
+/* Define to `int' if <sys/types.h> does not define. */
+#undef mode_t
+
+/* Define to `long' if <sys/types.h> does not define. */
+#undef off_t
+
+/* Define to `int' if <sys/types.h> does not define. */
+#undef pid_t
+
+/* Define to `unsigned' if <sys/types.h> does not define. */
+#undef size_t
+
+/* Define to `int' if <sys/types.h> doesn't define. */
+#undef uid_t
diff --git a/configure.ac b/configure.ac
new file mode 100644 (file)
index 0000000..22d2849
--- /dev/null
@@ -0,0 +1,242 @@
+AC_INIT([vixie-cron],[4.2],[mmaslano@redhat.com])
+AC_PREFIX_DEFAULT(/usr)
+AC_CONFIG_HEADER([config.h])
+AC_PREREQ(2.7)
+
+VERSION="4.2"
+if test "X$CFLAGS" = "X"; then
+CFLAGS="-O2 -g -Wall -Wno-unused -Wno-comment"
+LDFLAGS="-pie"
+fi
+
+AM_INIT_AUTOMAKE(foreign)
+
+AC_SUBST(VERSION)
+
+AC_CANONICAL_HOST
+
+dnl Checks for programs.
+
+AC_PROG_CC
+AC_PROG_INSTALL
+AC_PROG_LN_S
+
+AC_MSG_CHECKING(HP-UX -Aa)
+
+case "$host" in
+  *-*-hpux*)
+    if test -z "$GCC"; then
+      CFLAGS="$CFLAGS -Aa -D_HPUX_SOURCE"
+    fi
+    AC_MSG_RESULT(yes)
+    ;;
+  *)
+    AC_MSG_RESULT(no)
+    ;;
+esac
+AC_MSG_CHECKING(Trying to compile a trivial ANSI C program)
+AC_TRY_RUN([ main(int ac, char **av) { return 0; } ],
+    AC_MSG_RESULT(yes),
+    AC_MSG_RESULT(no)
+    AC_MSG_ERROR(Could not compile and run even a trivial ANSI C program - check CC.),
+    AC_MSG_ERROR(Could not compile and run even a trivial ANSI C program - check CC.))
+
+AC_CHECK_HEADERS( \
+        dirent.h \
+        fcntl.h \
+        getopt.h \
+        glob.h \
+        limits.h \
+        pam/pam_appl.h \
+        paths.h \
+        pty.h \
+        security/pam_appl.h \
+        stddef.h \
+        stdint.h \
+               sys/audit.h \
+        sys/stat.h \
+        sys/stream.h \
+        sys/stropts.h \
+               sys/time.h \
+        sys/timers.h \
+        sys/types.h \
+        time.h \
+        unistd.h \
+        util.h \
+        utime.h \
+)
+
+dnl Checks for typedefs, structures, and compiler characteristics.
+AC_C_CONST
+AC_TYPE_SIGNAL
+AC_TYPE_UID_T
+AC_TYPE_MODE_T
+AC_TYPE_OFF_T
+AC_TYPE_PID_T
+AC_TYPE_SIZE_T
+AC_STRUCT_TM
+
+
+dnl Checking for programs
+
+AC_MSG_CHECKING(etcdir)
+AC_ARG_WITH(etcdir,
+[  --with-etcdir=PATH      Directory containing permission files (default /etc).],
+[ case "$withval" in
+  no)
+    AC_MSG_ERROR(Need ETCDIR.)
+    ;;
+  yes)
+    ETCDIR=/etc
+    AC_MSG_RESULT(/etc)
+    ;;
+  *)
+    ETCDIR="$withval"
+    AC_MSG_RESULT($withval)
+    ;;
+  esac ],
+  ETCDIR="/etc"
+  AC_MSG_RESULT(/etc)
+)
+AC_SUBST(ETCDIR)
+
+AC_MSG_CHECKING(username to run under)
+AC_ARG_WITH(daemon_username,
+[ --with-daemon_username=DAEMON_USERNAME       Username to run under (default daemon) ],
+[ case "$withval" in
+  no)
+    AC_MSG_ERROR(Need DAEMON_USERNAME.)
+    ;;
+  yes)
+    DAEMON_USERNAME=daemon
+    AC_MSG_RESULT(daemon)
+    ;;
+  *)
+    DAEMON_USERNAME="$withval";
+    AC_MSG_RESULT($withval)
+    ;;
+    esac ],
+    DAEMON_USERNAME=daemon
+    AC_MSG_RESULT(daemon)
+)
+AC_SUBST(DAEMON_USERNAME)
+
+AC_MSG_CHECKING(groupname to run under)
+AC_ARG_WITH(daemon_groupname,
+[ --with-daemon_groupname=DAEMON_GROUPNAME     Groupname to run under (default daemon) ],
+[ case "$withval" in
+  no)
+    AC_MSG_ERROR(Need DAEMON_GROUPNAME.)
+    ;;
+  yes)
+    DAEMON_GROUPNAME=daemon
+    AC_MSG_RESULT(daemon)
+    ;;
+  *)
+    DAEMON_GROUPNAME="$withval";
+    AC_MSG_RESULT($withval)
+    ;;
+    esac ],
+    DAEMON_GROUPNAME=daemon
+    AC_MSG_RESULT(daemon)
+)
+AC_SUBST(DAEMON_GROUPNAME)
+
+# Check whether user wants SELinux support
+WITH_SELINUX_LIB=
+with_selinuxval=no
+case "$target" in
+    *-*-linux*) with_selinuxval=yes ;;
+    esac
+    withval=${with_selinuxval}
+    AC_ARG_WITH(selinux, [  --with-selinux          build with selinux support ])
+    if test $withval != no ; then
+       AC_DEFINE(WITH_SELINUX, 1, [Build with selinux support?])
+       WITH_SELINUX_LIB="-lselinux"
+    fi
+AC_SUBST(WITH_SELINUX_LIB)
+        
+# Check whether user wants PAM support
+AC_ARG_WITH(pam,
+        [  --with-pam              Enable PAM support ],
+        [  if test "x$withval" != "xno" ; then
+                        if test "x$ac_cv_header_security_pam_appl_h" != "xyes" && \
+                           test "x$ac_cv_header_pam_pam_appl_h" != "xyes" ; then
+                                AC_MSG_ERROR([PAM headers not found])
+                        fi
+
+                        saved_LIBS="$LIBS"
+                        AC_CHECK_LIB(dl, dlopen, , )
+                        AC_CHECK_LIB(pam, pam_set_item, , AC_MSG_ERROR([*** libpam missing]))
+                        AC_CHECK_FUNCS(pam_getenvlist)
+                        AC_CHECK_FUNCS(pam_putenv)
+                        LIBS="$saved_LIBS"
+
+                        PAM_MSG="yes"
+
+                        LIBPAM="-lpam -lpam_misc"
+                       AC_DEFINE(WITH_PAM,1,
+                               [Define if you want to enable PAM support])
+                        if test $ac_cv_lib_dl_dlopen = yes; then
+                                case "$LIBS" in
+                                *-ldl*)
+                                        # libdl already in LIBS
+                                        ;;
+                                *)
+                                        LIBPAM="$LIBPAM -ldl"
+                                        ;;
+                                esac
+                        fi
+                        AC_SUBST(LIBPAM)
+                fi
+        ]
+)
+
+AC_DEFINE(DEBUGGING,1,[Code will be built with debug info.])
+
+AC_DEFINE(MAILFMT,"MAILARG -FCronDaemon -i -odi -oem -oi -t",
+[-i    = don't terminate on "." by itself
+-Fx   = Set full-name of sender
+-odi  = Option Deliverymode Interactive
+-oem  = Option Errors Mailedtosender
+-oi   = Ignore "." alone on a line
+-t    = Get recipient from headers
+-d = undocumented but common flag.])
+
+AC_DEFINE(MAILARG,/usr/lib/sendmail,[There will be path to sendmail.])
+
+AC_DEFINE(MAIL_DATE,0,[Date is set by sendmail.])
+
+AC_DEFINE(SYSLOG,1,[Using syslog for log messages.])
+
+AC_DEFINE(CAPITALIZE_FOR_PS,0,[if you have a tm_gmtoff member in struct tm])
+
+AC_DEFINE(HAVE_TM_GMTOFF,0,[if your OS supports a BSD-style login.conf fil])
+
+##AC_DEFINE(LOGIN_CAP,0,[if your OS supports BSD authentication])
+
+AC_DEFINE(CRON_GROUP,0,[crontab])
+
+# Check whether user wants Linux audit support
+AC_DEFINE(WITH_AUDIT,1,[Define if you want audit trails])
+
+AC_ARG_ENABLE(debug,
+    [  --enable-debug    Turn on debugging],
+    [case "${enableval}" in
+    yes) debug=true ;;
+    no)  debug=false ;;
+    *) AC_MSG_ERROR(bad value ${enableval} for --enable-debug) ;;
+    esac],[debug=false])
+AM_CONDITIONAL(DEBUG, test x$debug = xtrue)
+
+pamdir=${sysconfdir}/pam.d
+AC_SUBST(pamdir)
+
+docdir=${datadir}/doc/cron/
+AC_SUBST(docdir)
+
+AC_CONFIG_FILES(Makefile src/Makefile man/Makefile doc/Makefile\
+       man/bitstring.3 man/cron.8 man/crontab.1 man/crontab.5)
+AC_CONFIG_SUBDIRS([src])
+AC_OUTPUT
+
diff --git a/crond.sysconfig b/crond.sysconfig
new file mode 100644 (file)
index 0000000..9e5819d
--- /dev/null
@@ -0,0 +1,9 @@
+# Settings for the CRON daemon.
+# CRONDARGS= :  any extra command-line startup arguments for crond
+# CRON_VALIDATE_MAILRCPTS=1:a non-empty value of this variable will
+#                           enable vixie-cron-4.1's validation of 
+#                           mail recipient names, which would then be
+#                           restricted to contain only the chars
+#                           from this tr(1) set : [@!:%-_.,:alnum:]
+#                           otherwise mailing is not attempted.
+CRONDARGS=
similarity index 100%
rename from CHANGES
rename to doc/CHANGES
similarity index 100%
rename from CONVERSION
rename to doc/CONVERSION
similarity index 100%
rename from FEATURES
rename to doc/FEATURES
diff --git a/doc/INSTALL b/doc/INSTALL
new file mode 100644 (file)
index 0000000..e92adba
--- /dev/null
@@ -0,0 +1,91 @@
+/* Copyright 1993,1994 by Paul Vixie
+ * All rights reserved
+ */
+
+/*
+ * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
+ * Copyright (c) 1997,2000 by Internet Software Consortium, Inc.
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
+ * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+$Id: INSTALL,v 1.4 2004/01/23 18:56:42 vixie Exp $
+
+Read the comments at the top of the Makefile, then edit the area marked
+'configurable stuff'.
+
+Edit config.h.  The stuff I expect you to change is down a bit from the
+top of the file, but it's clearly marked.  Also look at pathnames.h.
+
+You don't have to create the /var/cron or /var/cron/tabs directories, since
+both the daemon and the `crontab' program will do this the first time they
+run if they don't exist.  You do need to have a /var, though -- just "mkdir
+/var" if you don't have one, or you can "mkdir /usr/var; ln -s /usr/var /var"
+if you expect your /var to have a lot of stuff in it.
+
+You will also need /usr/local/etc and /usr/local/bin directories unless you
+change the Makefile.  These will have to be created by hand, but if you are
+a long-time Usenet user you probably have them already.  /usr/local/man is
+where I keep my man pages, but I have the source for `man' and you probably
+do not.  Therefore you may have to put the man pages into /usr/man/manl,
+which will be hard since there will be name collisions.  (Note that the man
+command was originally written by Bill Joy before he left Berkeley, and it
+contains no AT&T code, so it is in UUNET's archive of freely-distributable
+BSD code.)
+
+LINUX note: /usr/include/paths.h on some linux systems shows _PATH_SENDMAIL
+       to be /usr/bin/sendmail even though sendmail is installed in /usr/lib.
+       you should check this out.
+
+say:
+       make all
+
+su and say:
+       make install
+
+Note that if I can get you to "su and say" something just by asking, you have
+a very serious security problem on your system and you should look into it.
+
+Edit your /usr/lib/crontab file into little pieces -- see the CONVERSION file
+for help on this.
+
+Use the `crontab' command to install all the little pieces you just created.
+Some examples (see below before trying any of these!)
+
+       crontab -u uucp -r /usr/lib/uucp/crontab.src
+       crontab -u news -r /usr/lib/news/crontab.src
+       crontab -u root -r /usr/adm/crontab.src
+
+Notes on above examples: (1) the .src files are copied at the time the
+command is issued; changing the source files later will have no effect until
+they are reinstalled with another `crontab -r' command.  (2) The crontab
+command will affect the crontab of the person using the command unless `-u
+USER' is given; `-u' only works for root.  When using most `su' commands
+under most BSD's, `crontab' will still think of you as yourself even though
+you may think of yourself as root -- so use `-u' liberally.  (3) the `-r'
+option stands for `replace'; check the man page for crontab(1) for other
+possibilities.
+
+Kill your existing cron daemon -- do `ps aux' and look for /etc/cron.
+
+Edit your /etc/rc or /etc/rc.local, looking for the line that starts up
+/etc/cron.  Comment it out and add a line to start the new cron daemon
+-- usually /usr/local/etc/cron, unless you changed it in the Makefile.
+
+Start up this cron daemon yourself as root.  Just type /usr/local/etc/cron
+(or whatever); no '&' is needed since the daemon forks itself and the
+process you executed returns immediately.
+
+ATT notes: for those people unfortunate enough to be stuck on a AT&T UNIX,
+you will need the public-domain "libndir", found in the B News source and in
+any comp.sources.unix archive.  You will also need to hack the code some.
diff --git a/MAIL b/doc/MAIL
similarity index 100%
rename from MAIL
rename to doc/MAIL
diff --git a/doc/Makefile.am b/doc/Makefile.am
new file mode 100644 (file)
index 0000000..8b0853b
--- /dev/null
@@ -0,0 +1,2 @@
+doc_DATA = CHANGES  CONVERSION  FEATURES  INSTALL  MAIL  README  THANKS
+
diff --git a/doc/README b/doc/README
new file mode 100644 (file)
index 0000000..fcc64c9
--- /dev/null
@@ -0,0 +1,72 @@
+#/* Copyright 1988,1990,1993 by Paul Vixie
+# * All rights reserved
+# */
+
+##
+## Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
+## Copyright (c) 1997,2000 by Internet Software Consortium, Inc.
+##
+## Permission to use, copy, modify, and distribute this software for any
+## purpose with or without fee is hereby granted, provided that the above
+## copyright notice and this permission notice appear in all copies.
+##
+## THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
+## WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+## MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR
+## ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+## WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+## ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
+## OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+##
+
+ISC Cron - January 2004
+[V4.0 was November, 2000]
+[V4.0b1 was September 7, 1997]
+[V3.1 was some time after 1993]
+[V3.0 was December 27, 1993]
+[V2.2 was some time in 1992]
+[V2.1 was May 29, 1991]
+[V2.0 was July 5, 1990]
+[V2.0-beta was December 9, 1988]
+[V1.0 was May 6, 1987]
+ftp://ftp.isc.org/isc/cron/
+
+This is a version of 'cron' that is known to run on most systems.  It
+is functionally based on the SysV cron, which means that each user can have
+their own crontab file (all crontab files are stored in a read-protected
+directory, usually /var/cron/tabs).  No direct support is provided for
+'at'; you can continue to run 'atrun' from the crontab as you have been
+doing.  If you don't have atrun (i.e., System V) you are in trouble.
+
+A messages is logged each time a command is executed; also, the files
+"allow" and "deny" in /var/cron can be used to control access to the
+"crontab" command (which installs crontabs).  It hasn't been tested on
+SysV, although some effort has gone into making the port an easy one.
+
+To use this: Sorry, folks, there is no cutesy 'Configure' script.  You'll
+have to go edit a couple of files... So, here's the checklist:
+
+       Read all the FEATURES, INSTALL, and CONVERSION files
+       Edit config.h
+       Edit Makefile
+               (both of these files have instructions inside; note that
+                some things in config.h are definable in Makefile and are
+                therefore surrounded by #ifndef...#endif)
+       'make'
+       'su' and 'make install'
+               (you may have to install the man pages by hand)
+       kill your existing cron process
+               (actually you can run your existing cron if you want, but why?)
+       build new crontabs using /usr/lib/{crontab,crontab.local}
+               (either put them all in "root"'s crontab, or divide it up
+                and rip out all the 'su' commands, collapse the lengthy
+                lists into ranges with steps -- basically, this step is
+                as much work as you want to make it)
+       start up the new cron
+               (must be done as root)
+       watch it. test it with 'crontab -r' and watch the daemon track your
+               changes.
+       if you like it, change your /etc/{rc,rc.local} to use it instead of
+               the old one.
+
+$Id: README,v 1.6 2004/01/23 19:03:32 vixie Exp $
similarity index 100%
rename from THANKS
rename to doc/THANKS
diff --git a/man/Makefile.am b/man/Makefile.am
new file mode 100644 (file)
index 0000000..fb4c533
--- /dev/null
@@ -0,0 +1,16 @@
+man1_MANS = crontab.1
+man5_MANS = crontab.5
+man8_MANS = cron.8 crond.8
+
+crontab.1: crontab.1.in
+       cp -f crontab.1.in crontab.1
+
+crontab.5: crontab.5.in
+       cp -f crontab.5.in crontab.5
+
+cron.8: cron.8.in
+       cp -f cron.8.in cron.8
+
+crond.8: crond.8.in
+       cp -f crond.8.in crond.8
+
similarity index 100%
rename from bitstring.3
rename to man/bitstring.3.in
similarity index 100%
rename from cron.8
rename to man/cron.8.in
similarity index 100%
rename from crontab.1
rename to man/crontab.1.in
similarity index 100%
rename from crontab.5
rename to man/crontab.5.in
diff --git a/putman.sh b/putman.sh
deleted file mode 100644 (file)
index 67468e5..0000000
--- a/putman.sh
+++ /dev/null
@@ -1,23 +0,0 @@
-#!/bin/sh
-
-# putman.sh - install a man page according to local custom
-# vixie 27dec93 [original]
-#
-# $Id: putman.sh,v 1.1.1.1 1996/12/16 19:39:48 halley Exp $
-
-PAGE=$1
-DIR=$2
-
-SECT=`expr $PAGE : '[a-z]*.\([0-9]\)'`
-
-[ -d $DIR/man$SECT ] && {
-       set -x
-       cp $PAGE $DIR/man$SECT/$PAGE
-       set +x
-} || {
-       set -x
-       nroff -man $PAGE >$DIR/cat$SECT/`basename $PAGE .$SECT`.0
-       set +x
-}
-
-exit 0
diff --git a/src/Makefile.am b/src/Makefile.am
new file mode 100644 (file)
index 0000000..dddde57
--- /dev/null
@@ -0,0 +1,29 @@
+# Makefile.am - two binaries crond and crontab
+
+sbin_PROGRAMS = crond
+bin_PROGRAMS = crontab
+
+pam_DATA = ../crond.pam
+
+crond_SOURCES = \
+       cron.c database.c user.c entry.c job.c do_command.c \
+       misc.c env.c popen.c pw_dup.c security.c
+
+crontab_SOURCES = \
+       crontab.c misc.c entry.c env.c pw_dup.c security.c
+
+crontab_LDADD = \
+       -lselinux -lpam -lpam_misc
+
+crond_LDADD = \
+       -lselinux -lpam -lpam_misc
+
+crond_LDFLAGS = \
+       -fpie
+
+if DEBUG
+DBG = debug
+else
+DBG =
+endif
+noinst_PROGRAMS = $(DBG)
similarity index 100%
rename from bitstring.h
rename to src/bitstring.h
similarity index 100%
rename from config.h
rename to src/config.h
similarity index 100%
rename from cron.c
rename to src/cron.c
similarity index 100%
rename from cron.h
rename to src/cron.h
similarity index 100%
rename from crontab.c
rename to src/crontab.c
similarity index 100%
rename from database.c
rename to src/database.c
similarity index 100%
rename from do_command.c
rename to src/do_command.c
similarity index 100%
rename from entry.c
rename to src/entry.c
diff --git a/env.c b/src/env.c
similarity index 100%
rename from env.c
rename to src/env.c
similarity index 100%
rename from externs.h
rename to src/externs.h
similarity index 100%
rename from funcs.h
rename to src/funcs.h
similarity index 100%
rename from globals.h
rename to src/globals.h
diff --git a/job.c b/src/job.c
similarity index 100%
rename from job.c
rename to src/job.c
similarity index 100%
rename from macros.h
rename to src/macros.h
similarity index 100%
rename from misc.c
rename to src/misc.c
similarity index 100%
rename from pathnames.h
rename to src/pathnames.h
similarity index 100%
rename from popen.c
rename to src/popen.c
similarity index 100%
rename from pw_dup.c
rename to src/pw_dup.c
similarity index 100%
rename from security.c
rename to src/security.c
similarity index 100%
rename from structs.h
rename to src/structs.h
similarity index 100%
rename from user.c
rename to src/user.c
diff --git a/stamp-h1 b/stamp-h1
new file mode 100644 (file)
index 0000000..4547fe1
--- /dev/null
+++ b/stamp-h1
@@ -0,0 +1 @@
+timestamp for config.h
diff --git a/vixie-cron.init b/vixie-cron.init
new file mode 100755 (executable)
index 0000000..a204d36
--- /dev/null
@@ -0,0 +1,96 @@
+#! /bin/bash
+#
+# crond          Start/Stop the cron clock daemon.
+#
+# chkconfig: 2345 90 60
+# description: cron is a standard UNIX program that runs user-specified \
+#              programs at periodic scheduled times. vixie cron adds a \
+#              number of features to the basic UNIX cron, including better \
+#              security and more powerful configuration options.
+# processname: crond
+# config: /etc/crontab
+# pidfile: /var/run/crond.pid
+
+RETVAL=0
+prog="crond"
+CROND=/usr/sbin/crond
+LOCK_FILE=/var/lock/subsys/crond
+
+# Source function library.
+. /etc/init.d/functions
+
+# set sysconfig settings
+[ -f /etc/sysconfig/crond ] && . /etc/sysconfig/crond
+
+[ -f /etc/sysconfig/crond ] || exit 6
+
+# validate mail
+t=${CRON_VALIDATE_MAILRCPTS:-UNSET}
+[ "$t" != "UNSET" ] && export CRON_VALIDATE_MAILRCPTS="$t"
+prog="crond"
+
+start() {
+       echo -n $"Starting $prog: "
+       daemon $prog $OPTIONS && success || failure
+       RETVAL=$?
+       [ "$RETVAL" = 0 ] && touch $LOCK_FILE
+       echo
+}
+
+stop() {
+       echo -n $"Stopping $prog: "
+       if [ -n "`pidfileofproc $CROND`" ]; then
+               killproc $CROND
+               RETVAL=3
+       else
+               failure $"Stopping $prog"
+       fi
+       RETVAL=$?
+       [ "$RETVAL" = 0 ] && rm -f $LOCK_FILE
+       echo
+}      
+
+reload() {
+       echo -n $"Reloading $prog: "
+       if [ -n "`pidfileofproc $CROND`" ]; then
+               killproc $CROND -HUP
+       else
+               failure $"Reloading $prog"
+       fi
+       RETVAL=$?
+       echo
+}      
+
+case "$1" in
+  start)
+       start
+       ;;
+  stop)
+       stop
+       ;;
+  restart)
+       stop
+       start
+       ;;
+  reload)
+       reload
+       ;;
+  status)
+       status $CROND
+       ;;
+  condrestart)
+    if [ -f  $LOCK_FILE ]; then
+        if [ "$RETVAL" = 0 ]; then
+            stop
+            sleep 3
+            start
+        fi
+    fi
+    ;;
+  *)
+       echo $"Usage: $0 {start|stop|status|reload|restart|condrestart}"
+       RETVAL=3
+esac
+exit $RETVAL
+