| 1 | These are the GNU core utilities. This package is the union of
|
|---|
| 2 | the GNU fileutils, sh-utils, and textutils packages.
|
|---|
| 3 |
|
|---|
| 4 | Most of these programs have significant advantages over their Unix
|
|---|
| 5 | counterparts, such as greater speed, additional options, and fewer
|
|---|
| 6 | arbitrary limits.
|
|---|
| 7 |
|
|---|
| 8 | The programs that can be built with this package are:
|
|---|
| 9 |
|
|---|
| 10 | [ basename cat chgrp chmod chown chroot cksum comm cp csplit cut date dd
|
|---|
| 11 | df dir dircolors dirname du echo env expand expr factor false fmt fold
|
|---|
| 12 | ginstall groups head hostid hostname id join kill link ln logname ls
|
|---|
| 13 | md5sum mkdir mkfifo mknod mv nice nl nohup od paste pathchk pinky pr
|
|---|
| 14 | printenv printf ptx pwd readlink rm rmdir seq sha1sum shred sleep sort
|
|---|
| 15 | split stat stty su sum sync tac tail tee test touch tr true tsort tty
|
|---|
| 16 | uname unexpand uniq unlink uptime users vdir wc who whoami yes
|
|---|
| 17 |
|
|---|
| 18 | See the file NEWS for a list of major changes in the current release.
|
|---|
| 19 |
|
|---|
| 20 | See the file INSTALL for compilation and installation instructions.
|
|---|
| 21 |
|
|---|
| 22 | These programs are intended to conform to POSIX (with BSD and other
|
|---|
| 23 | extensions), like the rest of the GNU system. By default they conform
|
|---|
| 24 | to older POSIX (1003.2-1992), and therefore support obsolete usages
|
|---|
| 25 | like "head -10" and "chown owner.group file". This default is
|
|---|
| 26 | overridden at build-time by the value of <unistd.h>'s _POSIX2_VERSION
|
|---|
| 27 | macro, and this in turn can be overridden at runtime as described in
|
|---|
| 28 | the documentation under "Standards conformance".
|
|---|
| 29 |
|
|---|
| 30 | The ls, dir, and vdir commands are all separate executables instead of
|
|---|
| 31 | one program that checks argv[0] because people often rename these
|
|---|
| 32 | programs to things like gls, gnuls, l, etc. Renaming a program
|
|---|
| 33 | file shouldn't affect how it operates, so that people can get the
|
|---|
| 34 | behavior they want with whatever name they want.
|
|---|
| 35 |
|
|---|
| 36 | Special thanks to Paul Eggert, Brian Matthews, Bruce Evans, Karl Berry,
|
|---|
| 37 | Kaveh Ghazi, and François Pinard for help with debugging and porting
|
|---|
| 38 | these programs. Many thanks to all of the people who have taken the
|
|---|
| 39 | time to submit problem reports and fixes. All contributed changes are
|
|---|
| 40 | attributed in the ChangeLog files.
|
|---|
| 41 |
|
|---|
| 42 | And thanks to the following people who have provided accounts for
|
|---|
| 43 | portability testing on many different types of systems: Bob Proulx,
|
|---|
| 44 | Christian Robert, François Pinard, Greg McGary, Harlan Stenn,
|
|---|
| 45 | Joel N. Weber, Mark D. Roth, Matt Schalit, Nelson H. F. Beebe,
|
|---|
| 46 | Réjean Payette, Sam Tardieu.
|
|---|
| 47 |
|
|---|
| 48 | Thanks to Michael Stone for inflicting test releases of this package
|
|---|
| 49 | on Debian's unstable distribution, and to all the kind folks who used
|
|---|
| 50 | that distribution and found and reported bugs.
|
|---|
| 51 |
|
|---|
| 52 | Note that each man page is now automatically generated from a template
|
|---|
| 53 | and from the corresponding --help usage message. Patches to the template
|
|---|
| 54 | files (man/*.x) are welcome. However, the authoritative documentation
|
|---|
| 55 | is in texinfo form in the doc directory.
|
|---|
| 56 |
|
|---|
| 57 | If you run the tests on a SunOS4.1.4 system, expect the ctime-part of
|
|---|
| 58 | the ls `time-1' test to fail. I believe that is due to a bug in the
|
|---|
| 59 | way Sun implemented link(2) and chmod(2).
|
|---|
| 60 |
|
|---|
| 61 |
|
|---|
| 62 | ***********************
|
|---|
| 63 | HPUX 11.x build failure
|
|---|
| 64 | -----------------------
|
|---|
| 65 |
|
|---|
| 66 | A known problem exists when compiling on HPUX on both hppa and ia64
|
|---|
| 67 | in 64-bit mode (i.e. +DD64) on HP-UX 11.0, 11.11, and 11.23. This
|
|---|
| 68 | is not due to a bug in the package but instead due to a bug in the
|
|---|
| 69 | system header file which breaks things in 64-bit mode. The default
|
|---|
| 70 | compilation mode is 32-bit and the software compiles fine using the
|
|---|
| 71 | default mode. To build this software in 64-bit mode you will need
|
|---|
| 72 | to fix the system /usr/include/inttypes.h header file. After
|
|---|
| 73 | correcting that file the software also compiles fine in 64-bit mode.
|
|---|
| 74 | Here is one possible patch to correct the problem:
|
|---|
| 75 |
|
|---|
| 76 | --- /usr/include/inttypes.h.orig Thu May 30 01:00:00 1996
|
|---|
| 77 | +++ /usr/include/inttypes.h Sun Mar 23 00:20:36 2003
|
|---|
| 78 | @@ -489 +489 @@
|
|---|
| 79 | -#ifndef __STDC_32_MODE__
|
|---|
| 80 | +#ifndef __LP64__
|
|---|
| 81 |
|
|---|
| 82 |
|
|---|
| 83 | **********************
|
|---|
| 84 | Running tests as root:
|
|---|
| 85 | ----------------------
|
|---|
| 86 |
|
|---|
| 87 | If you run the tests as root, note that a few of them create files
|
|---|
| 88 | and/or run programs as a non-root user, `nobody' by default.
|
|---|
| 89 | If you want to use some other non-root username, specify it via
|
|---|
| 90 | the NON_ROOT_USERNAME environment variable. Depending on the
|
|---|
| 91 | permissions with which the working directories have been created,
|
|---|
| 92 | using `nobody' may fail, because that user won't have the required
|
|---|
| 93 | read and write access to the build and test directories.
|
|---|
| 94 | I find that it is best to unpack and build as a non-privileged
|
|---|
| 95 | user, and then to run the following command as that user in order
|
|---|
| 96 | to run the privilege-requiring tests:
|
|---|
| 97 |
|
|---|
| 98 | sudo env NON_ROOT_USERNAME=$USER make -k check
|
|---|
| 99 |
|
|---|
| 100 | If you can run the tests as root, please do so and report any
|
|---|
| 101 | problems. We get much less test coverage in that mode, and it's
|
|---|
| 102 | arguably more important that these tools work well when run by
|
|---|
| 103 | root than when run by less privileged users.
|
|---|
| 104 |
|
|---|
| 105 |
|
|---|
| 106 | ***************
|
|---|
| 107 | Reporting bugs:
|
|---|
| 108 | ---------------
|
|---|
| 109 |
|
|---|
| 110 | IMPORTANT: if you take the time to report a test failure,
|
|---|
| 111 | please be sure to include the output of running `make check'
|
|---|
| 112 | in verbose mode for each each failing test. For example,
|
|---|
| 113 | if the test that fails is tests/mv/hard-link-1, then you
|
|---|
| 114 | would run this command:
|
|---|
| 115 |
|
|---|
| 116 | env VERBOSE=yes make check -C tests/mv TESTS=hard-link-1 >> log 2>&1
|
|---|
| 117 |
|
|---|
| 118 | For some tests, you can get even more detail by including
|
|---|
| 119 | DEBUG=yes in the environment:
|
|---|
| 120 |
|
|---|
| 121 | env DEBUG=yes VERBOSE=yes make check -C tests/mv TESTS=hard-link-1 >> log 2>&1
|
|---|
| 122 |
|
|---|
| 123 | and then include the contents of the file `log' in your bug report.
|
|---|
| 124 |
|
|---|
| 125 | ***************************************
|
|---|
| 126 |
|
|---|
| 127 | There are pretty many tests, but nowhere near as many as we need.
|
|---|
| 128 | Additions and corrections are very welcome.
|
|---|
| 129 |
|
|---|
| 130 | If you see a problem that you've already reported, feel free to re-report
|
|---|
| 131 | it -- it won't bother me to get a reminder. Besides, the more messages I
|
|---|
| 132 | get regarding a particular problem the sooner it'll be fixed -- usually.
|
|---|
| 133 | If you sent a complete patch and, after a couple weeks you haven't
|
|---|
| 134 | received any acknowledgement, please ping us. A complete patch includes
|
|---|
| 135 | a well-written ChangeLog entry, unified (diff -u format) diffs relative
|
|---|
| 136 | to the most recent test release (or, better, relative to the latest
|
|---|
| 137 | sources in the CVS repository), an explanation for why the patch is
|
|---|
| 138 | necessary or useful, and if at all possible, enough information to
|
|---|
| 139 | reproduce whatever problem prompted it. Plus, you'll earn lots of
|
|---|
| 140 | karma if you include a test case to exercise any bug(s) you fix.
|
|---|
| 141 | Instructions for checking out the latest source via CVS are here:
|
|---|
| 142 |
|
|---|
| 143 | http://savannah.gnu.org/cvs/?group=coreutils
|
|---|
| 144 |
|
|---|
| 145 |
|
|---|
| 146 | If your patch adds a new feature, please try to get some sort of consensus
|
|---|
| 147 | that it is a worthwhile change. One way to do that is to send mail to
|
|---|
| 148 | [email protected] including as much description and justification
|
|---|
| 149 | as you can. Based on the feedback that generates, you may be able to
|
|---|
| 150 | convince us that it's worth adding.
|
|---|
| 151 |
|
|---|
| 152 |
|
|---|
| 153 | WARNING: If you modify files like configure.in, m4/*.m4, aclocal.m4,
|
|---|
| 154 | or any Makefile.am, then don't be surprised if what gets regenerated no
|
|---|
| 155 | longer works. To make things work, you'll have to be using appropriate
|
|---|
| 156 | versions of automake and autoconf. As for what versions are `appropriate',
|
|---|
| 157 | use the versions of
|
|---|
| 158 |
|
|---|
| 159 | * autoconf specified via AC_PREREQ in m4/jm-macros.m4
|
|---|
| 160 | * automake specified via AM_INIT_AUTOMAKE in configure.ac
|
|---|
| 161 |
|
|---|
| 162 | Usually it's fine to use versions that are newer than those specified.
|
|---|
| 163 |
|
|---|
| 164 | All of these programs except `test' recognize the `--version' option.
|
|---|
| 165 | When reporting bugs, please include in the subject line both the package
|
|---|
| 166 | name/version and the name of the program for which you found a problem.
|
|---|
| 167 |
|
|---|
| 168 | For general documentation on the coding and usage standards
|
|---|
| 169 | this distribution follows, see the GNU Coding Standards,
|
|---|
| 170 | http://www.gnu.org/prep/standards_toc.html.
|
|---|
| 171 |
|
|---|
| 172 | Mail suggestions and bug reports for these programs to
|
|---|
| 173 | the address on the last line of --help output.
|
|---|