summaryrefslogtreecommitdiff
path: root/acprep
blob: 8181e8b9909d776c26231e95094c3e6336de0039 (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
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
#!/bin/sh

# acprep, version 3.0
#
# This script configures my ledger source tree on my Mac OS/X machine.  This
# is not necessary, however, since I keep all the files necessary for building
# checked in to the source tree.  Users can just type './configure && make'.
# This script simply sets up the compiler and linker flags for all the various
# build permutations I use for testing and profiling.

if [ -d .git ]; then
    # Make sure that all of the dependencies are available
    git submodule init
    git submodule update

    COMMIT=$(git describe --all --long | sed 's/heads\///')
else
    COMMIT=unknown
fi


echo "m4_define([VERSION_NUMBER], [$COMMIT])" > version.m4
sh autogen.sh


# configure the template files
if [ ! -f po/Makevars ]; then
    mv po/Makevars.template po/Makevars
fi
git ls-files '*.cc' '*.h' | egrep '^(src|python)/' > po/POTFILES.in

# regenerate aclocal.m4
aclocal -I m4


SWITCHES="--with-included-gettext"

if [ -z "$PYTHON_HOME" ]; then
    PYTHON_HOME="/usr"
fi
if [ -z "$PYTHON_VERSION" ]; then
    PYTHON_VERSION="2.5"
fi


BOOST_VERSION="1_38"
BOOST_SUFFIX=""
for lib in $(ls -1 /opt/local/lib/libboost_regex*.a \
                   /usr/local/lib/libboost_regex*.a 2> /dev/null \
             | sort -r)
do
    lib=$(basename "$lib")
    suffix=$(echo "$lib" | sed 's/libboost_regex-//' | sed 's/\.a//')
    if [ ! "$suffix" = "libboost_regex" ]; then
	echo "Discovered Boost suffix: --boost $suffix"
	BOOST_SUFFIX="-$suffix"
    fi
    break
done


USE_GLIBCXX_DEBUG=true
CXXFLAGS=""
ARCHFLAGS=""
LDFLAGS=""
LDARCHFLAGS=""


INCDIRS=""
for include in					\
    /usr/local/include				\
    /usr/local/include/boost-$BOOST_VERSION	\
    $PYTHON_HOME/include/python$PYTHON_VERSION	\
    /opt/local/include				\
    /sw/include
do
    if [ -d "$include" ]; then
	INCDIRS="$INCDIRS -isystem $include"
    fi
done

LIBDIRS=""
for lib in						\
    /usr/local/lib					\
    $PYTHON_HOME/lib					\
    $PYTHON_HOME/lib/python$PYTHON_VERSION/config	\
    /opt/local/lib					\
    /sw/lib
do
    if [ -d "$lib" ]; then
	LIBDIRS="$LIBDIRS -L$lib"
    fi
done


SYSTEM=$(uname -s)

if [ $SYSTEM = Linux ]; then
    if [ "$(uname -m)" = x86_64 ]; then
	SWITCHES="--disable-static"
    fi
    CXXFLAGS="-pthread"
elif [ $SYSTEM = Solaris ]; then
    CXXFLAGS="-pthreads"
elif [ $SYSTEM = Darwin ]; then
    ARCHFLAGS="-arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.5.sdk"
    LDARCHFLAGS="$ARCHFLAGS -Wl,-syslibroot,/Developer/SDKs/MacOSX10.5.sdk"
fi


# Building the command-line tool as a shared library is a luxury,
# since there are no clients except a GUI tool which might use it (and
# that is built again anyway by Xcode).
CPPFLAGS="$INCDIRS"
CXXFLAGS="$CXXFLAGS -pipe"
LDFLAGS="$LDFLAGS $LIBDIRS"
BUILD_DIR=false


# The following are options to prepare a developer tree of Ledger for
# building:
#
# --debug
#
#   Build with debugging information.  This doesn't slow things down by much,
#   but gives you useful stack traces to mention in your bug reports.
#   Recommended if you're not running a release version.
#
# --build PATH
#
#   Building the sources in PATH instead of in the source directory.  This
#   breaks pre-compiled headers, but keeps your source tree clean.
#
# --boost SUFFIX
#
#   Use the boost library with the given SUFFIX.  Check the Boost "Getting
#   Started" documentation for what the different suffixes are and what they
#   mean.  Usually you can see the available suffixes on your system using
#   something like this command:
#
#    $ ls /usr/local/lib/libboost_date_time*
#
#   Here's everything that's available on my machine right now:
#
#    ""      - dynamic optimized Boost library
#    d       - dynamic debug
#    s       - static optimized
#    sd      - static debug
#    mt      - multi-threaded optimized
#    mt-d    - multi-threaded debug
#    mt-s    - multi-threaded static optimized
#    mt-sd   - multi-threaded static debug
#
#   Since Ledger does not use threading, I recommend using the static
#   optimized library unless you wish to build with debugging enabled.  If you
#   want to do that, see the --devel switch below.
#
# --devel
#
#   This means you want to build like the developer does, which means:
#
#    * using pre-compiled headers
#    * with glibc debugging enabled
#    * static linking as much as possible
#
#   The glibc debugging is the only tricky part, since you must have Boost
#   compiled with _GLIBCXX_DEBUG defined also -- which it won't be on your
#   system by default.
#  
#   So, you have to roll your own set of Boost debug libraries in order to
#   support this.  I like this because it gives me the most amount of safety
#   and checking possible, which is great for testing.  Here's how I build a
#   super-debugging Boost:
#
#      src $ git clone git://repo.or.cz/boost.git
#      src $ git checkout svn/Version_$BOOST_VERSION
#      src $ cd boost
#    boost $ sudo bjam release --prefix=/usr/local/stow/boost_$BOOST_VERSION \
#                --build-dir=$HOME/Products/boost_$BOOST_VERSION --toolset=darwin \
#                architecture=combined install
#    boost $ sudo bjam debug --prefix=/usr/local/stow/boost_$BOOST_VERSION \
#                --build-dir=$HOME/Products/boost_$BOOST_VERSION --toolset=darwin \
#                architecture=combined define=_GLIBCXX_DEBUG=1 install
#    boost $ cd /usr/local/stow
#     stow $ stow boost_$BOOST_VERSION
#
#   Of course, you'll need MacPorts to do this, with both the "bjam" and "stow"
#   packages installed.
#
#   Lastly, you need to build cppunit by hand with GLIBCXX_DEBUG also, or else
#   you'll see UniTests crash in flames and none of the unit tests will run.
#  
#   Now you're ready to run acprep like this:
#  
#    $ ./acprep --devel --debug --boost sd
#
#   Or, as I do it:
#
#    $ ./myacprep
#
# --release
#
#   This is the opposite of --devel: it means you wish to build in a release
#   scenario, preparing a universal binary and building against the non-debug
#   versions of Boost and CppUnit.
#
# NOTE: I do not expect anyone but me to use --devel or --release, so don't be
# surprised if it doesn't work as advertised.  In that case, look for me in
# the #ledger channel on the IRC server irc.freenode.net.

DO_BUILD=false

while [ -n "$1" ]; do
  case "$1" in
    --pch)
	  USE_GLIBCXX_DEBUG=false

	  SWITCHES="$SWITCHES --enable-pch"

          # These can cause problems when run against a full set of headers,
          # but with PCH, they only apply to Ledger itself
	  CXXFLAGS="$CXXFLAGS -Wconversion"
	  CXXFLAGS="$CXXFLAGS -Wold-style-cast"

	  # g++ 4.0.1 cannot use PCH headers on OS X 10.5, so we must use a
	  # newer version.  However, it also means I can't use GLIBCXX_DEBUG.
	  if [ -f /opt/local/bin/g++-mp-4.3 ]; then
	      if [ -f /opt/local/bin/ccache ]; then
		  CC="ccache /opt/local/bin/gcc-mp-4.3"
		  CXX="ccache /opt/local/bin/g++-mp-4.3"
		  LD="ccache /opt/local/bin/g++-mp-4.3"
	      else
		  CC=/opt/local/bin/gcc-mp-4.3
		  CXX=/opt/local/bin/g++-mp-4.3
		  LD=/opt/local/bin/g++-mp-4.3
	      fi
	  elif [ -f /usr/bin/g++-4.2 ]; then
	      if [ -f /opt/local/bin/ccache ]; then
		  CC="ccache /usr/bin/gcc-4.2"
		  CXX="ccache /usr/bin/g++-4.2"
		  LD="ccache /usr/bin/g++-4.2"
	      else
		  CC=/usr/bin/gcc-4.2
		  CXX=/usr/bin/g++-4.2
		  LD=/usr/bin/g++-4.2
	      fi
	  fi
	  shift 1 ;;

    --devel)
	if [ $USE_GLIBCXX_DEBUG = true ]; then
	    CPPFLAGS="$CPPFLAGS -D_GLIBCXX_DEBUG=1"
	    CPPFLAGS="-isystem /usr/local/stow/cppunit-debug/include $CPPFLAGS"
	    LDFLAGS="-L/usr/local/stow/cppunit-debug/lib $LDFLAGS"

	    # I build my debug Boost libs with _GLIBCXX_DEBUG
	    if [ -f /usr/local/lib/libboost_regex-xgcc40-d-1_38.a ]; then
		BOOST_SUFFIX="-xgcc40-d-$BOOST_VERSION"
	    fi
	else

	    CPPFLAGS="-isystem /usr/local/stow/cppunit/include $CPPFLAGS"
	    LDFLAGS="-L/usr/local/stow/cppunit/lib $LDFLAGS"
	fi
	shift 1 ;;

    --warn)
	# Warning flags
	CXXFLAGS="$CXXFLAGS -Wall -ansi -Winvalid-pch"
	CXXFLAGS="$CXXFLAGS -Wextra"
	CXXFLAGS="$CXXFLAGS -Wcast-align"
	CXXFLAGS="$CXXFLAGS -Wcast-qual"
	CXXFLAGS="$CXXFLAGS -Wfloat-equal"
	CXXFLAGS="$CXXFLAGS -Wmissing-field-initializers"
	CXXFLAGS="$CXXFLAGS -Wno-endif-labels"
	CXXFLAGS="$CXXFLAGS -Woverloaded-virtual"
	CXXFLAGS="$CXXFLAGS -Wsign-compare"
	CXXFLAGS="$CXXFLAGS -Wsign-promo"
	CXXFLAGS="$CXXFLAGS -Wstrict-null-sentinel"
	CXXFLAGS="$CXXFLAGS -Wwrite-strings"
	CXXFLAGS="$CXXFLAGS -Wno-old-style-cast"
	CXXFLAGS="$CXXFLAGS -Wno-deprecated"
	shift 1 ;;

    --debug)
	SWITCHES="$SWITCHES --enable-debug"
	CXXFLAGS="$CXXFLAGS -g"
	LDFLAGS="$LDFLAGS -g"
	shift 1 ;;
      
    --boost)
	shift 1
	BOOST_SUFFIX="-$1"
	shift 1 ;;

    --gcov)
	CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
	shift 1 ;;

    --gprof)
        CXXFLAGS="$CXXFLAGS -g -pg"
        LDFLAGS="$LDFLAGS -g -pg"
	shift 1 ;;

    --pic)
	CXXFLAGS="$CXXFLAGS -fPIC"
	shift 1 ;;

    --opt)
	CXXFLAGS="$CXXFLAGS -fomit-frame-pointer -O3"
	shift 1 ;;

    --output)
	shift 1
	BUILD_DIR="$1"
	shift 1 ;;

    --build)
	DO_BUILD=true
	shift 1 ;;

    --switch)
	shift 1
	SWITCHES="$SWITCHES $1"
	shift 1 ;;

    --local)
	shift 1 ;;

    --release)
	SWITCHES="$SWITCHES --disable-dependency-tracking"
	CPPFLAGS="-isystem /usr/local/stow/cppunit/include $CPPFLAGS"
	#CXXFLAGS="$CXXFLAGS $ARCHFLAGS"
	#LDFLAGS="$LDFLAGS $LDARCHFLAGS"
	LDFLAGS="-L/usr/local/stow/cppunit/lib $LDFLAGS"

	shift 1 ;;

    *)
	break ;;
  esac
done


HERE="$PWD"

if [ ! "$BUILD_DIR" = "false" ]; then
    if [ ! -d "$BUILD_DIR" ]; then
	mkdir -p "$BUILD_DIR"
    fi
    cd "$BUILD_DIR" || (echo "Cannot change to $BUILD_DIR"; exit 1)
fi

SWITCHES="$SWITCHES --with-boost-suffix=$BOOST_SUFFIX"

PATH="$PYTHON_HOME/bin:$PATH" \
    "$HERE/configure" --srcdir="$HERE" \
	CXX="$CXX" CPPFLAGS="$CPPFLAGS" CXXFLAGS="$CXXFLAGS" \
	LDFLAGS="$LDFLAGS" LIBS="$LIBS" \
	$SWITCHES


# Alter the Makefile so that it's not nearly so verbose.  This makes errors
# and warnings much easier to spot.

if [ -f Makefile ]; then
    perl -i -pe 's/^\t(\$\((LIBTOOL|CXX)\).*?\.(cc|cpp))$/\t\@echo "   " CXX \$\@;$1 > \/dev\/null/;' Makefile
    perl -i -pe 's/^\tmv -f/\t\@mv -f/;' Makefile
    perl -i -pe 's/^\t(\$\((.*?)LINK\).*)/\t\@echo "   " LD \$\@;$1 > \/dev\/null/;' Makefile
fi


# If the --build flag was passed, start a build right away with the right
# options.

echo '#!/bin/bash' > make.sh
MAKE_VARS="ARCHFLAGS=\"$ARCHFLAGS\""
MAKE_VARS="$MAKE_VARS CPPFLAGS=\"$CPPFLAGS\""
MAKE_VARS="$MAKE_VARS LDFLAGS=\"$LDFLAGS\""
MAKE_VARS="$MAKE_VARS CXXFLAGS=\"$CXXFLAGS\""
MAKE_VARS="$MAKE_VARS DISTCHECK_CONFIGURE_FLAGS=\"$SWITCHES\""
echo "make $MAKE_VARS \"\$@\"" >> make.sh
chmod u+x make.sh

if [ $DO_BUILD = true ]; then
    sh -x make.sh "$@"
fi