Blame view

README 8.38 KB
Michał Lenart authored
1
2
3
4
5
6
7

***************
Compilation - prerequisites
***************

This tutorial assumes that build process is performed on Linux 64bit machine (preferably from Debian/Ubuntu family).
Michał Lenart authored
8
sudo apt-get install build-essential autotools-dev python python-setuptools python-stdeb python-pip python-all-dev python-pyparsing devscripts libcppunit-dev acl
Michał Lenart authored
9
sudo pip install pyinstaller
Michał Lenart authored
10
Michał Lenart authored
11
For cross compiling:
Michał Lenart authored
12
--------------------
Michał Lenart authored
13
Michał Lenart authored
14
sudo apt-get install g++-multilib g++-mingw-w64 nsis libssl.0.9.8:i386
Michał Lenart authored
15
Michał Lenart authored
16
17
18
For cross compiling using buildAll.sh script:
---------------------------------------------
Michał Lenart authored
19
sudo apt-get install g++-multilib g++-mingw-w64 nsis libssl.0.9.8:i386 moreutils
Michał Lenart authored
20
Michał Lenart authored
21
For Java and Python bindings:
Michał Lenart authored
22
-----------------------------
Michał Lenart authored
23
sudo apt-get install default-jdk swig
Michał Lenart authored
24
Michał Lenart authored
25
Michał Lenart authored
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
Java and Python bindings with cross-compilation support:
--------------------------------------------------------
Download CMake 2.8.x (tested on 2.8.12.1).
Apply cmake-2.8.12..1-patch.diff on the sources.
Build and install CMake from patched sources.

Java and Python bindings without cross-compilation support:
-----------------------------------------------------------
sudo apt-get install cmake

***************
Compilation
***************
Create separate build directory in morfeusz root, run cmake and make in it:

mkdir build
cd build
cmake ..
make
Michał Lenart authored
46
***************
Michał Lenart authored
47
48
49
Testing
***************
Michał Lenart authored
50
To compile and run tests you must have cppunit library installed.
Michał Lenart authored
51
52
To test if everything is working type:
Michał Lenart authored
53
54
55
make
make package-java ### to also test Java wrapper
make package-python ### to also test Python wrapper
Michał Lenart authored
56
57
make test
Michał Lenart authored
58
If some tests fail, you can see errors by invoking:
Michał Lenart authored
59
60
61
62

ctest --output-on-failure

***************
Michał Lenart authored
63
64
65
66
67
68
69
Packaging
***************

Create packages for target platform:

make package
Michał Lenart authored
70
71
72
73
74
75
76
77
------------------------------
Note on building DEB packages:
------------------------------
Before running "make package" set default access rights on build directory 
in order to avoid "control-file-has-bad-permissions" lintian error:

setfacl -R -d -m o::r -m g::rx -m u::rwx .
Michał Lenart authored
78
79
80
81
82
83
84
85
Create packages with Java bindings for target platform:

make package-java

Create packages with Python bindings for target platform:

make package-python
Michał Lenart authored
86
87
88
89
Create packages with dictionary builder:

make package-builder
Michał Lenart authored
90
91
92
93
94
95
96
97
98
99
100
101
102
103
***************
Installation
***************

Install Morfeusz main program, C and C++ headers and libs:

make install

Install Python bindings:

make install-python

***************
Customizing build process
Michał Lenart authored
104
105
***************
Michał Lenart authored
106
Optional CMake variables:
Michał Lenart authored
107
Michał Lenart authored
108
CMAKE_BUILD_TYPE - manually set build type (possible values Debug, Release, RelWithDebInfo and MinSizeRel). 
Michał Lenart authored
109
Set to Debug if you want to include debugging symbols. Default value is "Release".
Michał Lenart authored
110
Michał Lenart authored
111
INPUT_TAGSET - tagset file
Michał Lenart authored
112
SEGMENT_RULES_FILE - segmentation rules file
Michał Lenart authored
113
114

INPUT_DICTIONARIES - comma-separated list of dictionary files (can use empty one from input/empty.txt)
Michał Lenart authored
115
116
ANALYZER_DICTIONARY_CPP - a file where analyzer embedded C++ dictionary file is read/written to
GENERATOR_DICTIONARY_CPP - a file where generator embedded C++ dictionary file is read/written to
Michał Lenart authored
117
SKIP_DICTIONARY_BUILDING - if set, the dictionary-building part of the build process is skipped
Michał Lenart authored
118
DEFAULT_DICT_NAME - default dictionary name
Michał Lenart authored
119
120
121
DEFAULT_DICT_DIR - a directory where dictionaries are read/written to
SKIP_DICTIONARY_BUILDING - do not build dictionaries. Use the ones provided by DEFAULT_DICT_DIR or ANALYZER/GENERATOR_DICTIONARY_CPP options.
EMBEDDED_DEFAULT_DICT - embed default dictionary into morfeusz library code (implicitly set for Windows and OSX builds).
Michał Lenart authored
122
CPACK_GENERATOR - manually set which package type to build (see http://www.cmake.org/Wiki/CMake:CPackPackageGenerators for available options)
Michał Lenart authored
123
DICT_VERSION - dictionary version
Michał Lenart authored
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

CMAKE_INSTALL_PREFIX - where to install morfeusz (on Linux default is /usr/local)
TARGET_DIR - a dir where packages built by CMake are put in

***************
Customizing build process - examples
***************
----------
Only build dictionary with default tagset and segmentation rules and given input data:
----------

cmake \
    -D INPUT_DICTIONARIES=/path/to/dict1.tab,/path/to/dict2.tab \
    -D DEFAULT_DICT_DIR=/path/to/dict/dir \
    -D DEFAULT_DICT_NAME=my_dictionary \
    ..
make dictionary

----------
Build and install in users home directory (on Linux):
----------
cmake \
    -D INPUT_DICTIONARIES=/path/to/dict1.tab,/path/to/dict2.tab \
    -D CMAKE_INSTALL_PREFIX=$HOME \
    -D DEFAULT_DICT_NAME=my_dictionary \
    ..
make
make install

----------
Build packages with embedded dictionary data (TGZ for all systems and installer for Windows).
Resulting packages will be put in current dir:
----------
cmake \
    -D INPUT_DICTIONARIES=/path/to/dict1.tab,/path/to/dict2.tab \
    -D DEFAULT_DICT_NAME=my_dictionary \
    -D EMBEDDED_DEFAULT_DICT=1 \
    ..
make
make package

----------
Build packages with dictionary data in separate files (creates only DEB on Linux).
Resulting package will be put in /path/to/target/dir:
----------
cmake \
    -D INPUT_DICTIONARIES=/path/to/dict1,/path/to/dict2 \
    -D DEFAULT_DICT_NAME=my_dictionary \
    -D TARGET_DIR=/path/to/target/dir \
    ..
make
make package
Michał Lenart authored
176
Michał Lenart authored
177
178
179
180
181
182
183
184
185
186
187
----------
Build DEB with dictionary "my_dictionary" (dependent on morfeusz2) but without executable, includes and shared lib:
----------
cmake \
    -D INPUT_DICTIONARIES=/path/to/dict1,/path/to/dict2 \
    -D DEFAULT_DICT_NAME=my_dictionary \
    -D DICT_VERSION=dict_version
    -D TARGET_DIR=/path/to/target/dir \
    ..
make dictionary-deb
Michał Lenart authored
188
Michał Lenart authored
189
190
191
192
193
194
195
196
197
198
199
200
201
**************************
Notes on cross-compilation
**************************

Copy Java JDK and Python libraries from target platform. Set JAVA_ROOT and PYTHON_ROOT in Toolchain files to match directories copied from target platform.

[Mac OS X 64bit] Libraries are at /System/Library/Frameworks/JavaVM.framework and /System/Library/Frameworks/Python.framework

[Windows 32 and 64 bit] usually at C:\Program Files\Java\jdk* and C:\Python27. You must also copy python27.dll from C:\Windows\System32 to Python27/libs directory.

[Linux 32bit] Java is usually at /usr/lib/jvm/default-java (alternatively you can download a package from Oracle website). The preferred way of obtaining Python is to compile it:
- compile latest version using ./configure --prefix=/some/directory/python
- copy contents of /some/directory/python to the build machine and set it as PYTHON_ROOT in Toolchain file
Michał Lenart authored
202
Michał Lenart authored
203
204
Create separate build directory, for example build-darwin.
Michał Lenart authored
205
206
207
Run cross-compilation:
----------------------
Michał Lenart authored
208
cmake -D CROSSMORFEUSZ_ROOT=<path_to_crossmorfeusz_dir> -DCMAKE_TOOLCHAIN_FILE=../toolchains/Toolchain-xxx.cmake ..
Michał Lenart authored
209
210
211
make
make package package-java package-python
Michał Lenart authored
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
Layout of crossmorfeusz directory:
----------------------------------

crossmorfeusz
  darwin64
    Python.framework
    JavaVM.framework
    x86_64-apple-darwin9
  windows32
    Java
    Python27
  windows64
    Java
    Python27
  linux32
    jdk1.7.0_45
    python  

Notes on Mac OS X cross-compilation:
------------------
Very special, very magic and ancient version of gcc OSX compiler is required (Apple is evil and does not support cross-compilation anymore). The best way to obtain it is to personally ask the authors (michal.lenart@ipipan.waw.pl, wolinski@ipipan.waw.pl). Once you get it, the compiler directory (x86_64-apple-darwin9) must be copied into /usr directory.
Michał Lenart authored
233
234
235
236
237


buildAll.sh script:
-------------------
./buildAll.sh /path/to/crossmorfeusz /path/to/dictionary1,/path/to/dictionary2,...
Michał Lenart authored
238
Michał Lenart authored
239
*************
Michał Lenart authored
240
Mac OS X
Michał Lenart authored
241
*************
Michał Lenart authored
242
243
244
245
246
247

## install xcode (using apple store)

# install brew
ruby -e "$(curl -fsSL https://raw.github.com/mxcl/homebrew/go/install)"
Michał Lenart authored
248
# install some other stuff
Michał Lenart authored
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
brew install svn
brew install swig
brew install make

# If you have Xcode 4.3 or newer the command line tools, such as make, are not installed by default. In Xcode preferences go to the "Downloads" tab and under "Components" push the "Install" button next to "Command Line Tools". After you have successfully downloaded and installed the command line tools you should also type the following command in the Terminal to make sure all your Xcode command line tools are switched to use the 4.3 versions:
#
#  sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer
#
# Once everything is successfully installed you should see make and other command line developer tools in /usr/bin.
#
# torrey.lyons http://stackoverflow.com/questions/11494522/installing-make-on-mac

# Must say everything is okay ("your system is ready to brew"):
brew doctor
Michał Lenart authored
264
265
266
267
*************
Windows
*************
Michał Lenart authored
268
Better cross-compile on Linux...