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
|
flext - C++ layer for Max/MSP and pd (pure data) externals
Copyright (c) 2001-2005 Thomas Grill (gr@grrrr.org)
For information on usage and redistribution, and for a DISCLAIMER OF ALL
WARRANTIES, see the file, "license.txt," in this distribution.
----------------------------------------------------------------------------
At the moment this is more like a sketchboard, but i'll promise to bring some
order into it some fine day in the not too distant future.
----------------------------------------------------------------------------
Build scripts
=============
Depending on platform the build process is run with
build.sh
or
build.bat
Arguments: PLATFORM SYSTEM COMPILER {TARGET} {definitions}
PLATFORM: win / lnx / mac
SYSTEM: pd / max
COMPILER: msvc / gcc / mingw / cygwin / bcc / icc
TARGET: (default is all)
all, build - build package in default style
install - install package
clean - clean build products
config - test if configuration needs refreshing
or
build-MODE-TYPE
install-MODE-TYPE
clean-MODE-TYPE
with
MODE: default, all, release, debug
TYPE: default, all, single, multi, shared
Additional definitions can be passed to the make program
like
"PKGINFO=info.txt" (defines new filename for package information)
or
"PKGINFO=" (package information will be skipped - only for config target)
For more macro names, see below
For each of the supported combinations of PLATFORM, SYSTEM and COMPILER
a MAKE program has been chosen, normally the one that comes with the compiler.
For gcc it is GNU make (gnumake)
For msvc it is Microsoft make (nmake)
For bcc it is Borland make (bmake)
Package info (package.txt)
==========================
Package information contains vital information for the build process.
Obligatory are only:
NAME: resulting filename of the build product
SRCS: list of source files
Normally also used are:
HDRS: used header files, which SRCS files are dependent upon
SRCDIR: source folder (relative to project folder), default is .
Other settings:
PRECOMPILE: prefix header file (in SRCDIR) for all source files,
will be precompiled if supported by the compiler
BUILDCLASS: can currently be flext or ext, default is ext.
flext will build the flext system
ext will build a flext-based external
BUILDMODE: release or debug, default is release
if release, optimization flags will be used
if debug, debug information will be generated
BUILDTYPE: single, multi or shared, default is single
if single, it will be linked against the single-threaded static flext library
if multi, it will be linked against the multi-threaded static flext library
if shared, it will be linked against the shared flext library
BUILDDIR: relative folder with additional build settings
Additional build settings (BUILDDIR)
====================================
If BUILDDIR is defined, all PLATFORM-SYSTEM-COMPILER combinations to support
must are mirrored by the respective .def and .inc files in the BUILDDIR.
config-PLATFORM.def files (e.g. config-lnx.def) :
These files can contain additional macro definitions, that are private
to the project.
The definitions should be strictly in the form SETTING=value, without any
make-specific macros etc.
The .def files work as templates that get copied to a user-editable
config.txt file when the build process is first started.
MAKE-PLATFORM-COMPILER.inc files
(e.g. gnumake-lnx-gcc.inc or nmake-win-msvc.inc):
These files (which are no considered to be edited by the user) can contain
specific modifications to compiler flags, include file paths etc.
For gnumake this would e.g. be
INCPATH += -I/usr/local/include/python2.3
for nmake or bmake e.g.
INCPATH = $(INCPATH) -I"c:\program files\Python2.3\include"
Structure of build system
=========================
The build system has several levels of information, which are evaluated in the
following order (see also buildsys/MAKE-sub.mak)
Project level:
- PKGINFO file (e.g. package.txt)
- USRCONFIG file (e.g. config.txt)
- USRMAKE file (e.g. build/gnumake-lnx-gcc.inc)
General definitions (in buildsys):
- MAKE.inc (e.g. buildsys/gnumake.inc)
contains evaluation of flext library name, build directory etc.
- MAKE-BUILDCLASS.inc (e.g. buildsys/gnumake-ext.inc)
contains some more flag settings
Real-time-system-dependent definitions (in buildsys/PLATFORM/SYSTEM):
- MAKE-COMPILER.inc (e.g. buildsys/lnx/pd/gnumake-gcc.inc)
contains general real-time-system dependent info (e.g. paths, FLEXT_SYS setting)
- MAKE-COMPILER-BUILDCLASS.inc (e.g. buildsys/lnx/pd/gnumake-gcc-ext.inc)
contains specific real-time-system dependent info (e.g. extension of binary)
Platform-dependent definitions (in buildsys/PLATFORM):
- MAKE-COMPILER.inc (e.g. buildsys/lnx/gnumake-gcc.inc)
contains general platform-specific flags
- MAKE-COMPILER-BUILDCLASS.inc (e.g. buildsys/lnx/gnumake-gcc-ext.inc)
contains the actual make targets (_build_,_clean_ and _install_)
Macro names
===============
PKGINFO - filename for package information (must reside in project folder)
CFLAGS - compiler flags
LDFLAGS - linker flags
INCPATH - include file path (must come with e.g. -I )
LIBPATH - library path (must come with e.g. -L )
LIBS - libraries to link in (must come with e.g. -l )
|