634
|
1 This file is a complement to "INSTALL", which contains instructions
|
|
2 that are specific to Linux.
|
|
3
|
|
4
|
|
5 Static linking for Linux
|
|
6 ========================
|
|
7
|
|
8 The most simple way of building Orthanc under Linux consists in
|
|
9 statically linking against all the third-party dependencies. In this
|
|
10 case, the system-wide libraries will not be used. The build tool
|
|
11 (CMake) will download the sources of all the required packages and
|
|
12 automatically compile them. This process should work on all the Linux
|
|
13 distributions.
|
|
14
|
|
15
|
|
16 To build binaries with debug information:
|
|
17
|
|
18 # cd ~/OrthancBuild
|
|
19 # cmake -DSTATIC_BUILD=ON -DCMAKE_BUILD_TYPE=Debug ~/Orthanc
|
|
20 # make
|
|
21 # make doc
|
|
22
|
|
23
|
|
24 To build a release version:
|
|
25
|
|
26 # cd ~/OrthancBuild
|
|
27 # cmake -DSTATIC_BUILD=ON -DCMAKE_BUILD_TYPE=Release ~/Orthanc
|
|
28 # make
|
|
29 # make doc
|
|
30
|
|
31
|
|
32 Note: When the "STATIC_BUILD" option is set to "ON", the build tool
|
|
33 will not ask you the permission to download packages from the
|
|
34 Internet.
|
|
35
|
|
36
|
|
37 Use system-wide libraries under Linux
|
|
38 =====================================
|
|
39
|
|
40 Under Linux, by default, Orthanc links against the shared libraries of
|
|
41 your system (the "STATIC_BUILD" option is set to "OFF"). This greatly
|
|
42 speeds up the compilation. This is also required when building
|
|
43 packages for Linux distributions. Because using system libraries is
|
|
44 the default behavior, you just have to use:
|
|
45
|
|
46 # cd ~/OrthancBuild
|
|
47 # cmake -DCMAKE_BUILD_TYPE=Debug ~/Orthanc
|
|
48 # make
|
|
49
|
|
50
|
|
51 However, on some Linux distributions, it is still required to download
|
|
52 and static link against some third-party dependencies, e.g. when the
|
|
53 system-wide library is not shipped or is outdated. Because of
|
|
54 difference in the packaging of the various Linux distribution, it is
|
|
55 also sometimes required to fine-tune some options.
|
|
56
|
|
57 You will find below build instructions for specific Linux
|
|
58 distributions. Distributions tagged by "SUPPORTED" are tested by
|
|
59 Sébastien Jodogne. Distributions tagged by "CONTRIBUTED" come from
|
|
60 Orthanc users.
|
|
61
|
|
62
|
|
63 SUPPORTED - Debian Squeeze (6.0)
|
|
64 --------------------------------
|
|
65
|
|
66 # sudo apt-get install build-essential unzip cmake mercurial \
|
635
|
67 uuid-dev libcurl4-openssl-dev liblua5.1-0-dev \
|
|
68 libgoogle-glog-dev libpng-dev \
|
|
69 libsqlite3-dev libssl-dev zlib1g-dev
|
634
|
70
|
|
71 # cmake -DALLOW_DOWNLOADS=ON \
|
|
72 -DUSE_SYSTEM_BOOST=OFF \
|
|
73 -DUSE_SYSTEM_DCMTK=OFF \
|
|
74 -DUSE_SYSTEM_MONGOOSE=OFF \
|
|
75 -DUSE_SYSTEM_JSONCPP=OFF \
|
|
76 ~/Orthanc
|
|
77
|
|
78
|
635
|
79 SUPPORTED - Ubuntu 12.10
|
|
80 ------------------------
|
|
81
|
|
82 # sudo apt-get install build-essential unzip cmake mercurial \
|
|
83 uuid-dev libcurl4-openssl-dev liblua5.1-0-dev \
|
|
84 libgoogle-glog-dev libgtest-dev libpng-dev \
|
|
85 libsqlite3-dev libssl-dev zlib1g-dev \
|
|
86 libdcmtk2-dev libboost-all-dev
|
|
87
|
|
88 # cmake "-DDCMTK_LIBRARIES=wrap;oflog" \
|
|
89 -DALLOW_DOWNLOADS=ON \
|
|
90 -DUSE_SYSTEM_MONGOOSE=OFF \
|
|
91 -DUSE_SYSTEM_JSONCPP=OFF \
|
|
92 -DUSE_GTEST_DEBIAN_PACKAGE=ON \
|
|
93 ~/Orthanc
|
|
94
|
|
95
|
634
|
96
|
|
97 Other Linux distributions?
|
|
98 --------------------------
|
|
99
|
|
100 Please send us your build instructions (by a mail to
|
|
101 s.jodogne@gmail.com)!
|
|
102
|
|
103 You can find build instructions for Orthanc up to 0.7.0 on the
|
|
104 following Wiki page:
|
|
105 https://code.google.com/p/orthanc/wiki/LinuxCompilationUpTo070
|
|
106
|
|
107 These instructions will not work as such beyond Orthanc 0.7.0, but
|
|
108 they might give indications.
|
|
109
|
|
110
|
|
111
|
|
112
|
|
113 Using ccache
|
|
114 ============
|
|
115
|
|
116 Under Linux, you also have the opportunity to use "ccache" to
|
|
117 dramatically decrease the compilation time when rebuilding
|
|
118 Orthanc. This is especially useful for developers. To this end, you
|
|
119 would use:
|
|
120
|
|
121 # CC="ccache gcc" CXX="ccache g++" cmake ~/Orthanc [Options]
|