allegro-4.2.0/docs/build/msvc.txt

/\ \ /\ \ /\ \

     ______   ___    ___
    /\  _  \ /\_ \  /\_ \
    \ \ \L\ \\//\ \ \//\ \      __     __   _ __   ___ 
     \ \  __ \ \ \ \  \ \ \   /'__`\ /'_ `\/\`'__\/ __`\
      \ \ \/\ \ \_\ \_ \_\ \_/\  __//\ \L\ \ \ \//\ \L\ \
       \ \_\ \_\/\____\/\____\ \____\ \____ \ \_\\ \____/
        \/_/\/_/\/____/\/____/\/____/\/___L\ \/_/ \/___/
                                       /\____/
                                       \_/__/


                 MSVC-specific information.

         See readme.txt for a more general overview.



====================================
============ MSVC notes ============
====================================

   Status: complete.

   The screensaver example is built, but you must copy scrsave.scr to
   your windows/system directory (or winnt/system32 directory
   under Windows NT/2k/XP) if you want to test it.



===========================================
============ Required software ============
===========================================

   Microsoft Visual C++.
   Recent set of DirectX and other Windows SDK headers.
   A GNU environment to run GNU tools with, such as DJGPP, MinGW or Cygwin.
   Depending on which one you choose, you will need the following packages:
   
      DJGPP: compiler (djdev*.zip, gcc*b.zip, bnu*b.zip).
         GNU make (mak*b.zip).
         Optional: GNU sed (sed*b.zip). Used by "make depend" and
         "fixdll.bat".
         Optional: GNU sort (txt*b.zip). Used by "fixdll.bat".

      MinGW: compiler (mingw-runtime, gcc, binutils).
         GNU make.
         Optional: GNU sed. Used by "make depend" and "fixdll.bat".
         Optional: GNU sort (textutils). Used by "fixdll.bat".
         Optional: w32api. See next section about details.

      Cygwin: compiler (cygwin, gcc, binutils).
         GNU make.
         Optional: GNU sed. Used by "make depend" and "fixdll.sh"
         Optional: GNU sort (textutils). Used by "fixdll.sh".
   
   Allegro should work ok with MSVC versions 4, 5, 6, 7.0 (.NET),
   7.1 (.NET 2003) and 8.0 (.NET 2005). However note that the lowest tested
   version is 6.

   The DirectX SDK can be obtained directly from Microsoft. An old version 
   of the headers is included with MSVC 6, but Allegro requires more recent 
   files. You should either copy the current headers into your MSVC include 
   and lib directories, or alter your INCLUDE and LIB environment variables
   to put the DirectX SDK files in front of the standard MSVC locations.

   If you choose to use DJGPP as your GNU environment, the DJGPP compiler and
   associated tools can be downloaded from your nearest SimTel mirror site,
   in the /pub/simtelnet/gnu/djgpp/ directory, or you can use the zip picker
   on http://www.delorie.com/djgpp/. See the djgpp readme.1st file for
   informations about how to install DJGPP.

   If you choose MinGW, download the MinGW compiler and associated tools from
   'http://www.mingw.org' or 'http://sourceforge.net/projects/mingw/'. You
   can download the complete distribution instead of the individual packages
   if you don't want to install each package manually.

   If you choose Cygwin, get setup.exe from 'http://sources.redhat.com/cygwin/'.
   Start the Cygwin setup program and download the required packages. Then
   install the packages (run setup.exe once more). When setup asks you which
   line endings you want, select unix-style instead of DOS.

   Remember that the chosen set of tools have to be on your PATH during the
   building of Allegro.



============================================
============ Installing Allegro ============
============================================

   This is a source-only distribution, so you will have to compile Allegro 
   before you can use it. To do this you should:

   Set up your environment so that MSVC can be used from the commandline.
   You probably have a vcvars32.bat file that will do this for you (usually
   located in the VC98\BIN folder where you have MSVC installed, for example
   C:\Program Files\Microsoft Visual Studio\). Under either Windows NT or
   Windows 2000, you will have to run this file every time you open a DOS box
   or configure the environment variables in Control Panel/System/Environment.

   The make process needs all the path variables to be in DOS 8.3 format, and
   since MSVC is usually installed in something like
   "C:\Program Files\Microsoft\Microsoft Visual Studio .NET 2003",
   this will cause a problem. Run "echo %MSVCDir%" (%VCINSTALLDIR%
   under MSVC 8) from the command line to see if you have this problem. 
   If you are using MSVC 6 or lower the output should already be in DOS 8.3
   format so you should not have any troubles. With higher versions of MSVC
   it will probably show the long path with spaces. There are two solutions
   for this.

   If you have chosen MinGW and have installed it with the w32api package
   you can solve this problem simply by passing the --msvcpaths
   parameter to fix.bat (see below).

   Otherwise if you are using vcvars32.bat, you will have to
   edit it so that it sets the 8.3 paths, not the long versions.
   To get 8.3 path names, you can use the command prompt (cmd.exe).
   Type in "dir /x" to get a listing of the 8.3 file and directory
   names alongside of their full names. You can also use the DOS prompt
   (command.exe) and "dir", but this will only show
   you the 8.3 names.

   If you are using Cygwin as the GNU environment, start the Cygwin bash shell
   from the command prompt (if you used the command prompt to run vcvars32.bat
   then you must start Cygwin in the same command-prompt window you used to
   run vcvars32.bat unless you configured the environment variables in Control
   Panel/System/Environment). This is usually done via "C:\cygwin\cygwin.bat".

   Go to the directory where you have installed Allegro by using 'cd'.

   If you are using Cygwin, type "./fix.sh msvc --utod". Otherwise (i.e if
   you are using DJGPP or MinGW), type "fix.bat msvc". If you are 
   using MinGW and want the fix.bat to solve problems with long paths,
   type "fix.bat msvc --msvcpaths".
   
   If you are using MSVC 7 you can specify "msvc7" instead of "msvc" to enable
   better optimizations. Likewise, you can specify "icl" to use the Intel
   commandline compiler. If you are using MSVC 8 you should specify "msvc8"
   otherwise you will get a lot of deprecation warnings. For MSVC 6 and older
   you can use also "msvc6".

   If you are compiling from CVS, before continuing you must run both
   "make depend" and "misc/fixdll.sh" as explained below, or the build will
   fail asking for some .inc file.

   Type "make". Then go do something interesting while everything compiles.
   When it finishes compiling, type "make install" to set the library up
   ready for use.

   If you also want to install a debugging version of the library (highly 
   recommended), now type "make install DEBUGMODE=1". Case is important, so
   it must be DEBUGMODE, not debugmode!

   If you also want to install a profiling version of the library, now type 
   "make install PROFILEMODE=1".

   If you want statically linked libraries as well as the default DLLs, pass
   additionally "STATICLINK=1" to the make commands above.

   If your copy of Allegro doesn't include the makefile.dep dependency files
   (unlikely, unless you have run "make veryclean" at some point or are
   building the CVS version), you can regenerate them by running
   "make depend".

   If your copy of Allegro doesn't include the linker .def file (unlikely, 
   unless you have run "make veryclean" at some point or are building the CVS
   version), you can regenerate it by running "misc\fixdll.bat". Cygwin users
   can run "misc/fixdll.sh" instead.

   Once the build is finished you can recover some disk space by running
   "make compress", which uses the UPX program to compress the executable
   files and the optimized dll. Before running "make compress", you must set
   the environment variable UPX_BIN to point to upx.exe. You will have to
   do run "make compress" before "make install" if you want the compressed
   dll to be copied to the windows directory. To recover even more disk
   space, you can run "make clean" to get rid of all the temporary files and
   HTML format documentation.



=======================================
============ Using Allegro ============
=======================================

   All the Allegro functions, variables, and data structures are defined in 
   allegro.h. You should include this in your programs, and link with one of
   the libraries:

      alleg.lib      - optimised DLL import library
      alld.lib       - debugging DLL import library
      allp.lib       - profiling DLL import library
      alleg_s.lib    - statically linked optimised library
      alld_s.lib     - statically linked debugging library
      allp_s.lib     - statically linked profiling library

   When using a statically linked library, you must define the preprocessor
   symbol ALLEGRO_STATICLINK before including any of the Allegro headers and
   link your program against Allegro and the main Win32/DirectX libraries
   in that order (see the variable LIBRARIES in makefile.vc). You have also
   to make sure that your program is linked against the right C run-time
   library, ie. the multi-threaded DLL version of MSVCRT (or the debug
   version if you are using the debug library). You can change this option
   at Project - Settings - C/C++ - Category: Code Generation - Use run-time
   library.

   Don't forget that you need to use the END_OF_MAIN() macro right after
   your main() function!

   If you use one of the DLL versions, you will obviously need to distribute 
   the appropriate DLL along with your program: these can be found in the 
   allegro/lib/msvc/ directory.