diff --git a/configure.ac b/configure.ac index e3d89eac47..5a9a4447f3 100644 --- a/configure.ac +++ b/configure.ac @@ -320,19 +320,6 @@ dnl replacing lstat with statlstat on sco makes it more portable between dnl sco clones AC_CHECK_FUNCS(statlstat) -dnl Overriding mmap support. This has to be before AC_FUNC_MMAP is used. -dnl We use only part of the functionality of mmap, so on AIX, -dnl it's possible to use mmap, even if it doesn't pass the autoconf test. -AC_ARG_WITH([mmap], - AS_HELP_STRING([--with-mmap], [Use the mmap call @<:@yes if found@:>@])) -if test x$with_mmap != xno; then - if test x$with_mmap = x; then - AC_FUNC_MMAP - else - AC_DEFINE(HAVE_MMAP, 1) - fi -fi - mc_GET_FS_INFO diff --git a/doc/INSTALL b/doc/INSTALL index 7e248df705..32b72f0e7a 100644 --- a/doc/INSTALL +++ b/doc/INSTALL @@ -1,13 +1,5 @@ -This file contains: - -- Build requirements for GNU Midnight Commander -- Installation instructions for GNU Midnight Commander -- Where to get more information on GNU Midnight Commander -- Notes about GNU Midnight Commander installation -- Obtaining related software - Build requirements for GNU Midnight Commander ----------------------------------------------------- +--------------------------------------------- - glibc - gcc @@ -26,6 +18,17 @@ Build requirements for GNU Midnight Commander Installation instructions for GNU Midnight Commander ---------------------------------------------------- +Midnight Commander is written in a portable manner and uses GNU Autoconf +for configuration, so it is expected to compile without changes on many +other operating systems. + +If you are installing from an official tarball, it already contains +pre-bootstrapped autotools build system (specifically the `configure' +script). In the case that you are installing from a version control +checkout, you need to bootstrap the build system yourself first using +the `autogen.sh' script. Note that to do this you would need to install +the autotools suite first and not only direct mc build dependencies. + The `configure' shell script attempts to guess correct values for various system-dependent variables used during compilation, and creates the makefiles. It also creates a file `config.status' that you can run @@ -36,14 +39,7 @@ To compile this package: 1. Configure the package for your system. Normally, you just `cd' to the directory containing the package's source -code and type `./configure'. If you're using `csh' on an old version of -SystemV, you might need to type `sh configure' instead to prevent `csh' -from trying to execute `configure' itself. Under AIX, you may need to -use ksh instead of sh. - -Running `configure' takes a while. While it is running, it prints some -messages that tell what it is doing. If you don't want to see any -messages, run `configure' with the `--quiet' option. +code and type `./configure'. To compile the package in a different directory than the one containing the source code, you must use a version of `make' supporting the `VPATH' @@ -58,13 +54,6 @@ By default, `make install' will install the package's files in installation prefix other than `/usr/local' by giving `configure' the option `--prefix=PATH'. -You can specify separate installation prefixes for architecture specific -files and architecture-independent files. If you give `configure' the -option `--exec-prefix=PATH', the package will use PATH as the prefix for -installing binary programs and libraries. Data files and documentation -will still use the regular prefix. Normally, all files are installed -using the same prefix. - If compiled on GNU/Linux, Midnight Commander detects if you have the gpm library installed. If you installed the gpm mouse library in a non-standard place, you will need to use the --with-gpm-mouse flag with @@ -103,12 +92,6 @@ incomplete, use `configure --help' to get the full list): building binaries for distribution purposes and may not work on some operating systems. -`--with-mmap', `--without-mmap' - Force using or not using the mmap function. It is currently used - in the internal viewer. `--with-mmap' may be useful on some - versions of AIX where the `configure' script decides that mmap is - broken, but it's actually suitable for the internal viewer. - `--with-subshell[=optional]', `--without-subshell' The subshell support is by default turned on, you can disable this by using the --without-subshell option. If you pass the @@ -220,9 +203,6 @@ ncurses): Set path to ncurses library [default=/usr/lib]; make sense only if --with-screen=ncurses is used. -Compiler options: -- - - - - - - - - - On systems that require unusual options for compilation or linking that the package's `configure' script does not know about, you can give `configure' initial values for variables by placing them in the command @@ -230,131 +210,16 @@ line: ./configure CC='gcc -traditional' LIBS=-lposix -Here are the variables that you might want to override when running -`configure'. - - - Variable: CC - C compiler program. The default is `gcc' if found, otherwise `cc'. - - - Variable: CFLAGS - The default flags used to build the program. - - - Variable: INSTALL - Program to use to install files. The default is `install' if you - have it, `cp' otherwise. - -For these variables, any value given in the command line is added to the -value that `configure' decides to use: - - - Variable: LIBS - Libraries to link with, in the form `-lfoo -lbar...'. - - - Variable: LDFLAGS - Linker flags, e.g. -L if you have libraries in a - nonstandard directory - - - Variable: CPPFLAGS - C/C++ preprocessor flags, e.g. -I if you have - headers in a nonstandard directory - -If you need to do unusual things to compile the package, we encourage -you to figure out how `configure' could check whether to do them, and -mail diffs or instructions to the address given in the README so we can -include them in the next release. - 2. Type `make' to compile the package. 3. Type `make install' to install programs, data files, and the -documentation. On GNU/Linux the console screen saver is installed as -well. - -4. You can remove the program binaries and object files from the source -directory by typing `make clean'. If you want to clean the source tree -completely, so that it contains only those files that should be packaged -in the archive, issue `make distclean'. If you've run configure in a -different directory than the source tree, distclean won't remove your -*.o and linked programs in that directory. - -5. GNU Midnight Commander allows you to stay in the last current -directory after exiting MC. This is done with a shell function, the man -page has more information about this. - -The file `configure.in' is used to create `configure' by a program -called `autoconf'. You only need it if you want to regenerate -`configure' using a newer version of `autoconf'. - +documentation. -Where to get more information on GNU Midnight Commander -------------------------------------------------------- - -There are two mailing lists for the program: - -mc@lists.midnight-commander.org: Discussion on GNU Midnight Commander file manager. -mc-devel@lists.midnight-commander.org: Discussion between the developers of the program. - -To subscribe to the mailing lists, visit their respective pages: - -https://lists.midnight-commander.org/mailman/listinfo/mc/ -https://lists.midnight-commander.org/mailman/listinfo/mc-devel/ - - -Notes about GNU Midnight Commander installation ------------------------------------------------ - -GNU Midnight Commander has been run in the following configurations: - -i386-*-linux -sparc-*-linux -alpha-*-linux -powerpc-*-linux -mips-dec-{open,net}bsd1.0 -mips-sgi-irix5.2 -mips-sgi-irix5.3 -powerpc-ibm-aix5.3.0.0 (IBM XL C, IBM XL C/C++) -sparc-sun-sunos4.1 -sparc-sun-netbsd1.0 -sparc-sun-solaris2.3 -hppa-hp-hpux9 -hppa-hp-hpux7 -m68k-apple-aux -mc88110-aviion-dgux5.4 -i386-*-bsdi2 -i386-*-freebsd4.3 -i386-*-openbsd2.9 - -Midnight Commander is written in a portable manner and uses GNU Autoconf -for configuration, so it is expected to compile without changes on many -other operating systems. - -You will need an ANSI C Compiler (such as GCC) and glib library to -compile the source. GNU Midnight Commander now comes with the S-Lang -screen manager, a fast screen manager, but you may want to use the -already installed S-Lang or ncurses library. - -If you insist on using ncurses, it's recommended to use ncurses 4.1 and -above, since the older versions don't support resizing in the xterm -window. - -GNU Midnight Commander comes with the mouse support on xterms and in the -Linux console. In order to take advantage of the mouse support on the -Linux console you will need the gpm mouse server (see the section -"Obtaining related software" in this file). - -Once you get gpm, compile it and install it, then you will have to -specify the `--with-gpm-mouse' flag to the configure program if you -installed it in a non-standard directory. If you installed the gpm -package under /usr or /usr/local, you don't need to specify this flag; -configure will find gpm for you. The support for mice on xterms is -always compiled in. - -We are working on further enhancements to the program, but we're not -sure which ones must go first. If you would like to point us in the -Right Direction we will be glad to hear from you. - -If you happen to find a feature that doesn't do what you expect, please -write to mc@lists.midnight-commander.org telling as much as you can -about the problem you're experiencing. Please don't send personal -messages to the maintainers. +If you're on a GNU/Linux system, this will install the `cons.saver' +utility, which allows the Midnight Commander to save and restore the +console contents. This utility can be installed setuid root, but it's +only needed on systems where users cannot access /dev/vcsaN, where N is +the virtual console number, on which the uses is logged on. Obtaining related software @@ -366,7 +231,7 @@ glib The only "hard" dependency of GNU Midnight Commander is glib. You can get glib from -ftp://ftp.gnome.org/pub/gnome/sources/glib/ +* https://download.gnome.org/sources/glib/ Minimal version of glib: 2.32.0 Recommended version: 2.32.x and higher. @@ -376,11 +241,9 @@ Newer versions may work, but haven't been tested. PCRE ---- -Both PCRE and PCRE2 libraries are supported. +Both PCRE and PCRE2 libraries are supported. You can get PCRE from -You can get PCRE from - -http://www.pcre.org/ +* https://www.pcre.org Terminal database ----------------- @@ -402,53 +265,32 @@ Screen libraries GNU Midnight Commander can use the included version of S-Lang, but you can get the latest version here: -http://www.s-lang.org/ +* https://www.jedsoft.org/slang/ Alternatively, you can use ncurses: -http://www.gnu.org/software/ncurses/ncurses.html +* https://invisible-island.net/ncurses/announce.html Mouse support ------------- The general purpose mouse (gpm) daemon is available from -http://unix.schottelius.org/gpm/ - -Compiler --------- - -If your C compiler is not powerful enough to compile GNU Midnight -Commander, you should report is as a bug to the GNU Midnight Commander -team. Sometimes there is no solution than upgrading to a modern and -free compiler - GCC (Compiler Collection): - -http://gcc.gnu.org/ - -AIX ---- -Currently you can not use gcc 4.2.4 (and probably other versions) on -AIX to compile the S-Lang version. Please use IBM XL C or IBM XL C/C++ -instead. - -If you compile a ncurses version you need to set TERM=dtterm to get -working color support. Furthermore it is important to specify the ---with-ncurses-includes/--with-ncurses-lib parameters because otherwise -mc will pick up term.h from AIX which does not work with the ncurses -library. +* https://www.nico.schottelius.org/software/gpm/ -The AIX S-Lang build was tested with S-Lang 2.0.7. Later versions may -also work but are not tested yet. +Porting +------- -Here is an example for S-Lang, it is assumed that the S-Lang library -is installed under /user/local and that you also want want to install -to /usr/local: +Some less widespread UNIX systems like AIX or Solaris often come with their own +implementations of make and relevant parts of the toolchain necessary to build +mc. While autotools abstract a lot of platform specific issues, you might +encounter unresolved problems while using the native toolchain. - export CC=cc_r - export CXX=xlC_r - export CONFIG_SHELL=/usr/bin/bash (if installed) - export SHELL=/usr/bin/bash (if installed) +Often, GNU tools are shipped as a part of an additional software collection +(/opt/freeware on AIX, or OpenCSW on Solaris). These tools are usually prefixed +with the letter `g', e.g. `gmake' instead of `make'. If you are not really +interested in building with the native toolchain, try to override tools causing +problems like this: - ./configure \ - --prefix=/usr/local \ - --with-screen=slang +./configure MAKE=gmake AR=gar +gmake diff --git a/doc/INSTALL.FAST b/doc/INSTALL.FAST deleted file mode 100644 index 77d97feea3..0000000000 --- a/doc/INSTALL.FAST +++ /dev/null @@ -1,51 +0,0 @@ -Read the INSTALL file for the complete instructions. - -GNU Midnight Commander requires glib2. - -GNU Midnight Commander uses the S-Lang screen library by default. It -tries the S-Lang library installed on the system. If it's not found, -the included S-Lang sources are used. It is also possible to use -ncurses as the screen library. - -1. Configure the package for your system. - -Normally, you just `cd' to the package main directory and type -`./configure'. - -The most often needed options to configure are following: - -`--prefix=PATH' - By default, `make install' will install the package's files - in `/usr/local/bin', `/usr/local/man', etc. or to `/usr/bin', - `/usr/man', etc. depending on the location of an old mc binary. - If you have none in your system, default will be `/usr/local'. - You can specify an installation prefix other than default by - giving `configure' the option `--prefix=PATH'. - -`--with-screen={slang|ncurses}' - Choose the library used to manage interaction with the terminal. - `slang' means S-Lang library already installed on the system, - `ncurses' means ncurses library already installed on the system. - The installed S-Lang library is used by default if found. - -You may also want to specify CFLAGS for the compiler, even if it finds -itself some defaults by typing e.g. - -./configure CFLAGS=-O3 - -2. Type `make' to compile the package. - -3. Type `make install' to install programs, data files, and -documentation. You may need to run this command as root. - -If you're on a GNU/Linux system, this will install the `cons.saver' -utility, which allows the Midnight Commander to save and restore the -screen contents. This utility can be installed setuid root, but it's -only needed on systems where users cannot access /dev/vcsaN, where N is -the virtual console number, on which the uses is logged on. - -If you're making a mc binary distribution for other people and want to -package the whole installed tree, use `make install DESTDIR=PATH', which -will make PATH the root for installation. - -4. Type `mc' and enjoy! diff --git a/doc/MAINTAINERS b/doc/MAINTAINERS deleted file mode 100644 index 1c2ab6692d..0000000000 --- a/doc/MAINTAINERS +++ /dev/null @@ -1 +0,0 @@ -Email: mc-devel@lists.midnight-commander.org diff --git a/doc/MIRRORS.txt b/doc/MIRRORS.txt deleted file mode 100644 index 751f834755..0000000000 --- a/doc/MIRRORS.txt +++ /dev/null @@ -1,10 +0,0 @@ -This is a list of sites known to mirror the Midnight Commander release. - ----------- - -The Midnight Commander distribution is placed at: - - * http://ftp.osuosl.org/pub/midnightcommander/ - * ftp://ftp.osuosl.org/pub/midnightcommander/ - ------------ diff --git a/doc/Makefile.am b/doc/Makefile.am index c192da1388..5cc4ae2231 100644 --- a/doc/Makefile.am +++ b/doc/Makefile.am @@ -1,7 +1,7 @@ DIST_SUBDIRS = hints man hlp SUBDIRS = hints man hlp -DOCS = FAQ HACKING INSTALL INSTALL.FAST MAINTAINERS README.QNX MIRRORS.txt +DOCS = FAQ HACKING INSTALL EXTRA_DIST = $(DX_CONFIG) doxygen-include.am $(DOCS) include doxygen-include.am diff --git a/doc/README b/doc/README index c2718ae4df..5b71024383 100644 --- a/doc/README +++ b/doc/README @@ -1,12 +1,12 @@ Contents -------- -Introduction -Dependencies -Features -Mini-documentation -Where to get more information -Reporting problems +* Introduction +* Dependencies +* Features +* Mini-documentation +* Where to get more information +* Reporting problems Introduction @@ -141,15 +141,19 @@ Where to get more information There is a webpage for GNU Midnight Commander at -https://www.midnight-commander.org/ +* https://www.midnight-commander.org This page also has current information about mailing lists and some useful advices how to report bugs. You can download the latest version of GNU Midnight Commander from -https://www.midnight-commander.org/downloads/ +* https://www.midnight-commander.org/downloads/ +The Midnight Commander distribution is placed at: + +* http://ftp.osuosl.org/pub/midnightcommander/ +* ftp://ftp.osuosl.org/pub/midnightcommander/ Reporting problems ------------------ @@ -168,8 +172,6 @@ There are two mailing lists: Use mc-devel@ if you are prepared for a more technical discussion with the developers of the package, otherwise use mc@. -Please don't sent HTML e-mail to either of those mailing lists. - Include the output of "mc --version", the operating system and the distribution (if applicable) you are using, the compiler and the configure flags used to compile the program (if you know them). diff --git a/doc/README.QNX b/doc/README.QNX deleted file mode 100644 index c4675d0925..0000000000 --- a/doc/README.QNX +++ /dev/null @@ -1,313 +0,0 @@ -Midnight Commander for QNX (not QNX Neutrino) ---------------------------------------------- - -1. Compiling -2. Running 'mc' under QNX -3. List of modifications on mc-4.1.33 -4. TODO -5. Contact information - -1. Compiling ------------- - -1.1 Make utility ----------------- - -Use 'gmake'. (This is the default 'make' under QNX 4.23+). [The old 'qmake' -cannot handle the makefiles in the mc-source.] - -1.2 Configuring ---------------- - -If you don't have an installed TCP/IP development kit, you have to 'hide' -the library file 'socket3r.lib' (can be installed by e.g. Watcom C 10.6) -in /usr/lib or /usr/watcom/10.6/usr/lib, because the existence of this file -will confuse 'configure': it will erroneously assume you have the complete -TCP/IP development kit (with headers) and will enable compiling of the -network-related VFS code (not only tarfs). -[A patch would be required in the configure-script to check the existence -of the TCP/IP-related headers also...] - -Use '--disable-nls' option, if you don't have the binary utilities of -GNU 'gettext' package (e.g. 'msgfmt'). ['--with-included-gettext' doesn't -really work in 4.1.33, there are configuration/compiling problems...] - -1.3 Compiler ------------- - -It is advised to use Watcom C 10.6+ to compile the source, because older -compilers (e.g. 9.52) do not support some convenient/required features. -[e.g. 'ar'-compatible 'wlib',...] - -1.4 "No prototype found for ''" warnings --------------------------------------------------- - -It is advised to use high warning level (e.g. 'CFLAGS="-w4" ./configure'), -when compiling the source, because Watcom C uses a special parameter passing -convention for functions with fixed number of arguments only. So if the -compiler doesn't see the correct prototype of a function with variable -number of arguments (like printf()), it will produce a warning about the -missing prototype, but generates function call code according to the special -parameter passing convention, not the required CDECL convention (it is used -by default for functions with variable number of arguments). So the calling -convention of the function call code and the function code itself will not -match! So you MUST provide the correct prototype for function with variable -number of arguments! (Or you can force using the stack-based calling -convention as a default, if you have the stack-call-conv version of all of the -required libraries ('3s.lib')...[Watcom C 10.6 required!]) - -[The latest release version (4.1.33/qnx) is checked against these types of -missing prototypes...] - -1.5 Tested configuration ------------------------- - -QNX 4.24 -Watcom C 10.6 (release version, no newer beta patches) -Photon 1.12 -no TCP/IP development kit (-> VFS: tarfs only!) -mc-4.1.33, mc-4.1.34 - -2. Running 'mc' under QNX -------------------------- - -Using 'qnx*' terminals: - - You cannot use your keyboard correctly, if you disable the "Full 8 bits - input" feature in the 'Options|Display bits...' dialog. - - On 'qnx*' terminals 'mc' will run in black and white mode by default, - because these types of terminals use non-ANSI-compatible color sequences. - -Accessing remote nodes via the native QNX-network: - - [The problem exists under the older versions of 'mc' only...] - If directory panels cannot handle '//' prefix in directory names, - use directory links in order to access remote nodes on the native QNX - network: - - mkdir /net - ln -sf //1/ /net/1 - ... - -Extension and menu files: - - Default 'tar' uses 'stderr' (and not 'stdout' as its 'normal' output with - '-t' option. - - Default 'tar' is not a GNU 'tar', so does not understand '-z' option. - -Special key-mappings: - - Restrictions of the META-? as Alt-? functionality: - [META-? as ESC-? will always work!!!] - - Alt-TAB -> Ctrl-TAB (Alt-TAB reserved in Photon [1.12+]) - Alt-ENTER -> Ctrl-ENTER ('qnx*' terminals only) - - Alt-: doesn't work - -'qansi*' terminals: - - Problem [QNX 4.23+ only]: screen corruption (strange line-drawing character - set handling) on 'qansi*' terminals, if linked with mc/Slang/terminfo - terminal management. (Older versions of QNX and Slang/termcap not affected.) - - This problem is solved, see the comments in slang/sldisply.c about - SLTT_TRANSP_ACS_PATCH and QNX_QANSI_SLANG_COMPAT_ACS! - -other terminals: - - I have tested 'mc' under QNX on 'qnx*' and 'qansi*' terminals only. - -toggle panels on/off (CTRL-o): - - Currently not supported, but could be implemented later... - -3. List of modifications on mc-4.1.33/mc-4.1.34 ------------------------------------------------ - -edit/ - - syntax.c: (4.1.33 only, fixed in 4.1.34) - - line 100,191: WCC 10.6 doesn't like "