• albert-github's avatar
    This patch contains changes regarding the build system so that the *nix and... · ac2cd570
    albert-github authored
    This patch contains changes regarding the build system so that the *nix and Windows systems use the same information (consistency). Some use names routine names have been changed (from .l files with -P option) to reflect the file name that generated the routines, this makes it easier to create a general procedure.
    A number of include / header files are files are generated from different file types (html, xml, js), due some limitations of the windows build system the generated file names had to be changed (the extension in the windows build system is only available including the '.' so e.g. the file jquery_fx.js generates now jquery_fx.js.h instead of jquery_fx_js.h)
    In the windows version the creation of .cpp files from .l files has been adjusted to correct for the YY_BUF_SIZE problems.
    Furthermore on windows (and also used on *nix) some commends have been replaced with python scripts so that on windows only python is need (besides flex and and bison). On *nix also perl is required for the generation using tmake.
    
    Below a short description of the changes will be given and grouped.
    
    Changed files
    =============
    - .gitignore
    added some directories and file
    
    - Doxyfile
    corrected for changed file names
    
    - Makefile.in
    added realclean and some other changes (ignore error) and the moment when the Makefile is deleted (as last file).
    Added entries for doxyapp and doxmlparser
    
    Added realclean for the following files (consistency):
    ======================================================
    - Makefile.win_make.in
    - Makefile.win_nmake.in
    - addon/doxmlparser/examples/metrics/Makefile.in
    - addon/doxmlparser/src/Makefile.in
    - addon/doxmlparser/test/Makefile.in
    - addon/doxyapp/Makefile.in
    - addon/doxysearch/Makefile.in
    - libmd5/Makefile.in
    - qtools/Makefile.in
    
    - addon/doxyapp/doxyapp.pro.in
    removed double occurence of -L../../lib
    
    - addon/doxysearch/doxysearch.pro.in
    no visible change just spacing?
    
    - addon/doxywizard/Makefile.in
    added realclean
    corrected call to qmake (to get it from the right place, it is not necessarily in the path)
    made some macros known in the called process
    
    - addon/doxywizard/configdoc.cpp
    automatically generated, can be removed
    
    - addon/doxywizard/doxywizard.pro.in
    corrected dependencies
    corrected call to python (to get it from the right place, it is not necessarily in the path)
    new items to generate version.cpp and config_doxyw.cpp
    
    - configure
    added configuration definition possibility for python
    added possibility to build doxmlparser
    automatically generate the lang_cfg.h file based on the available languages (translator_??.h) and not on a fixed list. This step still has to be added to the windows build process.
    
    - doc/Makefile.in
    corrected call to python (to get it from the right place, it is not necessarily in the path)
    
    - doc/config.doc
    small correction
    
    - doc/install.doc
    added python as a requirement
    changed CVS to GitHub
    
    - doc/language.doc
    automatically generated file, based on other changes.
    
    - doc/language.tpl
    made XX and xx more consistent
    changed description of the procedure based on changes already made configure.
    
    - src/Makefile.in
    adjusted used file names in distclean
    Solved PERL usage consistent with LEX / YACC (with %%PERL%%)
    automatically add translator_??>h to HEADERS
    same spacing
    
    Adjusted in the following file the names of some include files:
    ===============================================================
    - src/cite.cpp
    - src/docbookgen.cpp
    - src/ftvhelp.cpp
    - src/htmlgen.cpp
    - src/layout.cpp
    - src/searchindex.cpp
    - src/xmlgen.cpp
    
    Adjusted in the following files some routine names (..YY..) to be consistent with the file names:
    =================================================================================================
    - src/commentscan.l
    - src/constexp.h
    - src/constexp.l
    - src/constexp.y
    - src/fortrancode.l
    - src/fortranscanner.l
    - src/pyscanner.l
    - src/pre.l
    - src/scanner.l
    - src/tclscanner.l
    - src/vhdlparser.y
    - src/vhdlscanner.l
    
    - src/config.xml
    small textual correction
    
    - src/configoptions.cpp
    generated output file, can be removed
    
    - src/lang_cfg.h
    Automatically generated file with selected languages (*nix). On windows a procedure has to be defined.
    
    - src/libdoxycfg.t.in
    corrected call to python (to get it from the right place, it is not necessarily in the path)
    
    - src/libdoxygen.pro.in
    adjusted include file names
    removed translator_??.h files, they are added automatically
    changed file name ce_lex.cpp -> constexp.cpp (generated file)
    
    - src/libdoxygen.t.in
    made LEX calls used the file name for the -P option
    changed INCREASEBUF script to a python script
    changed teh geneartion of some include file, now by means of a pythons script. Names of the generated include file had to be changed as well.
    added possibility to generate version.cpp here as well.
    
    Added HEADERS to dependency so non existing but later generated include files are recognized as well:
    =====================================================================================================
    - tmake/lib/unix/generic.t
    - tmake/lib/win32-borland/generic.t
    - tmake/lib/win32-g++/generic.t
    - tmake/lib/win32-mingw/generic.t
    - tmake/lib/win32-msvc/generic.t
    - tmake/lib/win32-symantec/generic.t
    - tmake/lib/win32-visage/generic.t
    - tmake/lib/win32-watcom/generic.t
    
    - winbuild/Doxygen.vcproj
    made consistent wit *nix version.
    Generating all possible files
    removed unused /empty parts
    setting for the Lex.rules and other rules files some default values
    
    - winbuild/Doxywizard.vcproj
    made consistent wit *nix version.
    Generating all possible files
    removed unused /empty parts
    removed system dependent paths (C:\... etc) replaced then with external environment variables
    
    - winbuild/Lex.rules
    adjusted file to comply with new requirements, only user variable is -d. -i is set to read only (value can be changed  in doxygen.vcproj). Handling of other arguments is all default.
    generation including increasebuffer possibility
    
    - winbuild/doxyindexer.vcproj
    corrected path
    
    - winbuild/doxysearch.vcproj
    removed system dependent paths (C:\... etc) replaced then with external environment variables
    
    - winbuild/qtools.vcproj
    corrected type, wrong used directory
    
    The following files are automatically generated (with slightly other names like index.xsd.h etc.):
    ==================================================================================================
    - src/index_xsd.h
    - src/doxygen_bst.h
    - src/dynsections_js.h
    - src/extsearch_js.h
    - src/footer_html.h
    - src/header_html.h
    - src/jquery_fx_js.h
    - src/jquery_p1_js.h
    - src/jquery_p2_js.h
    - src/jquery_p3_js.h
    - src/jquery_pt_js.h
    - src/jquery_ui_js.h
    - src/navtree_css.h
    - src/navtree_js.h
    - src/resize_js.h
    - src/search_css.h
    - src/search_functions_php.h
    - src/search_js.h
    - src/search_opensearch_php.h
    - src/svgpan_js.h
    the following files are generated with different names:
    - src/bib2xhtml.h
    becomes
    - src/bib2xhtml.pl/h
    
    - src/layout_default.h
    becomes
    - src/layout_default.xml.h
    
    The file:
    =========
    - addon/doxywizard/config.l
    is replaced by:
    - addon/doxywizard/config_doxyw.l
    so there are in the system not 2 different config.l files. Renamed some routines from configYY -> config_doxywYY...
    
    New files:
    ==========
    - src/increasebuffer.py
    increase YY_BUF_SIZE and YY_READ_BUF_SIZE from 16k / 8k to 256k.
    
    - src/settings.py
    create settings.h file
    
    - src/to_c_cmd.py
    create include files from different files (html, xml, js) so they can be included in the code as defaults
    
    - src/version.py
    create version.cpp file based on the configure file
    
    - winbuild/Config.rules
    rules file to convert the config.xml file into configoptions.cpp (doxygen) or configdoc.cpp (doxywizard). Seen the differences 2 rules are created within this file.
    
    - winbuild/Gen_head.rules
    rules files to generate include files from different files using to_c_cmd.py
    
    - winbuild/Settings.rules
    rules file for generating the settings.h file. It is possible to select to use CLANG and SqlLite3
    
    - winbuild/Version.rules
    rules file to be able to start version.py
    
    The files:
    ==========
    - version.bat
    - runbison.bat
    - increasebuffer.pl
    are not used anymore.
    
    I've only added the files as indicated, I didn't remove the files from the repository.
    ac2cd570
generic.t 7.08 KB
#!
#! This is a tmake template for building Win32 applications or libraries.
#!
#${
    if ( Config("qt") ) {
	if ( !(Project("DEFINES") =~ /QT_NODLL/) &&
	     ((Project("DEFINES") =~ /QT_(?:MAKE)?DLL/) ||
	      ($ENV{"QT_DLL"} && !$ENV{"QT_NODLL"})) ) {
	    Project('TMAKE_QT_DLL = 1');
	    if ( (Project("TARGET") eq "qt") && Project("TMAKE_LIB_FLAG") ) {
		Project('CONFIG += dll');
	    }
	}
    }
    if ( Config("dll") || Project("TMAKE_APP_FLAG") ) {
	Project('CONFIG -= staticlib');
	Project('TMAKE_APP_OR_DLL = 1');
    } else {
	Project('CONFIG += staticlib');
    }
    if ( Config("warn_off") ) {
	Project('TMAKE_CFLAGS += $$TMAKE_CFLAGS_WARN_OFF');
	Project('TMAKE_CXXFLAGS += $$TMAKE_CXXFLAGS_WARN_OFF');
    } elsif ( Config("warn_on") ) {
	Project('TMAKE_CFLAGS += $$TMAKE_CFLAGS_WARN_ON');
	Project('TMAKE_CXXFLAGS += $$TMAKE_CXXFLAGS_WARN_ON');
    }
    if ( Config("debug") ) {
	Project('TMAKE_CFLAGS += $$TMAKE_CFLAGS_DEBUG');
	Project('TMAKE_CXXFLAGS += $$TMAKE_CXXFLAGS_DEBUG');
	Project('TMAKE_LFLAGS += $$TMAKE_LFLAGS_DEBUG');
    } elsif ( Config("release") ) {
	Project('TMAKE_CFLAGS += $$TMAKE_CFLAGS_RELEASE');
	Project('TMAKE_CXXFLAGS += $$TMAKE_CXXFLAGS_RELEASE');
	Project('TMAKE_LFLAGS += $$TMAKE_LFLAGS_RELEASE');
    }
    if ( Config("qt") || Config("opengl") ) {
	Project('CONFIG += windows' );
    }
    if ( Config("qt") ) {
	Project('CONFIG *= moc');
	AddIncludePath(Project("TMAKE_INCDIR_QT"));
	if ( Config("release") ) {
	    Project('DEFINES += NO_DEBUG');
	}
	if ( Config("opengl") ) {
	    Project('TMAKE_LIBS *= $$TMAKE_LIBS_QT_OPENGL');
	}
	if ( (Project("TARGET") eq "qt") && Project("TMAKE_LIB_FLAG") ) {
	    if ( Project("TMAKE_QT_DLL") ) {
		Project('DEFINES -= QT_DLL');
		Project('DEFINES *= QT_MAKEDLL');
		Project('TMAKE_LFLAGS += $$TMAKE_LFLAGS_QT_DLL');
	    }
	} else {
	    if ( Project("TMAKE_QT_DLL") ) {
		Project('DEFINES *= QT_DLL');
	    }
	    Project('TMAKE_LIBS *= $$TMAKE_LIBS_QT');
	    if ( Project("TMAKE_QT_DLL") ) {
		my $qtver =FindHighestLibVersion($ENV{"QTDIR"} . "/lib", "qt");
		Project("TMAKE_LIBS /= s/qt.lib/qt${qtver}.lib/");
		if ( !Config("dll") ) {
		    Project('TMAKE_LIBS *= $$TMAKE_LIBS_QT_DLL');
		}
	    }
	}
    }
    if ( Config("opengl") ) {
	Project('TMAKE_LIBS *= $$TMAKE_LIBS_OPENGL');
    }
    if ( Config("dll") ) {
	Project('TMAKE_LFLAGS_CONSOLE_ANY = $$TMAKE_LFLAGS_CONSOLE_DLL');
	Project('TMAKE_LFLAGS_WINDOWS_ANY = $$TMAKE_LFLAGS_WINDOWS_DLL');
	if ( Project("TMAKE_LIB_FLAG") ) {
	    my $ver = Project("VERSION");
	    $ver =~ s/\.//g;
	    $project{"TARGET_EXT"} = "${ver}.dll";
	} else {
	    $project{"TARGET_EXT"} = ".dll";
	}
    } else {
	Project('TMAKE_LFLAGS_CONSOLE_ANY = $$TMAKE_LFLAGS_CONSOLE');
	Project('TMAKE_LFLAGS_WINDOWS_ANY = $$TMAKE_LFLAGS_WINDOWS');
	if ( Project("TMAKE_APP_FLAG") ) {
	    $project{"TARGET_EXT"} = ".exe";
	} else {
	    $project{"TARGET_EXT"} = ".lib";
	}
    }
    if ( Config("windows") ) {
	if ( Config("console") ) {
	    Project('TMAKE_LFLAGS *= $$TMAKE_LFLAGS_CONSOLE_ANY');
	    Project('TMAKE_LIBS   *= $$TMAKE_LIBS_CONSOLE');
	} else {
	    Project('TMAKE_LFLAGS *= $$TMAKE_LFLAGS_WINDOWS_ANY');
	}
	Project('TMAKE_LIBS   *= $$TMAKE_LIBS_WINDOWS');
    } else {
	Project('TMAKE_LFLAGS *= $$TMAKE_LFLAGS_CONSOLE_ANY');
	Project('TMAKE_LIBS   *= $$TMAKE_LIBS_CONSOLE');
    }
    if ( Config("moc") ) {
	$moc_aware = 1;
    }
    Project('TMAKE_LIBS += $$LIBS');
    Project('TMAKE_FILETAGS = HEADERS SOURCES DEF_FILE RC_FILE TARGET TMAKE_LIBS DESTDIR DLLDESTDIR $$FILETAGS');
    foreach ( split(/\s/,Project("TMAKE_FILETAGS")) ) {
	$project{$_} =~ s-[/\\]+-\\-g;
    }
    if ( Project("DEF_FILE") ) {
	Project('TMAKE_LFLAGS *= /DEF:$$DEF_FILE');
    }
    if ( Project("RC_FILE") ) {
	if ( Project("RES_FILE") ) {
	    tmake_error("Both .rc and .res file specified.\n" .
			"Please specify one of them, not both.");
	}
	$project{"RES_FILE"} = $project{"RC_FILE"};
	$project{"RES_FILE"} =~ s/\.rc$/.res/i;
	Project('TARGETDEPS += $$RES_FILE');
    }
    if ( Project("RES_FILE") ) {
	Project('TMAKE_LIBS *= $$RES_FILE');
    }
    StdInit();
    if ( Project("VERSION") ) {
	$project{"VER_MAJ"} = $project{"VERSION"};
	$project{"VER_MAJ"} =~ s/\.\d+$//;
	$project{"VER_MIN"} = $project{"VERSION"};
	$project{"VER_MIN"} =~ s/^\d+\.//;
    }
    Project('debug:TMAKE_CLEAN += $$TARGET.pdb vc*.pdb $$TARGET.ilk');
#$}
#!
# Makefile for building #$ Expand("TARGET")
# Generated by tmake at #$ Now();
#     Project: #$ Expand("PROJECT");
#    Template: #$ Expand("TEMPLATE");
#############################################################################

####### Compiler, tools and options

CC	=	#$ Expand("TMAKE_CC");
CXX	=	#$ Expand("TMAKE_CXX");
CFLAGS	=	#$ Expand("TMAKE_CFLAGS"); ExpandGlue("DEFINES","-D"," -D","");
CXXFLAGS=	#$ Expand("TMAKE_CXXFLAGS"); ExpandGlue("DEFINES","-D"," -D","");
INCPATH	=	#$ ExpandPath("INCPATH",'-I',' -I','');
#$ !Project("TMAKE_APP_OR_DLL") && DisableOutput();
LINK	=	#$ Expand("TMAKE_LINK");
LFLAGS	=	#$ Expand("TMAKE_LFLAGS");
LIBS	=	#$ Expand("TMAKE_LIBS");
#$ !Project("TMAKE_APP_OR_DLL") && EnableOutput();
#$ Project("TMAKE_APP_OR_DLL") && DisableOutput();
LIB	=	#$ Expand("TMAKE_LIB");
#$ Project("TMAKE_APP_OR_DLL") && EnableOutput();
MOC	=	#$ Expand("TMAKE_MOC");

ZIP	=	#$ Expand("TMAKE_ZIP");

####### Files

HEADERS =	#$ ExpandList("HEADERS");
SOURCES =	#$ ExpandList("SOURCES");
OBJECTS =	#$ ExpandList("OBJECTS");
SRCMOC	=	#$ ExpandList("SRCMOC");
OBJMOC	=	#$ ExpandList("OBJMOC");
DIST	=	#$ ExpandList("DISTFILES");
TARGET	=	#$ ExpandGlue("TARGET",$project{"DESTDIR"},"",$project{"TARGET_EXT"});

####### Implicit rules

.SUFFIXES: .cpp .cxx .cc .c

.cpp.obj:
	#$ Expand("TMAKE_RUN_CXX_IMP");

.cxx.obj:
	#$ Expand("TMAKE_RUN_CXX_IMP");

.cc.obj:
	#$ Expand("TMAKE_RUN_CXX_IMP");

.c.obj:
	#$ Expand("TMAKE_RUN_CC_IMP");

####### Build rules

all: #$ ExpandGlue("ALL_DEPS",""," "," "); $text .= '$(TARGET)';

$(TARGET): $(HEADERS) $(OBJECTS) $(OBJMOC) #$ Expand("TARGETDEPS");
#$ Project("TMAKE_APP_OR_DLL") || DisableOutput();
	$(LINK) $(LFLAGS) /OUT:$(TARGET) @<<
	    $(OBJECTS) $(OBJMOC) $(LIBS)
#$ Project("TMAKE_APP_OR_DLL") || EnableOutput();
#$ Project("TMAKE_APP_OR_DLL") && DisableOutput();
	$(LIB) /OUT:$(TARGET) @<<
	    $(OBJECTS) $(OBJMOC)
#$ Project("TMAKE_APP_OR_DLL") && EnableOutput();
<<
#$ (Config("dll") && Project("DLLDESTDIR")) || DisableOutput();
	-copy $(TARGET) #$ Expand("DLLDESTDIR");
#$ (Config("dll") && Project("DLLDESTDIR")) || EnableOutput();
#$ Project("RC_FILE") || DisableOutput();

#$ Substitute("\$\$RES_FILE: \$\$RC_FILE\n\t\$\$TMAKE_RC \$\$RC_FILE");
#$ Project("RC_FILE") || EnableOutput();

moc: $(SRCMOC)

#$ TmakeSelf();

dist:
	#$ Substitute('$(ZIP) $$PROJECT.zip $$PROJECT.pro $(SOURCES) $(HEADERS) $(DIST)');

clean:
	#$ ExpandGlue("OBJECTS","-del ","\n\t-del ","");
	#$ ExpandGlue("SRCMOC" ,"-del ","\n\t-del ","");
	#$ ExpandGlue("OBJMOC" ,"-del ","\n\t-del ","");
	-del $(TARGET)
	#$ ExpandGlue("TMAKE_CLEAN","-del ","\n\t-del ","");
	#$ ExpandGlue("CLEAN_FILES","-del ","\n\t-del ","");

####### Compile

#$ BuildObj(Project("OBJECTS"),Project("SOURCES"));
#$ BuildMocObj(Project("OBJMOC"),Project("SRCMOC"));
#$ BuildMocSrc(Project("HEADERS"));
#$ BuildMocSrc(Project("SOURCES"));