********************************************************************* * * * LEDA * * * * Windows 95/98/NT/2000/XP * * MSVC++ 7.1 * * Static Libraries * * * * Installation and Usage * * * ********************************************************************* This file describes the installation and usage of static libraries of LEDA with Microsoft Visual C++ .NET. Remark: This file describes the situation in a GUI package of LEDA. If you have the geometry, graph, or basic package only the corresponding libraries are provided. 0. Contents of File ------------------- I. Preparations II. Files and Directories III. Compiling and Linking in Microsoft Visual C++ .NET IV. Compiling and Linking Application Programs in a DOS-Box V. Example programs and demos I. Preparations --------------- To install LEDA you only need to execute the LEDA distribution file LEDA---win32-.exe. During setup you can choose the name of the LEDA root directory and the parts of LEDA you want to install. Then you have to set the environment variable LEDAROOT as follows: 1. Windows NT/2000/XP: On these platforms LEDARROOT is set automatically to the directory where you installed LEDA by the setup program. 2. Windows 95/98: (a) Add the line set LEDAROOT= to the file "autoexec.bat" where is the root directory of your LEDA installation, e.g., D:\LEDA-5.0\ (b) Restart Windows 95/98 for the change to take effect. II. Files and Directories ------------------------- To compile and link your programs with LEDA, the LEDA main directory should contain the following files and subdirectories: Readme.txt Readme File Install\win32_msc70_lib.txt this file incl\ the LEDA include directory license.txt License file and at least one of the following library sets libl_ml.lib, libg_ml.lib, libp_ml.lib, libw_ml.lib, libgeow_ml.lib, libd3_ml.lib libl_mld.lib, libg_mld.lib, libp_mld.lib, libw_mld.lib, libgeow_mld.lib, libd3_mld.lib libl_md.lib, libg_md.lib, libp_md.lib, libw_md.lib, libgeow_md.lib, libd3_md.lib libl_mdd.lib, libg_mdd.lib, libp_mdd.lib, libw_mdd.lib, libgeow_mdd.lib, libd3_mdd.lib libl_mt.lib, libg_mt.lib, libp_mt.lib, libw_mt.lib, libgeow_mt.lib, libd3_mt.lib libl_mtd.lib, libg_mtd.lib, libp_mtd.lib, libw_mtd.lib, libgeow_mtd.lib, libd3_mtd.lib III. Compiling and Linking in Microsoft Visual C++ .NET ------------------------------------------------------- To compile and link an application program using LEDA in Microsoft Visual C++ .NET proceed as follows: (1) In the "File" menu of Visual C++ .NET click on "New->Project". (2) Choose "Visual C++ Projects" as project type and "Win32 Project" as template. Enter a project name, choose a directory for the project, and click "OK" (3) In the Win32 Application Wizard click on "Application Settings", choose "Console Application" and "Empty Project", and click "Finish" (4) After clicking "OK" you have an empty project space If you already have a source file prog.cpp: (5) Activate the file browser and add prog.cpp to the main folder of your project (6) In the Solution Explorer of your project click on "Source Files" with the right mouse button, then click on "Add-> Add Existing Item" with the left mouse button (7) Double click on prog.cpp If you want to enter a new source file: (5') In the Solution Explorer of your project click on "Source Files" with the right mouse button, then click on "Add-> Add New Item" with the left mouse button. (6') Choose "C++ File" in Templates, enter a name, and click "Open". (7') Enter your code. (8) In the Solution Explorer right click on your project and left click on "Properties" (9) Click on "C/C++" and "Code Generation" and choose the "Run Time Library" (=compiler flag) you want to use. The default value is "/MLd", alternatives are "/ML", "/MD", "/MDd", "/MT", and "/MTd". Notice that you have to use the LEDA libraries that correspond to the chosen flag, e.g., with option "/MD" you must use libl_md.lib, libg_md.lib, libp_md.lib, libw_md.lib, libgeow_md.lib, and libd3_md.lib. Using another set of libraries with "/MD" could lead to serious linker errors. (10) Click on "Linker" and "Command Line" and add the name of the LEDA libraries you want to use in "Additional Options" as follows. We use to indicate the compiler option chosen in Step (9) (,e.g., is mld for "/MLd"). libl_.lib for programs using only basic data types of LEDA libg_.lib libl_.lib for programs using graph data types libp_.lib libg_.lib libl_.lib for programs using geometric data types libd3_.lib libp_.lib libg_.lib libl_.lib\ wsock32.lib for programs using three-dimensional data types libw_.lib libp_.lib libg_.lib libl_.lib\ wsock32.lib for programs using graphics data types libgeow_.lib libd3_.lib libw_.lib libp_.lib\ libg_.lib libl_.lib wsock32.lib for programs using GeoWin Alternatively, you can include in your program and the correct LEDA libraries are linked to your program automatically. If GeoWin is used you need to add "_LINK_GeoW" to the "Preprocessor definitions" in Step (9). Notice that autolink_static.h only works correctly for the GUI package of LEDA. (11) Click "OK" to leave the "Settings" (12) In the "Tools" menu click on "Options" (13) Click on "Projects->VC++ Directories" (14) Choose "Include Files" in "Show Directories for:" and add the directory \incl containing the LEDA include files (Double click on the small rectangle in "Directories", enter \incl, or click on the small grey rectangle on the right and choose the correct directory.) (15) Choose "Library Files" in "Show Directories for:" and add the directory containing the LEDA libraries. (16) Click "OK" to leave the "Options" (17) In the "Build" menu click on "Build " or "Rebuild " to compile your program. (18) In the "Build" menu click on "Execute prog.exe" to execute your program. Remark: If your C++ source code files has extension .c, you need to add the option "/TP" in "Project Options" (similar to Step (9)), otherwise you will get a number of compiler error. (Click on "C/C++" and "Command Line". Add /TP in "Additional Options" and click "Apply".) To add LEDA to an existing Project in Microsoft Visual C++ .NET, start the Microsoft Visual Studio with your project and follow Steps (8)-(16) above. IV. Compiling and Linking Application Programs in a DOS-Box ----------------------------------------------------------- (a) Setting the Environment Variables for Visual C++: The compiler CL.EXE and the linker LINK.EXE require that the environment variables PATH, INCLUDE, and LIB have been set properly. When Visual C++ was installed, setup created a batch file, VSVARS32.BAT, containing commands to modify PATH, LIB, and INCLUDE. Run VSVARS32.BAT at the command prompt before you compile your application program. VSVARS32.BAT is located in the \bin subdirectory of your compiler installation, e.g., c: \programs \microsoft visual studio .NET \Vc7 \bin. To compile programs together with LEDA, the environment variables PATH, LIB, and INCLUDE must additionally contain the corresponding LEDA directories. (b) Setting Environment Variables for LEDA: (i) Windows NT/2000/XP: 1. In the "Start" menu, point to "Settings", then click "Control Panel". 2. In the "Control Panel", double click "System". 3. In the System Properties dialog box, click the Environment tab (for NT), respectively the Extended tab and then on "Environment Variables" (for 2000/XP). If a user variable PATH, LIB, or INCLUDE already exists, extend the current value as follows: extend PATH by extend INCLUDE by \incl extend LIB by Otherwise add new a user variable PATH, INCLUDE, or LIB with value , respectively \incl. (ii) Windows 95/98: 1. Change the file autoexec.bat as follows: If a variable PATH, INCLUDE, or LIB is already set, append the appropriate LEDA directory , respectively \incl. Otherwise add a corresponding line to autoexec.bat: set PATH= set INCLUDE= \incl set LIB= 2. Restart Windows 95/98 for the change to take effect. After these procedures, it suffices to call VSVARS32.BAT at the command prompt. In both cases the LEDA paths are automatically appended to the compiler paths. (c) Compiling and Linking Application Programs: After setting the environment variables, you can use the LEDA libraries as follows to compile and link programs. Programs using basic data types: cl