|
diff --git a/configure b/configure index df8250e..b6800dc 100755 --- a/ configure+++ b/ configure |
|
@@ -43,196 +43,199 @@ fi |
43 | VERSION_MAJ=$(sed -n -e 's/.*QPE_VERSION "\([0-9]*\)\.[0-9]*\.[0-9]*.*".*/\1/p' <library/version.h) |
43 | VERSION_MAJ=$(sed -n -e 's/.*QPE_VERSION "\([0-9]*\)\.[0-9]*\.[0-9]*.*".*/\1/p' <library/version.h) |
44 | VERSION_MIN=$(sed -n -e 's/.*QPE_VERSION "[0-9]*\.\([0-9]\)\.[0-9]*.*".*/\1/p' <library/version.h) |
44 | VERSION_MIN=$(sed -n -e 's/.*QPE_VERSION "[0-9]*\.\([0-9]\)\.[0-9]*.*".*/\1/p' <library/version.h) |
45 | VERSION_PAT=$(sed -n -e 's/.*QPE_VERSION "[0-9]*\.[0-9]*\.\([0-9]*\).*".*/\1/p' <library/version.h) |
45 | VERSION_PAT=$(sed -n -e 's/.*QPE_VERSION "[0-9]*\.[0-9]*\.\([0-9]*\).*".*/\1/p' <library/version.h) |
46 | |
46 | |
47 | TOMAKE= |
47 | TOMAKE= |
48 | |
48 | |
49 | if grep -q 'VERSION_STR.*"3' $QTDIR/include/qglobal.h |
49 | if grep -q 'VERSION_STR.*"3' $QTDIR/include/qglobal.h |
50 | then |
50 | then |
51 | QT3=yes |
51 | QT3=yes |
52 | else |
52 | else |
53 | QT3=no |
53 | QT3=no |
54 | fi |
54 | fi |
55 | |
55 | |
56 | # Parse the arguments, setting things to "yes" or "no". |
56 | # Parse the arguments, setting things to "yes" or "no". |
57 | |
57 | |
58 | while [ -n "$1" ]; do |
58 | while [ -n "$1" ]; do |
59 | case $1 in |
59 | case $1 in |
60 | -platform|-xplatform) # No difference since we don't need to build moc, etc. |
60 | -platform|-xplatform) # No difference since we don't need to build moc, etc. |
61 | shift; PLATFORM=$1 |
61 | shift; PLATFORM=$1 |
62 | ;; |
62 | ;; |
63 | -release) |
63 | -release) |
64 | DEBUG= |
64 | DEBUG= |
65 | ;; |
65 | ;; |
66 | -debug) |
66 | -debug) |
67 | DEBUG=-debug |
67 | DEBUG=-debug |
68 | ;; |
68 | ;; |
69 | -shared) |
69 | -shared) |
70 | SHARING=shared |
70 | SHARING=shared |
71 | ;; |
71 | ;; |
72 | -static) |
72 | -static) |
73 | SHARING=static |
73 | SHARING=static |
74 | ;; |
74 | ;; |
75 | -qconfig) |
75 | -qconfig) |
76 | # optional way to specify the qconfig-qpe.h is to pass -qconfig qpe |
76 | # optional way to specify the qconfig-qpe.h is to pass -qconfig qpe |
77 | shift; QCONFIGARG=DEFINES+=QCONFIG='\"'$1'\"' # Don't quote me on that. |
77 | shift; QCONFIGARG=DEFINES+=QCONFIG='\"'$1'\"' # Don't quote me on that. |
78 | ;; |
78 | ;; |
79 | -make) |
79 | -make) |
80 | shift; TOMAKE="$TOMAKE $1" |
80 | shift; TOMAKE="$TOMAKE $1" |
81 | ;; |
81 | ;; |
82 | -qt3) |
82 | -qt3) |
83 | QT3=yes |
83 | QT3=yes |
84 | ;; |
84 | ;; |
85 | *) |
85 | *) |
86 | HELP=yes;; |
86 | HELP=yes;; |
87 | esac |
87 | esac |
88 | shift |
88 | shift |
89 | done |
89 | done |
90 | |
90 | |
91 | TARGET=configs/$PLATFORM-$SHARING$DEBUG |
91 | TARGET=configs/$PLATFORM-$SHARING$DEBUG |
92 | |
92 | |
93 | if [ '!' -f $TARGET ] |
93 | if [ '!' -f $TARGET ] |
94 | then |
94 | then |
95 | if [ -f configs/linux-$PLATFORM-g++-$SHARING$DEBUG ] |
95 | if [ -f configs/linux-$PLATFORM-g++-$SHARING$DEBUG ] |
96 | then |
96 | then |
97 | TARGET=configs/linux-$PLATFORM-g++-$SHARING$DEBUG |
97 | TARGET=configs/linux-$PLATFORM-g++-$SHARING$DEBUG |
98 | PLATFORM=linux-$PLATFORM-g++ |
98 | PLATFORM=linux-$PLATFORM-g++ |
99 | else |
99 | else |
100 | echo |
100 | echo |
101 | echo ' The specified platform/compiler not supported: ' $TARGET |
101 | echo ' The specified platform/compiler not supported: ' $TARGET |
102 | echo |
102 | echo |
103 | exit 2 |
103 | exit 2 |
104 | fi |
104 | fi |
105 | fi |
105 | fi |
106 | |
106 | |
107 | # Next, emit a usage message if something failed. |
107 | # Next, emit a usage message if something failed. |
108 | |
108 | |
109 | if [ "$HELP" = "yes" ]; then |
109 | if [ "$HELP" = "yes" ]; then |
110 | cat <<EOF |
110 | cat <<EOF |
111 | Usage: $0 [-debug] [-release] [-shared] [-static] [-qt3] [-platform ...] |
111 | Usage: $0 [-debug] [-release] [-shared] [-static] [-qt3] [-platform ...] |
112 | |
112 | |
113 | The defaults (*) are usually acceptable. Here is a short explanation of |
113 | The defaults (*) are usually acceptable. Here is a short explanation of |
114 | each option: |
114 | each option: |
115 | |
115 | |
116 | * -release ........... Compile and link Qt with debugging turned off. |
116 | * -release ........... Compile and link Qt with debugging turned off. |
117 | -debug ............. Compile and link Qt with debugging turned on. |
117 | -debug ............. Compile and link Qt with debugging turned on. |
118 | |
118 | |
119 | * -shared ............ Create and use a shared Qt library (libqt.so) |
119 | * -shared ............ Create and use a shared Qt library (libqt.so) |
120 | -static ............ Create and use a static Qt library (libqt.a) |
120 | -static ............ Create and use a static Qt library (libqt.a) |
121 | |
121 | |
122 | -qt3 ............... Configure for use with Qt 3.x |
122 | -qt3 ............... Configure for use with Qt 3.x |
123 | |
123 | |
124 | -platform target ... The platform you are building on ($PLATFORM) |
124 | -platform target ... The platform you are building on ($PLATFORM) |
125 | EOF |
125 | EOF |
126 | exit 0; |
126 | exit 0; |
127 | fi |
127 | fi |
128 | |
128 | |
129 | CUSTOM=`echo $PLATFORM | sed -n -e "s/.*-\(.*\)-.*/\1/p"` |
129 | CUSTOM=`echo $PLATFORM | sed -n -e "s/.*-\(.*\)-.*/\1/p"` |
130 | |
130 | |
131 | if [ -f library/custom-$CUSTOM.h ] |
131 | if [ -f library/custom-$CUSTOM.h ] |
132 | then |
132 | then |
133 | rm -f library/custom.h |
133 | rm -f library/custom.h |
134 | ln -s custom-$CUSTOM.h library/custom.h |
134 | ln -s custom-$CUSTOM.h library/custom.h |
135 | fi |
135 | fi |
136 | |
136 | |
137 | mkdir -p include/qpe |
137 | mkdir -p include/qpe |
138 | ( cd include/qpe && rm -f *.h; ln -s ../../library/*.h .; ln -s ../../library/backend/*.h .; rm -f *_p.h; ) |
138 | ( cd include/qpe && rm -f *.h; ln -s ../../library/*.h .; ln -s ../../library/backend/*.h .; rm -f *_p.h; ) |
139 | |
139 | mkdir -p include/qtopia |
| |
140 | ( cd include/qtopia && rm -f *.h; ln -s ../../library/*.h .; ) |
| |
141 | mkdir -p include/qtopia/private |
| |
142 | ( cd include/qtopia/private && rm -f *.h; ln -s ../../../library/backend/*.h .; ) |
140 | mkdir -p include/opie |
143 | mkdir -p include/opie |
141 | ( cd include/opie && rm -f *.h; ln -s ../../libopie/*.h .; rm -f *_p.h; ) |
144 | ( cd include/opie && rm -f *.h; ln -s ../../libopie/*.h .; rm -f *_p.h; ) |
142 | ( cd include/opie && ln -s ../../libsql/*.h . ) |
145 | ( cd include/opie && ln -s ../../libsql/*.h .; ) |
143 | |
146 | |
144 | echo Creating makefiles... |
147 | echo Creating makefiles... |
145 | |
148 | |
146 | # Set version for library directly |
149 | # Set version for library directly |
147 | # Version 1.5.0 right now for compat. |
150 | # Version 1.5.0 right now for compat. |
148 | sed -e 's/^\(VERSION.*= \).*/\1'1.5.0.$VERSION_PAT/ <library/library.pro >library/library.pro-v |
151 | sed -e 's/^\(VERSION.*= \).*/\1'1.5.0.$VERSION_PAT/ <library/library.pro >library/library.pro-v |
149 | mv library/library.pro-v library/library.pro |
152 | mv library/library.pro-v library/library.pro |
150 | |
153 | |
151 | if [ "$QT3" = yes ] |
154 | if [ "$QT3" = yes ] |
152 | then |
155 | then |
153 | VCONFIG="CONFIG+=qt3" |
156 | VCONFIG="CONFIG+=qt3" |
154 | else |
157 | else |
155 | VCONFIG="CONFIG+=qt2" |
158 | VCONFIG="CONFIG+=qt2" |
156 | fi |
159 | fi |
157 | |
160 | |
158 | if [ -f $TMAKEPATH/tmake.conf ] |
161 | if [ -f $TMAKEPATH/tmake.conf ] |
159 | then |
162 | then |
160 | # You have tmake. We'll regenerate the file for you... |
163 | # You have tmake. We'll regenerate the file for you... |
161 | echo "Makefiles will be regenerated." |
164 | echo "Makefiles will be regenerated." |
162 | fi |
165 | fi |
163 | |
166 | |
164 | H=`pwd` |
167 | H=`pwd` |
165 | if [ -z "$TOMAKE" ] |
168 | if [ -z "$TOMAKE" ] |
166 | then |
169 | then |
167 | TOMAKE=`make showcomponents` |
170 | TOMAKE=`make showcomponents` |
168 | fi |
171 | fi |
169 | |
172 | |
170 | for a in $TOMAKE ; do |
173 | for a in $TOMAKE ; do |
171 | N=$a/Makefile |
174 | N=$a/Makefile |
172 | M=$a/Makefile.in |
175 | M=$a/Makefile.in |
173 | O=$a/Makefile.add |
176 | O=$a/Makefile.add |
174 | f=`basename $a` |
177 | f=`basename $a` |
175 | |
178 | |
176 | if [ -f "$TMAKEPATH/tmake.conf" -a -f "$a/$f.pro" ] |
179 | if [ -f "$TMAKEPATH/tmake.conf" -a -f "$a/$f.pro" ] |
177 | then |
180 | then |
178 | ( cd $a; |
181 | ( cd $a; |
179 | TMAKEPATH=$QTDIR/tmake:$TMAKEPATH \ |
182 | TMAKEPATH=$QTDIR/tmake:$TMAKEPATH \ |
180 | tmake $QCONFIGARG CONFIG+=embedded $VCONFIG \ |
183 | tmake $QCONFIGARG CONFIG+=embedded $VCONFIG \ |
181 | -t $H/qt/tmake/propagate.t $f.pro | |
184 | -t $H/qt/tmake/propagate.t $f.pro | |
182 | sed -e "s|$QTDIR|\$(QTDIR)|g" -e "s|$OPIEDIR|\$(OPIEDIR)|g" >Makefile.in; |
185 | sed -e "s|$QTDIR|\$(QTDIR)|g" -e "s|$OPIEDIR|\$(OPIEDIR)|g" >Makefile.in; |
183 | ) |
186 | ) |
184 | echo -n "." |
187 | echo -n "." |
185 | #echo Building $N.. |
188 | #echo Building $N.. |
186 | appname=`grep '^TARGET' $a/$f.pro | sed 's/^TARGET.*=//' | tr -d " \t"` |
189 | appname=`grep '^TARGET' $a/$f.pro | sed 's/^TARGET.*=//' | tr -d " \t"` |
187 | translation=`grep '^TRANSLATION.*[^+]=.*' $a/$f.pro | sed 's,^TRANSL.*=.*i18n\/.*\/,,' | sed 's/ //g' | sed 's,\.ts.*,,' | sed 's,^lib,,' ` |
190 | translation=`grep '^TRANSLATION.*[^+]=.*' $a/$f.pro | sed 's,^TRANSL.*=.*i18n\/.*\/,,' | sed 's/ //g' | sed 's,\.ts.*,,' | sed 's,^lib,,' ` |
188 | if [ -n "$translation" -a -n "$appname" ] |
191 | if [ -n "$translation" -a -n "$appname" ] |
189 | then |
192 | then |
190 | if [ "$appname" != "$translation" ] |
193 | if [ "$appname" != "$translation" ] |
191 | then |
194 | then |
192 | echo |
195 | echo |
193 | echo "Warning: translation and appname disagree in $a/$f.pro" |
196 | echo "Warning: translation and appname disagree in $a/$f.pro" |
194 | fi |
197 | fi |
195 | fi |
198 | fi |
196 | |
199 | |
197 | fi |
200 | fi |
198 | |
201 | |
199 | cat > $N <<EOF |
202 | cat > $N <<EOF |
200 | ############################################################################# |
203 | ############################################################################# |
201 | # Automatically generated from $M |
204 | # Automatically generated from $M |
202 | # Build options from $1 |
205 | # Build options from $1 |
203 | ############################################################################# |
206 | ############################################################################# |
204 | |
207 | |
205 | EOF |
208 | EOF |
206 | |
209 | |
207 | SED= |
210 | SED= |
208 | PLATFORM_CFLAGS= |
211 | PLATFORM_CFLAGS= |
209 | |
212 | |
210 | if [ "$f" = "embeddedkonsole" ] |
213 | if [ "$f" = "embeddedkonsole" ] |
211 | then |
214 | then |
212 | case $PLATFORM in |
215 | case $PLATFORM in |
213 | *x86*|*generic*|*ipaq*|*sharp*) |
216 | *x86*|*generic*|*ipaq*|*sharp*) |
214 | SED="$SED /^LIBS.*=/s/\$/ -lutil/;" |
217 | SED="$SED /^LIBS.*=/s/\$/ -lutil/;" |
215 | PLATFORM_CFLAGS="-DHAVE_OPENPTY" |
218 | PLATFORM_CFLAGS="-DHAVE_OPENPTY" |
216 | ;; *) |
219 | ;; *) |
217 | SED= |
220 | SED= |
218 | esac |
221 | esac |
219 | elif [ "$f" = "libmpeg3" ] |
222 | elif [ "$f" = "libmpeg3" ] |
220 | then |
223 | then |
221 | # Patch our Makefile.in file with the platform specifics for the libmpeg3 library |
224 | # Patch our Makefile.in file with the platform specifics for the libmpeg3 library |
222 | # Use the C++ compiler to compile the .c files (because the fixed-point classes are C++ code) |
225 | # Use the C++ compiler to compile the .c files (because the fixed-point classes are C++ code) |
223 | SED='s/\$(CC)/\$(CXX)/;' |
226 | SED='s/\$(CC)/\$(CXX)/;' |
224 | case $PLATFORM |
227 | case $PLATFORM |
225 | in |
228 | in |
226 | # For x86 turn on using floating point, compile mmx and css code |
229 | # For x86 turn on using floating point, compile mmx and css code |
227 | *x86*) |
230 | *x86*) |
228 | # "-funroll-loops -fomit-frame-pointer -malign-loops=2 -malign-jumps=2 -malign-functions=2 -march=i486" |
231 | # "-funroll-loops -fomit-frame-pointer -malign-loops=2 -malign-jumps=2 -malign-functions=2 -march=i486" |
229 | PLATFORM_CFLAGS="-DHAVE_MMX -DHAVE_CSS" |
232 | PLATFORM_CFLAGS="-DHAVE_MMX -DHAVE_CSS" |
230 | SED="$SED /SOURCES.*=/s/=/= video\\/mmxidct.S video\\/reconmmx.s\ /;" |
233 | SED="$SED /SOURCES.*=/s/=/= video\\/mmxidct.S video\\/reconmmx.s\ /;" |
231 | # For generic turn on using floating point |
234 | # For generic turn on using floating point |
232 | ;; *generic*) |
235 | ;; *generic*) |
233 | PLATFORM_CFLAGS="" |
236 | PLATFORM_CFLAGS="" |
234 | # For the ipaq use fixed point maths, don't compile the mmx or css code |
237 | # For the ipaq use fixed point maths, don't compile the mmx or css code |
235 | ;; *ipaq*|*sharp*) |
238 | ;; *ipaq*|*sharp*) |
236 | PLATFORM_CFLAGS="-DUSE_FIXED_POINT" |
239 | PLATFORM_CFLAGS="-DUSE_FIXED_POINT" |
237 | ;; *) |
240 | ;; *) |
238 | # For 'other platforms', turn off optimizations and use fixed point |
241 | # For 'other platforms', turn off optimizations and use fixed point |
|