summaryrefslogtreecommitdiffstats
path: root/windows/hdf5build_examples.BAT
blob: 3fea3300ec5fbb84af09ee7930f2db59ec5eeea5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
@echo OFF
rem Copyright by The HDF Group.

rem Copyright by the Board of Trustees of the University of Illinois.

rem All rights reserved.

rem

rem This file is part of HDF5.  The full HDF5 copyright notice, including

rem terms governing use, modification, and redistribution, is contained in

rem the files COPYING and Copyright.html.  COPYING can be found at the root

rem of the source code distribution tree; Copyright.html can be found at the

rem root level of an installed copy of the electronic HDF5 document set and

rem is linked from the top-level documents page.  It can also be found at

rem http://hdfgroup.org/HDF5/doc/Copyright.html.  If you do not have

rem access to either file, you may request a copy from helphdfgroup.org.



rem File Name: hdf5build_examples.bat

rem This batch file is used to build HDF5 C/C++/Fortran examples.

rem This batch file takes the following options:

rem .  /fort             Build HDF5 examples, including Fortran

rem .  /nodebug          Note: Default is to build debug and release versions

rem .  /useenv           Build HDF5 examples using compiler settings defined

rem .                    in the environment, rather than the IDE.

rem .  /?                Help information

rem By Scott Wegner

rem Created: April 1st, 2008

rem Last Updated: April 14, 2008


rem This batch file makes the following assumptions:

rem    - The appropriate version of Visual Studio is installed and setup

rem    - The directory structure is setup from a fresh source copy

rem    - copy_hdf.bat has already been run from the ./windows directory

rem    - HDF5 has already been built using standard settings

rem    - Visual Studio already contains the required paths for external libraries

rem    - szip and zlib DLLs are already placed in an accessible directory

rem    - hdf5_ext_szip or hdf5_ext_zlib have been set accordingly

rem    - if building with the /useenv option, szip and zlib paths have been added

rem      to %include% and %libpath% as necessary.


rem By default, only C and C++ examples are built.


setlocal enabledelayedexpansion
pushd %~dp0

set nerrors=0
if "%1"=="/?" goto help

set blddebug=debug

set bldrelease=release

goto main



rem Print a help message

:help



    echo.Builds HDF5 example projects.

    echo.

    echo.Usage: %~nx0 [OPTION]

    echo.

    echo.   /fort             Build HDF5 examples, including Fortran

    echo.   /ivf101           Build HDF5 examples using Intel Visual Fortran 10.1

    echo.   /ivf111           Build HDF5 examples using Intel Visual Fortran 11.1

    echo.   /nodebug          Note: Default is to build debug and release versions

    echo.   /useenv           Build HDF5 examples using compiler settings defined

    echo.                     in the environment, rather than the IDE.

    echo.   /?                Help information



    exit /b 0





rem Parse through the parameters sent to file, and set appropriate variables

:parse_params



    for %%a in (%*) do (

        if "%%a"=="/fort" (
            rem Enable Fortran
            set hdf5_enablefortran=true
            
        ) else if "%%a"=="/ivf111" (

            rem Enable Fortran

            set hdf5_ivf111=true

            

        ) else if "%%a"=="/ivf101" (
            rem Enable Fortran
            set hdf5_ivf101=true

		) else if "%%a"=="/nodebug" (

            rem Enable Fortran

            set blddebug=

            

        ) else if "%%a"=="/useenv" (
            rem Pass /useenv flag to devenv
            set hdf5_useenv=true
            
        ) else (
            rem Set errorlevel 2 to send to help if we receive a bad parameter
            echo.Unknown option: %%a
            call :help
            exit /b 1
        )
    )
    
    exit /b 0


rem Setup our environment

:setup

    rem Constants
    
    echo.Setting up environment
     
    rem Make sure PROCESSOR_ARCHITECURE is set to either x86 or AMD64
    if "%PROCESSOR_ARCHITECTURE%"=="x86" (

        set hdf5_platform=Win32

    ) else if "%PROCESSOR_ARCHITECTURE%"=="AMD64" (
        set hdf5_platform=x64
    ) else (
        echo.Error: Environment variable PROCESSOR_ARCHITECTURE should contain
        echo.either x86 or AMD64
        exit /b 1
    )
   
    rem Setup Visual Studio environment.  By default, use the Visual Studio 
    rem 2008 environment.
    
    set ccflags=
    
    rem Currently VS2008 is the only compiler supported. 8
    echo.Using Visual Studio 2008
    
    if not defined hdf5_enablefortran (
		if defined vs90comntools (
			rem This sets the Visual Studio 2008 path and environment variables
			if %hdf5_platform%==Win32 (
				call "%vs90comntools%\..\..\VC\vcvarsall.bat" x86

			) else (

				call "%vs90comntools%\..\..\VC\vcvarsall.bat" x86_amd64
			)
       ) else (
            echo.Error: Cannot setup Visual Studio 2009 environment.  Please
            echo.make sure VS90COMNTOOLS is defined in the environment.
            exit /b 1
        )
        
    ) else (
		if not defined hdf5_ivf101 (
			echo.with Intel Visual Fortran 11.1
			
			if defined ifort_compiler111 (
				rem This sets the Intel Fortran 11.1 environment, as well as
				rem setting the appropriate Visual Studio environment
				
				if %hdf5_platform%==Win32 (
					call "%ifort_compiler111%\Bin\IA32\ifortvars_ia32.bat"

				) else (

					call "%ifort_compiler111%\Bin\intel64\ifortvars_intel64.bat"
				)
			) else (
				echo.Error: Cannot setup Intel Fortran 11.1 environment.  Please
				echo.make sure IFORT_COMPILER111 is defined in the environment.
				exit /b 1
			)
			
		) else (
			echo.with Intel Visual Fortran 10.1
		
			if defined ifort_compiler10 (
				rem This sets the Intel Fortran 10.1 environment, as well as
				rem setting the appropriate Visual Studio environment
				
				if %hdf5_platform%==Win32 (
					call "%ifort_compiler10%\IA32\Bin\ifortvars.bat"

				) else (

					call "%ifort_compiler10%\em64t\Bin\ifortvars.bat"
				)
			) else (
				echo.Error: Cannot setup Intel Fortran 10.1 environment.  Please
				echo.make sure IFORT_COMPILER10 is defined in the environment.
				exit /b 1
			)
		)
    )
    
    rem Setup variables for our SLN files
    set C_SLN=%CD%\windows\examples\allexamples\allexamples.sln
    set CPP_SLN=%CD%\windows\c++\examples\allcppexamples\allcppexamples.sln
    set HL_SLN=%CD%\windows\hl\examples\allhlcexamples\allhlcexamples.sln
    rem We currently don't have HL C++ project files
    if defined hdf5_enablefortran (
        set FORT_SLN=%CD%\windows\fortran\examples\allf90examples\allf90examples.sln
        set HLFORT_SLN=%CD%\windows\hl\fortran\examples\allhlf90examples\allhlf90examples.sln
    ) else (
        set FORT_SLN=
        set HLFORT_SLN=
    )
    
    if defined hdf5_useenv (
        rem This will tell Visual Studio to use include, library, etc. paths
        rem defined by %INCLUDE% %LIBPATH%, etc.  Assume the user has already
        rem added external library paths to these variables.
        set ccflags=%ccflags% /useenv
    )

    exit /b 0


rem Build the HDF5 libraries.  By default, C and C++ libraries are built.

:build

    echo.Building HDF5

    echo.*****************************************************************************
    echo.                        Build HDF5 Examples
    echo.*****************************************************************************
    echo.

    rem TODO: Write code for each of these example sets
    rem Build both debug and release versions
    for %%a in (C CPP HL FORT HLFORT) do (
        if defined %%a_SLN (
            echo.**************************
            echo. Building %%a Examples
            echo.**************************
            for %%b in (%blddebug% %bldrelease%) do (
                echo.Building %%a %%b examples...
                devenv !%%a_SLN! %ccflags% /rebuild %%b
                if !errorlevel! neq 0 (
                    echo.HDF5 %%b %%a examples build failed
                    exit /b
                )
            )
        )
    )

    exit /b


rem Handle errors

:error

    rem For now, our error handling consists of setting nerrors and quitting
    echo.HDF5 examples build failed.
    set /a nerrors=%nerrors%+1
    goto end
    
    rem We'll never really get here, but we keep this line for consistency.
    exit /b


rem This is where the magic happens

:main

    call :parse_params %*
    if %errorlevel% neq 0 (
        rem Error case.
        echo.Error parsing parameters!
        goto error
    )
    
    call :setup
    if %errorlevel% neq 0 (
        echo.Error setting up examples build environment.
        goto error
    )

    call :build
    if %errorlevel% neq 0 (
        echo.Error building HDF5 examples!
        goto error
    )

    if "%nerrors%"=="0" (

        echo. All HDF5 example projects built successfully!

    )

    rem Fall through to end



:end

    popd

    endlocal & exit /b %nerrors%