0032323: Configuration - drop unused dependency from Xmu
[occt.git] / dox / build / build_3rdparty / building_3rdparty.md
1  Build 3rd-parties {#build_upgrade_building_3rdparty}
2 ==============================================
3 @tableofcontents
4
5 On Windows, the easiest way to install third-party libraries is to download archive with pre-built binaries from https://opencascade.com/content/3rd-party-components.
6 On Linux and OS X, it is recommended to use the version installed in the system natively.
7
8 @section dev_guides__building_3rdparty_win_1 Windows
9
10 This document presents guidelines for building third-party products used by Open CASCADE Technology (OCCT) and samples on Windows platform. It is assumed that you are already familiar with MS Visual Studio / Visual C++. 
11
12 You need to use the same version of MS Visual Studio for building all third-party products and OCCT itself, in order to receive a consistent set of run-time binaries. 
13
14 The links for downloading the third-party products are available at https://opencascade.com/content/3rd-party-components.
15
16 There are two types of third-party products used  by OCCT: 
17
18 * Mandatory  products: 
19         * Tcl/Tk 8.5 -- 8.6;
20         * FreeType 2.4.10 -- 2.5.3.
21 * Optional  products:
22         * TBB 3.x -- 4.x;
23         * FreeImage 3.14.1 -- 3.16.0;
24         * VTK 6.1.0.
25
26 It is recommended to create a separate new folder on your workstation, where you will unpack the downloaded archives of the third-party  products, and where you will build these products (for example, *c:\\occ3rdparty*). 
27
28 Further in this document, this folder is referred to as *3rdparty*. 
29
30 @subsection dev_guides__building_3rdparty_win_2 Tcl/Tk
31
32 Tcl/Tk is required for DRAW test harness.
33
34 **Installation from sources: Tcl**
35   
36 Download the necessary archive from https://www.tcl.tk/software/tcltk/download.html and unpack it.
37   
38 1. In the *win* sub-directory, edit file *buildall.vc.bat*:
39
40    * Edit the line "call ... vcvars32.bat" to have correct path to the version of Visual Studio to be used for building, for instance:
41
42          call "%VS80COMNTOOLS%\vsvars32.bat"
43
44      If you are building 64-bit version, set environment accordingly, e.g.:
45
46          call "%VS80COMNTOOLS%\..\..\VC\vcvarsall.bat" amd64
47      
48    * Define variable *INSTALLDIR* pointing to directory where Tcl/Tk will be installed, e.g.:
49
50          set INSTALLDIR=D:\OCCT\3rdparty\tcltk-86-32
51
52    * Add option *install* to the first command line calling *nmake*:
53
54          nmake -nologo -f makefile.vc release htmlhelp install %1
55
56    * Remove second call to *nmake* (building statically linked executable)
57
58 2. Edit file *rules.vc* replacing line 
59
60        SUFX         = tsgx
61
62    by
63
64        SUFX         = sgx
65
66    This is to avoid extra prefix 't' in the library name, which is not recognized by default by OCCT build tools.
67
68
69 3. By default, Tcl uses dynamic version of run-time library (MSVCRT), which must be installed on the system where Tcl will be used.
70    You may wish to link Tcl library with static version of run-time to avoid this dependency.
71    For that:
72
73    * Edit file *makefile.vc* replacing strings "crt = -MD" by "crt = -MT"
74
75    * Edit source file *tclMain.c* (located in folder *generic*) commenting out forward declaration of function *isatty()*.
76
77
78 4. In the command prompt, run *buildall.vc.bat*
79
80    You might need to run this script twice to have *tclsh* executable installed; check subfolder *bin* of specified installation path to verify this.
81
82 5. For convenience of use, we recommend making a copy of *tclsh* executable created in subfolder *bin* of *INSTALLDIR* and named with Tcl version number suffix, as *tclsh.exe* (with no suffix)
83
84        > cd D:\OCCT\3rdparty\tcltk-86-32\bin
85        > cp tclsh86.exe tclsh.exe
86
87 **Installation from sources: Tk**
88   
89 Download the necessary archive from https://www.tcl.tk/software/tcltk/download.html and unpack it.
90
91 Apply the same steps as described for building Tcl above, with the same INSTALLDIR.
92 Note that Tk produces its own executable, called *wish*. 
93
94 You might need to edit default value of *TCLDIR* variable defined in *buildall.vc.bat* (should be not necessary if you unpack both Tcl and Tk sources in the same folder).
95
96 @subsection dev_guides__building_3rdparty_win_2_2 FreeType
97
98 FreeType is required for text display in a 3D viewer. You can download its sources from https://sourceforge.net/projects/freetype/files/
99
100 ### The building procedure
101
102 1. Unpack the downloaded archive of FreeType product into the *3rdparty*  folder. As a result, you will get a folder named, for example, *3rdparty\\freetype-2.4.10*.  Further in this document, this folder is referred to as *freetype*. 
103    
104 2. Open the solution file *freetype\\builds\\win32\\vc20xx\\freetype.sln*  in Visual Studio. Here *vc20xx* stands for your version of Visual Studio. 
105
106 3. Select the configuration to build: either Debug or Release. 
107
108 4. Build  the *freetype* project. 
109
110    As a result, you will get a  freetype import library (.lib) in the *freetype\\obj\\win32\\vc20xx*  folder.  
111
112
113 5. If you build FreeType for a 64 bit platform, select in the main menu **Build - Configuration Manager**  and add *x64* platform to the solution configuration by copying the settings from Win32 platform: 
114
115    @figure{/build/build_3rdparty/images/3rdparty_image001.png}
116
117    Update the value of the Output File for  x64 configuration: 
118
119    @figure{/build/build_3rdparty/images/3rdparty_image003.png}
120
121    Build the *freetype* project. 
122
123    As a result, you will obtain a 64 bit import library (.lib) file in the *freetype\\x64\\vc20xx*  folder. 
124
125    To build FreeType as a dynamic library (.dll) follow steps 6, 7 and 8 of this procedure. 
126
127 6. Open menu Project-> Properties-> Configuration  Properties-> General and change option **Configuration Type** to *Dynamic  Library (.dll)*. 
128 7. Edit file *freetype\\include\\freetype\\config\\ftoption.h*:  
129   
130    in line 255, uncomment the definition of macro *FT_EXPORT* and change it as follows: 
131
132        #define FT_EXPORT(x)   __declspec(dllexport) x 
133
134 8. Build  the *freetype* project. 
135
136    As a result, you will obtain the files of the import  library (.lib) and the dynamic library (.dll)   in folders <i>freetype  \\objs\\release</i> or <i>\\objs\\debug </i>. 
137    
138    If you build for a 64 bit platform, follow step 5 of the procedure. 
139
140    To facilitate the use of FreeType libraries in OCCT with minimal adjustment of build procedures, it is recommended to copy the include files and libraries of FreeType into a separate folder, named according to the pattern: *freetype-compiler-bitness-building mode*, where: 
141    * **compiler** is *vc8* or *vc9* or *vc10* or *vc11*; 
142    * **bitness**  is *32* or *64*;
143    * **building mode** is *opt* (for Release) or *deb* (for Debug). 
144     
145    The *include* subfolder should be copied as is, while libraries should be renamed to *freetype.lib* and *freetype.dll* (suffixes removed) and placed to subdirectories *lib *and  *bin*, respectively. If the Debug configuration is built, the Debug libraries should be put into subdirectories *libd* and *bind*. 
146
147
148 @subsection dev_guides__building_3rdparty_win_3_1 TBB
149
150 This third-party product is installed with binaries 
151 from the archive that can be downloaded from https://github.com/intel/tbb.
152 Go to the **Download** page, find the  release version you need  (e.g. *tbb30_018oss*) and pick the archive for Windows  platform. 
153
154 Unpack the downloaded  archive of TBB product into the *3rdparty* folder. 
155
156 Further in this document,  this folder is referred to as *tbb*. 
157
158 @subsection dev_guides__building_3rdparty_win_3_3 FreeImage
159
160 This third-party product should be built as a dynamically loadable library (.dll file). 
161 You can download its sources from 
162 https://sourceforge.net/projects/freeimage/files/Source%20Distribution/
163
164 ### The building procedure: 
165
166 1. Unpack the  downloaded archive of FreeImage product into *3rdparty* folder. 
167   
168    As a result, you should have a folder named *3rdparty\\FreeImage*. 
169   
170    Rename it according to the rule: *freeimage-platform-compiler-building  mode*, where 
171    
172    * **platform**  is *win32* or *win64*; 
173    * **compiler**  is *vc8* or *vc9* or *vc10* or *vc11*; 
174    * **building  mode** is *opt* (for release) or *deb* (for debug) 
175
176    Further in this  document, this folder is referred to as *freeimage*. 
177
178 2. Open the solution file *freeimage\\FreeImage.*.sln* in your Visual Studio. 
179   
180    If you use a Visual Studio version higher than VC++ 2008, apply conversion of the workspace. 
181    Such conversion should be suggested automatically by Visual  Studio. 
182     
183 3. Select a  configuration to build. 
184
185    - Choose **Release**  if you are building Release binaries. 
186    - Choose **Debug** if you are building  Debug binaries. 
187
188    *Note:* 
189
190    If you want to  build a debug version of FreeImage binaries then you need to rename the following files in FreeImage and FreeimagePlus projects:
191    
192    Project -> Properties -> Configuration Properties -> Linker -> General -> Output File
193
194        FreeImage*d*.dll  to FreeImage.dll 
195        FreeImagePlus*d*.dll to FreeImagePlus.dll 
196
197    Project -> Properties -> Configuration Properties -> Linker -> Debugging-> Generate Program Database File
198
199        FreeImage*d*.pdb  to FreeImage.pdb 
200        FreeImagePlus*d*.pdb to FreeImagePlus.pdb 
201
202    Project -> Properties -> Configuration Properties -> Linker -> Advanced-Import Library
203
204        FreeImage*d*.lib  to FreeImage.lib 
205        FreeImagePlus*d*.lib  to FreeImagePlus.lib 
206
207    Project -> Properties -> Configuration Properties -> Build Events -> Post -> Build Event -> Command Line 
208
209        FreeImage*d*.dll     to FreeImage.dll 
210        FreeImage*d*.lib     to FreeImage.lib 
211        FreeImagePlus*d*.dll to FreeImagePlus.dll 
212        FreeImagePlus*d*.lib to FreeImagePlus.lib 
213
214    Additionally, rename in project FreeImagePlus 
215    
216    Project -> Properties -> Configuration  Properties -> Linker -> Input -> Additional Dependencies 
217
218        from FreeImage*d*.lib to FreeImage.lib 
219
220 4. Select a platform to build. 
221
222    - Choose *Win32* if you are building for a 32 bit platform. 
223    - Choose *x64* if you are building for a 64 bit platform. 
224
225 5. Start the building process. 
226
227    As a result, you should have the  library files of FreeImage product  in *freeimage\\Dist* folder (*FreeImage.dll* and *FreeImage.lib*) and in *freeimage\\Wrapper\\FreeImagePlus\\dist* folder (*FreeImagePlus.dll* and *FreeImagePlus.lib*).
228
229 @subsection dev_guides__building_3rdparty_win_3_4 VTK
230
231 VTK is an open-source, freely available software system for 3D computer graphics, image processing and visualization. VTK Integration Services component provides adaptation functionality for visualization of OCCT topological shapes by means of VTK library.
232
233 ### The building procedure:
234
235 1. Download the necessary archive from https://www.vtk.org/VTK/resources/software.html and unpack it into *3rdparty* folder.
236
237    As a result, you will get a folder named, for example, <i>3rdparty\VTK-6.1.0.</i>
238
239    Further in this document, this folder is referred to as *VTK*.
240
241 2. Use CMake to generate VS projects for building the library:
242    - Start CMake-GUI and select VTK folder as source path, and the folder of your choice for VS project and intermediate build data.
243    - Click **Configure**.
244    - Select the VS version to be used from the ones you have installed (we recommend using VS 2010) and the architecture (32 or 64-bit).
245    - Generate VS projects with default CMake options. The open solution *VTK.sln* will be generated in the build folder.
246
247 3. Build project VTK in Release mode.
248
249
250 @section build_3rdparty_linux Linux
251
252 This document presents additional guidelines for building third-party 
253 products used by Open CASCADE Technology and samples on Linux platform. 
254
255 The links for downloading the third-party products are available on the web site at 
256 https://opencascade.com/content/3rd-party-components.
257
258 There are two types of third-party products, which are  necessary to build OCCT: 
259   
260 * Mandatory  products: 
261         * Tcl/Tk 8.5 - 8.6;  
262         * FreeType 2.4.10 - 2.5.3;
263 * Optional  products: 
264         * TBB 3.x - 4.x;
265         * FreeImage 3.14.1 - 3.16.0;
266         * VTK 6.1.0.
267
268 @subsection dev_guides__building_3rdparty_linux_4 Installation From Official Repositories
269
270 **Debian-based distributives**
271
272 All 3rd-party products required for building of OCCT could be installed
273 from official repositories. You may install them from console using apt-get utility:
274
275     sudo apt-get install tcllib tklib tcl-dev tk-dev libfreetype-dev libx11-dev libgl1-mesa-dev libfreeimage-dev rapidjson-dev
276
277 Building is possible with C++ compliant compiler:
278
279     sudo apt-get install g++
280
281 @subsection dev_guides__building_3rdparty_linux_2_1 Tcl/Tk 
282
283 Tcl/Tk is required for DRAW test harness. 
284
285 **Installation from sources: Tcl**
286   
287 Download the necessary archive from https://www.tcl.tk/software/tcltk/download.html and unpack it.
288   
289 1. Enter the unix sub-directory of the directory where the Tcl source  files are located <i>(TCL_SRC_DIR)</i>. 
290
291        cd TCL_SRC_DIR/unix   
292
293 2. Run the *configure* command:
294
295        configure --enable-gcc  --enable-shared --enable-threads --prefix=TCL_INSTALL_DIR   
296
297    For a 64 bit platform also add <i>--enable-64bit</i> option to the command line. 
298   
299 3. If the configure command has finished successfully, start  the building process:
300   
301        make   
302
303 4. If building is finished successfully, start the installation of Tcl. 
304    All binary and service files of the product will be copied to the directory defined by *TCL_INSTALL_DIR* 
305
306        make install   
307
308 **Installation from sources: Tk**
309   
310 Download the necessary archive from https://www.tcl.tk/software/tcltk/download.html and unpack it.
311   
312 1. Enter the unix sub-directory of the directory where the Tk source files are located <i>(TK_SRC_DIR)</i> 
313
314        cd TK_SRC_DIR/unix   
315
316 2. Run the configure command, where <i>TCL_LIB_DIR</i> is *TCL_INSTALL_DIR/lib*.
317
318        configure --enable-gcc  --enable-shared --enable-threads --with-tcl=TCL_LIB_DIR  --prefix=TK_INSTALL_DIR   
319
320    For a 64 bit platform also add <i>--enable-64bit</i> option to the  command line. 
321
322 3. If the configure command has finished successfully, start the building process: 
323
324        make   
325
326 4. If the building has finished successfully, start the installation of Tk. 
327    All binary and service files of the product will be copied 
328    to the directory defined by *TK_INSTALL_DIR* (usually it is *TCL_INSTALL_DIR*) 
329
330        make install   
331
332 @subsection dev_guides__building_3rdparty_linux_2_2 FreeType
333
334 FreeType is required for text display in the 3D viewer. 
335 Download the necessary archive from https://sourceforge.net/projects/freetype/files/ and unpack it.
336   
337 1. Enter the directory where the source files of FreeType  are located <i>(FREETYPE_SRC_DIR)</i>. 
338
339        cd FREETYPE_SRC_DIR   
340
341 2. Run the *configure* command: 
342   
343        configure  --prefix=FREETYPE_INSTALL_DIR   
344
345    For a 64 bit platform also add <i>CFLAGS='-m64 -fPIC'  CPPFLAGS='-m64 -fPIC'</i> option to the command line. 
346     
347 3. If the *configure* command has finished successfully, start  the building process: 
348
349        make   
350
351 4. If the building has finished successfully, start the installation of FreeType. 
352    All binary and service files of the product will be copied to the directory defined by *FREETYPE_INSTALL_DIR* 
353     
354        make install   
355
356     
357 @subsection dev_guides__building_3rdparty_linux_3_1 TBB
358
359 This third-party product is  installed with binaries from the archive that can be downloaded from https://github.com/intel/tbb.
360 Go to the **Download** page, find the  release version you need and pick the archive for Linux platform.
361 To install, unpack the downloaded archive of TBB product.
362
363 @subsection dev_guides__building_3rdparty_linux_3_3 FreeImage
364
365 Download the necessary archive from https://sourceforge.net/projects/freeimage/files/Source%20Distribution/
366 and unpack it. The directory with unpacked sources is  further referred to as *FREEIMAGE_SRC_DIR*. 
367   
368 1. Modify *FREEIMAGE_SRC_DIR/Source/OpenEXR/Imath/ImathMatrix.h*: 
369    In line 60 insert the following: 
370
371        #include string.h   
372
373 2. Enter the directory where the source files of FreeImage are located <i>(FREEIMAGE_SRC_DIR)</i>. 
374   
375        cd FREEIMAGE_SRC_DIR   
376
377 3. Run the building process 
378   
379        make   
380
381 4. Run the installation process 
382
383    a. If you have the permission to write into directories <i>/usr/include</i> and <i>/usr/lib</i>, run the following command: 
384
385           make install   
386    b. If you do not have this permission, you need to modify file *FREEIMAGE_SRC_DIR/Makefile.gnu*: 
387   
388       Change lines 7-9 from:
389   
390           DESTDIR ?= /   
391           INCDIR  ?= $(DESTDIR)/usr/include   
392           INSTALLDIR  ?= $(DESTDIR)/usr/lib   
393
394       to: 
395
396           DESTDIR  ?= $(DESTDIR)   
397           INCDIR  ?= $(DESTDIR)/include   
398           INSTALLDIR  ?= $(DESTDIR)/lib   
399
400       Change lines 65-67 from: 
401
402           install  -m 644 -o root -g root $(HEADER) $(INCDIR)   
403           install  -m 644 -o root -g root $(STATICLIB) $(INSTALLDIR)   
404           install  -m 755 -o root -g root $(SHAREDLIB) $(INSTALLDIR)   
405   
406       to:
407
408           install  -m 755 $(HEADER) $(INCDIR)   
409           install  -m 755 $(STATICLIB) $(INSTALLDIR)   
410           install  -m 755 $(SHAREDLIB) $(INSTALLDIR)
411
412       Change line 70 from: 
413
414           ldconfig
415
416       to:
417   
418           \#ldconfig   
419     
420    Then run the installation process by the following command: 
421
422         make DESTDIR=FREEIMAGE_INSTALL_DIR  install   
423
424 5. Clean temporary files
425
426         make clean
427
428 @subsection dev_guides__building_3rdparty_linux_3_4 VTK
429
430 You can download VTK sources from https://www.vtk.org/VTK/resources/software.html
431
432 ### The building procedure:
433
434 Download the necessary archive from https://www.vtk.org/VTK/resources/software.html and unpack it.
435
436 1. Install or build *cmake* product from the source file.
437 2. Start *cmake* in GUI mode with the directory where the source files of *VTK* are located:
438
439        ccmake VTK_SRC_DIR
440
441    * Press <i>[c]</i> to make the  initial configuration
442    * Define the necessary options in *VTK_INSTALL_PREFIX*
443    * Press <i>[c]</i> to make the final  configuration
444    * Press <i>[g]</i> to generate  Makefile and exit
445
446 3. Start the building of VTK:
447
448        make
449
450 4. Start the installation of VTK. Binaries will be installed according to the *VTK_INSTALL_PREFIX* option.
451
452        make install
453
454 @section build_3rdparty_macos Mac OS X
455
456 This document presents additional guidelines for building third-party products 
457 used by Open CASCADE Technology and samples on Mac OS X platform (10.6.4  and later). 
458
459 The links for downloading the third-party products are available at https://opencascade.com/content/3rd-party-components.
460
461 There are two types of third-party products, which are  necessary to build OCCT: 
462   
463 * Mandatory  products: 
464         * Tcl/Tk 8.5 - 8.6;
465         * FreeType 2.4.10 - 2.5.3.
466 * Optional  products: 
467         * TBB 3.x - 4.x;
468         * FreeImage 3.14.1 - 3.16.0
469   
470
471 @subsection dev_guides__building_3rdparty_osx_2_1 Tcl/Tk 8.5 
472
473 Tcl/Tk is required for DRAW test harness. Version 8.5 or  8.6 can be used with OCCT. 
474
475 **Installation from sources: Tcl 8.5**
476
477 Download the necessary archive from https://www.tcl.tk/software/tcltk/download.html and unpack it.
478
479 1. Enter the *macosx* sub-directory of the directory where the Tcl source files are located <i>(TCL_SRC_DIR)</i>. 
480
481        cd TCL_SRC_DIR/macosx   
482
483 2. Run the *configure* command 
484
485        configure --enable-gcc  --enable-shared --enable-threads --prefix=TCL_INSTALL_DIR   
486
487    For a 64 bit platform also add <i>--enable-64bit</i> option to the command line. 
488
489 3. If the *configure* command has finished successfully, start the building process 
490
491        make   
492   
493 4. If building is finished successfully, start the installation of Tcl. 
494    All binary and service files of the product will be copied to the directory defined by *TCL_INSTALL_DIR*. 
495
496        make install   
497
498 **Installation from sources: Tk 8.5**
499
500 Download the necessary archive from https://www.tcl.tk/software/tcltk/download.html and unpack it.
501
502 1. Enter the *macosx* sub-directory of the directory where the  source files of Tk are located <i>(TK_SRC_DIR)</i>. 
503
504        cd TK_SRC_DIR/macosx   
505
506 2. Run the *configure* command, where TCL_LIB_DIR is  TCL_INSTALL_DIR/lib 
507
508        configure --enable-gcc --enable-shared --enable-threads --with-tcl=TCL_LIB_DIR --prefix=TK_INSTALL_DIR   
509
510         For a 64 bit platform also add <i>--enable-64bit</i> option to the  command line. 
511
512 3. If the *configure* command has finished successfully, start the building process:
513
514        make   
515
516 4. If the building has finished successfully, start the  installation of Tk. All binary and service files of the product will be copied to the directory defined by *TK_INSTALL_DIR* (usually it is TCL_INSTALL_DIR) 
517
518        make install   
519
520 @subsection dev_guides__building_3rdparty_osx_2_2 FreeType 2.4.10
521   
522 FreeType is required for text display in the 3D viewer. 
523
524 Download the necessary archive from https://sourceforge.net/projects/freetype/files/ and unpack it.
525
526 1. Enter the directory where the source files of FreeType  are located <i>(FREETYPE_SRC_DIR)</i>. 
527
528        cd FREETYPE_SRC_DIR   
529
530 2. Run the *configure* command 
531   
532        configure  --prefix=FREETYPE_INSTALL_DIR   
533
534    For a 64 bit platform also add <i>CFLAGS='-m64 -fPIC'  CPPFLAGS='-m64 -fPIC'</i> option to the command line. 
535
536 3. If the *configure* command has finished successfully, start  the building process 
537
538        make   
539
540 4. If building has finished successfully, start the installation of FreeType. 
541    All binary and service files of the product will be copied to the directory defined by *FREETYPE_INSTALL_DIR*.
542
543        make install   
544     
545 @subsection dev_guides__building_3rdparty_osx_3_1 TBB 3.x or 4.x
546
547 This third-party product is installed with binaries from the archive 
548 that can be downloaded from https://github.com/intel/tbb.
549 Go to the **Download** page, find the release version you need (e.g. *tbb30_018oss*) 
550 and  pick the archive for Mac OS X platform. 
551 To install, unpack the downloaded archive of TBB 3.0 product (*tbb30_018oss_osx.tgz*).
552
553 @subsection dev_guides__building_3rdparty_osx_3_3 FreeImage 3.14.1 or 3.15.x
554
555 Download the necessary archive from 
556 https://sourceforge.net/projects/freeimage/files/Source%20Distribution/
557 and unpack it. The directory with unpacked sources is  further referred to as *FREEIMAGE_SRC_DIR*.  
558
559 Note that for building FreeImage on Mac OS X 10.7 you should replace *Makefile.osx* 
560 in *FREEIMAGE_SRC_DIR* by the corrected file, which you can find in attachment to issue #22811 in OCCT Mantis bug tracker 
561 (https://tracker.dev.opencascade.org/file_download.php?file_id=6937&type=bug).
562
563 1. If you build FreeImage 3.15.x you can skip this  step. 
564    Modify <i>FREEIMAGE_SRC_DIR/Source/OpenEXR/Imath/ImathMatrix.h:</i> 
565   
566    In line 60 insert the following: 
567
568        #include string.h 
569
570    Modify <i>FREEIMAGE_SRC_DIR/Source/FreeImage/PluginTARGA.cpp:</i> 
571   
572    In line 320 replace: 
573
574        SwapShort(value); 
575
576    with: 
577
578        SwapShort(&value); 
579
580 2. Enter the directory where the source files of FreeImage  are located <i>(FREEIMAGE_SRC_DIR)</i>. 
581
582        cd FREEIMAGE_SRC_DIR 
583
584 3. Run the building process 
585
586        make   
587
588 4. Run the installation process 
589    
590    1. If you have the permission to write into <i>/usr/local/include</i>  and <i>/usr/local/lib</i> directories, run the following command: 
591
592           make install   
593
594    2. If you do not have this permission, you need to modify file *FREEIMAGE_SRC_DIR/Makefile.osx*: 
595
596       Change line 49 from:     
597
598           PREFIX ?= /usr/local
599
600       to:
601    
602           PREFIX  ?= $(PREFIX) 
603
604       Change lines 65-69 from: 
605
606           install -d -m 755 -o  root -g wheel $(INCDIR) $(INSTALLDIR) 
607           install  -m 644 -o root -g wheel $(HEADER) $(INCDIR) 
608           install  -m 644 -o root -g wheel $(SHAREDLIB) $(STATICLIB) $(INSTALLDIR) 
609           ranlib  -sf $(INSTALLDIR)/$(STATICLIB) 
610           ln  -sf $(SHAREDLIB) $(INSTALLDIR)/$(LIBNAME) 
611     
612       to: 
613
614           install  -d $(INCDIR) $(INSTALLDIR) 
615           install  -m 755 $(HEADER) $(INCDIR) 
616           install  -m 755 $(STATICLIB) $(INSTALLDIR) 
617           install  -m 755 $(SHAREDLIB) $(INSTALLDIR) 
618           ln  -sf $(SHAREDLIB) $(INSTALLDIR)/$(VERLIBNAME)  
619           ln  -sf $(VERLIBNAME) $(INSTALLDIR)/$(LIBNAME)
620
621       Then run the installation process by the following command: 
622   
623           make PREFIX=FREEIMAGE_INSTALL_DIR  install 
624   
625 5. Clean temporary files 
626   
627        make clean