% Changes to adapt CTIE to web2c. % Copyright 2002,2003 Julian Gilbey % All rights reserved. % % This file is distributed WITHOUT ANY WARRANTY, express or implied. % % Permission is granted to make and distribute verbatim copies of this % file provided that the copyright notice and this permission notice % are preserved on all copies. % % Permission is granted to copy and distribute modified versions of this % file under the conditions for verbatim copying, provided that the % entire resulting derived work is distributed under the terms of a % permission notice identical to this one. % % This file is based heavily on tie.ch by Olaf Weber to adapt tie.w to % the web2c system and on comm-w2c.ch from the Web2C 7.4.5 distribution % by Wlodek Bzyl and Olaf Weber. @x l.19 Add macro definitions \def\title{The CTIE processor} @y \def\Kpathsea/{{\mc KPATHSEA\spacefactor1000}} \def\title{The CTIE processor} @z @x l.102 main(argc, argv) int argc; string *argv; @y int main @,P2C(int, argc, string *, argv) @z @x l.105 Set up kpathsea stuff @; @y @; @; @z These are defined by kpathsea; we replace this by the path-searching initialisation code taken almost verbatim from comm-w2c.ch. @x l.116 @ We include the additional types |boolean| and |string|. \.{CTIE} replaces the complex \.{TIE} character set handling (based on that of the original \.{WEB} system) with the standard \.{CWEB} behaviour, and so uses the |char| type for input and output. @d false 0 @d true 1 @= typedef int boolean; typedef char* string; @y @ The \.{ctie} program from the original \.{CTIE} package uses the compile-time default directory or the value of the environment variable \.{CWEBINPUTS} as an alternative place to be searched for files, if they could not be found in the current directory. This version uses the \Kpathsea/ mechanism for searching files. The directories to be searched for come from three sources: (a)~a user-set environment variable \.{CWEBINPUTS} (overriden by \.{CWEBINPUTS\_ctie});\par (b)~a line in \Kpathsea/ configuration file \.{texmf.cnf},\hfil\break e.g. \.{CWEBINPUTS=.:$TEXMF/texmf/cweb//} or \.{CWEBINPUTS.ctie=.:$TEXMF/texmf/cweb//};\hangindent=2\parindent\par (c)~compile-time default directories \.{.:$TEXMF/texmf/cweb//} (specified in \.{texmf.in}). @d kpse_find_cweb(name) kpse_find_file(name, kpse_cweb_format, true) @ The simple file searching is replaced by the `path searching' mechanism that the \Kpathsea/ library provides. We set |kpse_program_name| to |"ctie"|. This means if the variable |CWEBINPUTS.ctie| is present in \.{texmf.cnf} (or |CWEBINPUTS_ctie| in the environment) its value will be used as the search path for filenames. This allows different flawors of \.{CTIE} to have different search paths. @= kpse_set_program_name(argv[0], "ctie"); @ We include the additional types |boolean| and |string|. \.{CTIE} replaces the complex \.{TIE} character set handling (based on that of the original \.{WEB} system) with the standard \.{CWEB} behaviour, and so uses the |char| type for input and output. The |kpathsea| library (version 3.4.5) defines the |true|, |false|, |boolean| and |string| types in \.{kpathsea/types.h}, so we do not actually need to define them here. @z @x l.129 The kpathsea include files find the right header file for these. @ We predeclare some standard string-handling functions here instead of including their system header files, because the names of the header files are not as standard as the names of the functions. (There's confusion between \.{} and \.{}.) @= extern int strlen(); /* length of string */ extern char* strcpy(); /* copy one string to another */ extern int strncmp(); /* compare up to $n$ string characters */ extern char* strncpy(); /* copy up to $n$ string characters */ extern char *strerror(); @y @ We don't need to predeclare any string handling functions here, as the \.{kpathsea} headers do the right thing. @z @x l.176 And this. @ And we need dynamic memory allocation. This should cause no trouble in any \CEE/ program. @^system dependencies@> @= #ifdef __STDC__ #include #else #include #endif @y @ And we need dynamic memory allocation. This should cause no trouble in any \CEE/ program. The \.{kpathsea} include files handle the definition of |malloc()|, too. @^system dependencies@> @z @x l.284 way too short! @d max_file_name_length 60 @y @d max_file_name_length 1024 @z @x l.329 boolean get_line(i, do_includes) file_index i; boolean do_includes; @y boolean get_line @,P2C(file_index, i, boolean, do_includes) @z The next piece is simplified using the kpathsea kpse_find_file function. @x l.497 If the environment variable \.{CWEBINPUTS} is set, or if the compiler flag of the same name was defined at compile time, \.{CWEB} will look for include files in the directory thus named, if it cannot find them in the current directory. (Colon-separated paths are not supported.) @y We use the \Kpathsea/ library (in particular, the \.{CWEBINPUTS} variable) to search for this file. @z @x l.510 Don't need the same variables any longer char temp_file_name[max_file_name_length]; char *file_name_end; char *k, *kk; int l; /* length of file name */ @y char *file_name_end; string fullname; char *k; @z @x l.534 Replace with kpse_find_file if ((new_inc->the_file=fopen(new_inc->file_name, "r"))!=NULL) { @y fullname=kpse_find_cweb(new_inc->file_name); if (fullname) new_inc->the_file=fopen(fullname, "r"); if (fullname!=NULL && new_inc->the_file!=NULL) { free(fullname); @z @x l.539 And this part is replaced by kpse_find_file kk=getenv("CWEBINPUTS"); if (kk!=NULL) { if ((l=strlen(kk))>max_file_name_length-2) too_long(); strcpy(temp_file_name, kk); } else { #ifdef CWEBINPUTS if ((l=strlen(CWEBINPUTS))>max_file_name_length-2) too_long(); strcpy(temp_file_name, CWEBINPUTS); #else l=0; #endif /* |CWEBINPUTS| */ } if (l>0) { if (k+l+2>=file_name_end) too_long(); for (; k>= new_inc->file_name; k--) *(k+l+1)=*k; strcpy(new_inc->file_name, temp_file_name); new_inc->file_name[l]='/'; /* \UNIX/ pathname separator */ if ((new_inc->the_file=fopen(new_inc->file_name, "r"))!=NULL) { new_inc->parent=inp_desc->current_include; /* link it in */ inp_desc->current_include=new_inc; goto restart; /* success */ } } @y @z @x l.565 slightly more useful error message err_print(i, "! Cannot open include file"); @y if (fullname) { free(fullname); err_print(i, "! Cannot open include file"); } else err_print(i, "! Cannot find include file"); @z @x l.585 void err_print(); @y void err_print @,P2H(file_index, char *); @z @x l.590 void err_print(i, s) /* prints `\..' and location of error message */ file_index i; char *s; @y void err_print @,P2C(file_index, i, char *, s) /* prints `\..' and location of error message */ @z @x l.664 int wrap_up() @y int wrap_up @,P1H(void) @z @x l.674 int wrap_up(); @y int wrap_up @,P1H(void); @z @x l.697 void pfatal_error(); @y void pfatal_error @,P2H(char *, char *); @z @x l.700 void pfatal_error(s, t) char *s, *t; @y void pfatal_error @,P2C(char *, s, char *, t) @z @x l.747 Use the kpathsea library to do this @ For the master file we start by reading its first line into the buffer, if we could open it. @= { input_organisation[0]->the_file= fopen(input_organisation[0]->file_name, "r"); if (input_organisation[0]->the_file==NULL) pfatal_error("! Cannot open master file ", input_organisation[0]->file_name); @.Cannot open master file@> @y @ For the master file we start by reading its first line into the buffer, if we could open it. We use the \.{kpathsea} library to find the file. @= { string fullname; fullname = kpse_find_cweb(input_organisation[0]->file_name); if (fullname) input_organisation[0]->the_file = fopen(fullname, "r"); if (fullname==NULL || input_organisation[0]->the_file==NULL) { if (fullname) { pfatal_error("! Cannot open master file ", input_organisation[0]->file_name); } else { fatal_error(-1, "! Cannot find master file ", input_organisation[0]->file_name); } } else free(fullname); @.Cannot open master file@> @.Cannot find master file@> @z @x l.768 And this @= { file_index i; i=1; while (ithe_file= fopen(input_organisation[i]->file_name, "r"); if (input_organisation[i]->the_file==NULL) pfatal_error("! Cannot open change file ", input_organisation[i]->file_name); @.Cannot open change file@> @y @= { file_index i; string fullname; i=1; while (ifile_name); if (fullname) input_organisation[i]->the_file = fopen(fullname, "r"); if (fullname==NULL || input_organisation[i]->the_file==NULL) { if (fullname) { pfatal_error("! Cannot open change file ", input_organisation[i]->file_name); } else { fatal_error(-1, "! Cannot find change file ", input_organisation[i]->file_name); } } else free(fullname); @.Cannot open change file@> @.Cannot find change file@> @z @x l.792 boolean lines_dont_match(i, j) file_index i, j; @y boolean lines_dont_match @,P2C(file_index, i, file_index, j) @z @x l.809 void init_change_file(i) file_index i; @y void init_change_file @,P1C(file_index, i) @z @x l.858 void put_line(j) file_index j; @y void put_line @,P1C(file_index, j) @z @x l.873 boolean e_of_ch_module(i) file_index i; @y boolean e_of_ch_module @,P1C(file_index, i) @z @x l.894 boolean e_of_ch_preamble(i) file_index i; @y boolean e_of_ch_preamble @,P1C(file_index, i) @z @x l.1106 void usage_error() @y void usage_error @,P1H(void) @z @x l.1119 Add Web2C version to banner string printf("%s\n", banner); /* print a ``banner line'' */ @y { extern KPSEDLL string kpathsea_version_string; /* from kpathsea/version.c */ printf("%s (%s)\n", banner, kpathsea_version_string); /* print a ``banner line'' */ } @z @x l.1233 void usage_help(); void print_version_and_exit(); @y void usage_help @,P1H(void); void print_version_and_exit @,P2H(string, string); @z @x l.1238 void usage_help() @y void usage_help @,P1H(void) @z @x l.1253 void print_version_and_exit(name, version) string name, version; { printf ("%s %s\n", name, version); puts ("Copyright (C) 2002,2003 Julian Gilbey."); puts ("There is NO warranty. This is free software. See the source"); puts ("code of CTIE for redistribution conditions."); exit (0); } @y void print_version_and_exit @,P2C(string, name, string, version) { extern KPSEDLL string kpathsea_version_string; /* from kpathsea/version.c */ printf ("%s %s\n", name, version); puts (kpathsea_version_string); puts ("Copyright (C) 2002,2003 Julian Gilbey."); puts ("Kpathsea is copyright (C) 1999 Free Software Foundation, Inc."); puts ("There is NO warranty. This is free software."); puts ("Redistribution of this software is covered by the terms of"); puts ("both the CTIE copyright and the GNU General Public Licence."); puts ("For more information about these matters, see the files"); puts ("named COPYING and the CTIE source."); puts ("Primary authors of CTIE: Julian Gilbey."); puts ("Kpathsea written by Karl Berry and others.\n"); exit (0); } @z @x l.1267 @* System-dependent changes. This section should be replaced, if necessary, by changes to the program that are necessary to make \.{CTIE} work at a particular installation. It is usually best to design your change file so that all changes to previous modules preserve the module numbering; then everybody's version will be consistent with the printed program. More extensive changes, which introduce new modules, can be inserted here; then only the index itself will get a new module number. @^system dependencies@> @y @* System-dependent changes. We modify the program to use the \.{kpathsea} library. We need to include the headers first. @= #include @ A global variable for the file read mode. @= string file_open_mode; @z