1 This is a port of GNU Bison @VERSION@ to MSDOS/DJGPP. 2 3 Copyright (C) 2005-2012 Free Software Foundation, Inc. 4 5 This program is free software: you can redistribute it and/or modify 6 it under the terms of the GNU General Public License as published by 7 the Free Software Foundation, either version 3 of the License, or 8 (at your option) any later version. 9 10 This program is distributed in the hope that it will be useful, 11 but WITHOUT ANY WARRANTY; without even the implied warranty of 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 GNU General Public License for more details. 14 15 You should have received a copy of the GNU General Public License 16 along with this program. If not, see <http://www.gnu.org/licenses/>. 17 18 19 1.: DJGPP specific changes. 20 ======================= 21 22 The DJGPP port of Bison offers LFN and SFN support depending on which 23 OS it is running. If LFN support is available or not is determinated at 24 run time. If LFN support is available (DOS session under Win9X, Win2K, 25 WinXP, etc.) the standard posix file name extensions will be used. 26 These are: y.tab.c, y.tab.c++, y.tab.h, y.output, etc. If only SFN 27 support is available (plain DOS), then the standard MSDOS short file 28 names will be used. These are: y_tab.c, y_tab.h, y.out, etc. 29 It should be noticed that this bison version needs the m4 program as 30 back end to generate the parser file (y.tab.c etc.) from the skeleton 31 files. This implies that m4 must always be installed to get bison 32 working. m4 will use a couple of m4 scripts that will be installed in 33 /dev/env/DJDIR/share/bison and shall not be removed. 34 It should also be noticed that the skeleton files bison.simple and 35 bison.hairy are no longer supported. This applies also to the environ- 36 ment variables BISON_HAIRY and BISON_SIMPLE. Those variables are *no* 37 longer honored at all. 38 The kind of skeleton file bison.hairy is no longer supported at all. 39 The skeleton file bison.simple is now called yacc.c and is an m4 script. 40 The other two skeleton files supported by this bison version are glr.c 41 and lalr1.cc. The first one is a generalized LR C parser based on 42 Bison's LALR(1) tables and the second one is a experimental C++ parser 43 class. 44 As has been told before, bison uses m4 to generate the parser file. 45 This is done by forking and using pipes for the IPC. MSDOS does not 46 support this functionality so this has been reproduced in the usual 47 way by redirecting stdin and stdout of bison and m4 to temporary files 48 and processing these files in sequence. 49 It should be noticed that due to the great amount of file names that do 50 not cleanly map to 8.3 file names, you will need an OS with LFN support 51 to configure and compile the sources. On Win98 this implies that the 52 generation of numeric tails for 8.3 file name aliases must be enabled 53 or the compilation will fail. 54 55 56 Please **read** the docs. 57 58 59 2.: Installing the binary package. 60 ============================== 61 62 2.1.: Copy the binary distribution into the top DJGPP installation directory, 63 just unzip it preserving the directory structure running *ONE* of the 64 following commands: 65 unzip32 bsn@PACKAGE_VERSION (a] b.zip or 66 djtarx bsn@PACKAGE_VERSION (a] b.zip or 67 pkunzip -d bsn@PACKAGE_VERSION (a] b.zip 68 69 70 71 3.: Building the binaries from sources. 72 =================================== 73 74 3.1.: Create a temporary directory and copy the source package into the 75 directory. If you download the source distribution from one of the 76 DJGPP sites, just unzip it preserving the directory structure 77 running *ONE* of the following commands: 78 unzip32 bsn@PACKAGE_VERSION (a] s.zip or 79 djtarx bsn@PACKAGE_VERSION (a] s.zip or 80 pkunzip -d bsn@PACKAGE_VERSION (a] s.zip 81 and proceed to the paragraph 3.3, below. 82 83 3.2.: Source distributions downloaded from one of the GNU FTP sites need 84 some more work to unpack, if LFN support is not available. If LFN is 85 available then you can extract the source files from the archive with 86 any unzip program and proceed to the paragraph 3.3, below. Any file 87 name issue will be handled by the DJGPP configuration files. 88 To unpack the source distribution on SFN systems, first, you MUST use 89 the `djunpack' batch file to unzip the package. That is because some 90 file names in the official distributions need to be changed to avoid 91 problems on the various platforms supported by DJGPP. 92 `djunpack' invokes the `djtar' program (that is part of the basic DJGPP 93 development kit) to rename these files on the fly given a file with 94 name mappings; the distribution includes a file `djgpp/fnchange.lst' 95 with the necessary mappings. So you need first to retrieve that batch 96 file, and then invoke it to unpack the distribution. Here's how: 97 98 djtar -x -p -o bison-@VERSION@/djgpp/djunpack.bat bison-@VERSION (a] .tar.gz > djunpack.bat 99 djunpack bison-@VERSION (a] .tar.gz 100 101 (The name of the distribution archive and the leading directory of the 102 path to `djunpack.bat' in the distribution will be different for 103 versions of Bison other than @VERSION@.) 104 105 If the argument to `djunpack.bat' include leading directories, it MUST 106 be given with the DOS-style backslashes; Unix-style forward slashes 107 will NOT work. 108 109 If the distribution comes as a .tar.bz2 archive, and your version of 110 `djtar' doesn't support bzip2 decompression, you need to unpack it as 111 follows: 112 113 bnzip2 bison-@VERSION (a] .tar.bz2 114 djtar -x -p -o bison-@VERSION@/djgpp/djunpack.bat bison-@VERSION@.tar > djunpack.bat 115 djunpack bison-@VERSION@.tar 116 117 3.3.: To build the binaries you will need the following binary packages: 118 djdev203.zip (or a later but NOT a prior version) 119 bsh204b.zip (or a later but NOT a prior version) 120 gccNNNb.zip, gppNNN.zip, bnuNNNb.zip, makNNNb.zip, filNNNb.zip, 121 perlNNNb.zip, shlNNNb.zip, txtNNNb.zip, txiNNNb.zip, grepNNNb.zip, 122 sedNNNb.zip and m4NNN.zip 123 124 If you want to run the check you will need also: 125 difNNNb.zip 126 127 NNN represents the latest version number of the binary packages. All 128 this packages can be found in the /v2gnu directory of any 129 ftp.delorie.com mirror. 130 You will need bsh204b.zip or later and *NOT* a prior version or 131 the build will fail. The same applies to djdev203.zip. Please note 132 that Bison requires m4-144b.zip or later to work properly. 133 134 3.4.: If for some reason you want to reconfigure the package cd into the top 135 srcdir (bison-@TREE_VERSION@) and run the following commands: 136 del djgpp\config.cache 137 make clean 138 djgpp\config 139 140 Please note that you *MUST* delete the config.cache file in the djgpp 141 subdir or you will not really reconfigure the sources because the 142 configuration informations will be read from the cache file instead 143 of being newly computed. 144 To build the programs in a directory other than where the sources are, 145 you must add the parameter that specifies the source directory, 146 e.g: 147 x:\src\gnu\bison-@TREE_VERSION@\djgpp\config x:/src/gnu/bison-@TREE_VERSION@ 148 149 Lets assume you want to build the binaries in a directory placed on a 150 different drive (z:\build in this case) from where the sources are, 151 then you will run the following commands: 152 z: 153 md \build 154 cd \build 155 x:\src\gnu\bison-@TREE_VERSION@\djgpp\config x:/src/gnu/bison-@TREE_VERSION@ 156 157 The order of the options and the srcdir option does not matter. You 158 *MUST* use forward slashes to specify the source directory. 159 160 The batch file will set same environment variables, make MSDOS specific 161 modifications to the Makefile.in's and supply all other needed options 162 to the configure script. 163 164 3.5.: To compile the package run from the top srcdir the command: 165 make 166 167 3.6.: Now you can run the tests if you like. From the top srcdir run the 168 command: 169 make check 170 171 No test should fail but the tests #131 (Doxygen Public Documentation) 172 and #132 (Doxygen Private Documentation) will be skipped. Please note 173 that the testsuite only works with LFN available. On plain DOS, most 174 of the tests will fail due to invalid DOS names. 175 176 3.7.: To install the binaries, header, library, catalogs, and info docs 177 run the following command from the top srcdir: 178 make install 179 180 This will install the products into your DJGPP installation tree given 181 by the default prefix "/dev/env/DJDIR". If you prefer to install them 182 into some other directory you will have to set prefix to the appropriate 183 value: 184 make install prefix=z:/some/other/place 185 186 187 188 Send GNU bison specific bug reports to <bug-bison (a] gnu.org>. 189 Send suggestions and bug reports concerning the DJGPP port to 190 comp.os.msdos.djgpp or <djgpp (a] delorie.com>. 191 192 193 Enjoy. 194 195 Guerrero, Juan Manuel <juan.guerrero (a] gmx.de> 196